Miscellaneous
0
Views
0
Downloads
0
Favorites
GeigerTicks
//+------------------------------------------------------------------+
//| GeigerTicks.mq4 |
//+------------------------------------------------------------------+
#property copyright "Nanaos"
#property link "http://www.nanaos.net"
#property indicator_separate_window
#property indicator_buffers 1
#property indicator_color1 Navy
//---- buffers
extern int MaxDrawTicks=500;
extern bool SoundOn = true;
extern string TickSoundUp = "tickup.wav";
extern string TickSoundDown = "tickdown.wav";
double ExtMapBuffer1[];
int myBars;
int tickCounter;
int delimeterCounter;
//+------------------------------------------------------------------+
//| Custom indicator initialization function |
//+------------------------------------------------------------------+
int init()
{
//---- indicators
SetIndexStyle(0,DRAW_LINE);
SetIndexBuffer(0, ExtMapBuffer1);
SetIndexEmptyValue(0,0.0);
//Print("Îáíóëÿåì òèêè");
for (int i=Bars-1;i>=0;i--) ExtMapBuffer1[i]=0.0;
//----
return(0);
}
//+------------------------------------------------------------------+
//| Custom indicator deinitialization function |
//+------------------------------------------------------------------+
int deinit()
{
//----
//----
return(0);
}
//+------------------------------------------------------------------+
//| ñäâèíåì ìàññèâ |
//+------------------------------------------------------------------+
void SetDelimeter()
{
//----
//return;
string delimeterDate=TimeToStr(Time[0]);
if (myBars!=0)
{
//Print("Ñòàâèì ðàçäåëèòåëü");
int handle=WindowFind("GeigerTicks");
if(!ObjectCreate(delimeterDate,OBJ_VLINE,handle,Time[0],0))
{
// Alert("Íåäà÷íàÿ ïîïûòêà ñîçäàíèÿ ðàçäåëèòåëÿ â îêíå ", handle," ïî âðåìåíè ",TimeToStr(CurTime()));
Print("Îøèáêà ¹",GetLastError(),", èìÿ ðàçäåëèòåëÿ ",delimeterDate);
}
else
{
ObjectSet(delimeterDate,OBJPROP_COLOR,DarkGreen);
ObjectSet(delimeterDate,OBJPROP_STYLE,STYLE_DASHDOT);
ObjectsRedraw();
}
}
//----
return(0);
}
//+------------------------------------------------------------------+
//| ñäâèíåì ìàññèâ |
//+------------------------------------------------------------------+
void ShiftArray()
{
//----
int V_lines;
string delimeterName;
datetime firstTime;
int BarFirstTime;
if (tickCounter>2*MaxDrawTicks)
{
for (int i=tickCounter;i>=MaxDrawTicks;i--) ExtMapBuffer1[i]=0.0;
tickCounter=MaxDrawTicks;
}
for(int cnt=tickCounter;cnt>0;cnt--)
{
ExtMapBuffer1[cnt]=ExtMapBuffer1[cnt-1];
}
V_lines=ObjectsTotal();
for (int z=0;z<V_lines;z++)
{
delimeterName=ObjectName(z);
if (ObjectFind(delimeterName)!=-1)
{
if (ObjectType(delimeterName)==OBJ_VLINE)
{
firstTime=ObjectGet(delimeterName,OBJPROP_TIME1);
BarFirstTime=iBarShift(NULL,0,firstTime);
firstTime=Time[BarFirstTime+1];
ObjectSet(delimeterName,OBJPROP_TIME1,firstTime);
}
}
}
//----
return(0);
}
//+------------------------------------------------------------------+
//| ïðèçíàê íîâîãî áàðà |
//+------------------------------------------------------------------+
bool isNewBar()
{
//----
bool res=false;
if (myBars!=Bars)
{
res=true;
myBars=Bars;
}
//----
return(res);
}
//+------------------------------------------------------------------+
//| Custom indicator iteration function |
//+------------------------------------------------------------------+
int start()
{
int counted_bars=IndicatorCounted();
//----
if (isNewBar())
{
// óñòàíîâèòü ðàçäåëèòåëü
//tickCounter++;
SetDelimeter();
ExtMapBuffer1[0]=Bid;
}
else
{
tickCounter++;
ShiftArray();
ExtMapBuffer1[0]=Bid;
if (SoundOn)
{
if (ExtMapBuffer1[1] < Bid)
{
PlaySound(TickSoundUp);
}
else
{
PlaySound(TickSoundDown);
}
}
}
//----
return(0);
}
//+------------------------------------------------------------------+
Comments
Markdown Formatting Guide
# H1
## H2
### H3
**bold text**
*italicized text*
[title](https://www.example.com)

`code`
```
code block
```
> blockquote
- Item 1
- Item 2
1. First item
2. Second item
---