论坛全局菜单下方 - TICKMILL 285X70论坛全局菜单下方 - ThinkMarkets285X70论坛全局菜单下方 - 荔枝返现285X70论坛全局菜单下方 -  icmarkets285X70
查看:1024回复:2
草龙
注册时间2004-12-17
[MT4指标]osa趋势指示指标
楼主发表于:2014-04-03 14:05只看该作者倒序浏览
1楼 电梯直达
电梯直达
主图指标 附图指标, 在osa的基础上显示涨跌以及角度线 mt4指标类型:趋势指标 是否能用在mt4手机版上:否 是否含有未来函数:无 //+------------------------------------------------------------------+ //| FX5_Divergence_V2.1.mq4 | //| FX5 | //| [email protected] | //+------------------------------------------------------------------+ #property copyright "Copyright ? 2007, FX5" #property link "[email protected]" //---- #property indicator_separate_window #property indicator_buffers 5 #property indicator_color1 LimeGreen #property indicator_color2 FireBrick #property indicator_color3 Green #property indicator_color4 Red //---- input parameters extern string separator1 = "*** OSMA Settings ***"; extern int fastEMA = 12; extern int slowEMA = 26; extern int signal = 9; extern string separator2 = "*** Indicator Settings ***"; extern bool drawDivergenceLines = true; extern bool displayAlert = true; //---- buffers double upOsMA; double downOsMA; double bullishDivergence; double bearishDivergence; double OsMA; //---- static datetime lastAlertTime; //+------------------------------------------------------------------+ //| Custom indicator initialization function | //+------------------------------------------------------------------+ int init() { //---- indicators SetIndexStyle(0, DRAW_HISTOGRAM, STYLE_SOLID, 2); SetIndexStyle(1, DRAW_HISTOGRAM, STYLE_SOLID, 2); SetIndexStyle(2, DRAW_ARROW); SetIndexStyle(3, DRAW_ARROW); SetIndexStyle(4, DRAW_NONE); //---- SetIndexBuffer(0, upOsMA); SetIndexBuffer(1, downOsMA); SetIndexBuffer(2, bullishDivergence); SetIndexBuffer(3, bearishDivergence); SetIndexBuffer(4, OsMA); //---- SetIndexArrow(2, 233); SetIndexArrow(3, 234); //---- IndicatorDigits(Digits + 2); IndicatorShortName("FX5_Divergence_v2.1(" + fastEMA + "," + slowEMA + "," + signal + ")"); return(0); } //+------------------------------------------------------------------+ //| Custom indicator deinitialization function | //+------------------------------------------------------------------+ int deinit() { for(int i = ObjectsTotal() - 1; i >= 0; i--) { string label = ObjectName(i); if(StringSubstr(label, 0, 14) != "DivergenceLine") continue; ObjectDelete(label); } return(0); } //+------------------------------------------------------------------+ //| Custom indicator iteration function | //+------------------------------------------------------------------+ int start() { int countedBars = IndicatorCounted(); if(countedBars < 0) countedBars = 0; CalculateIndicator(countedBars); return(0); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void CalculateIndicator(int countedBars) { for(int i = Bars - countedBars; i >= 0; i--) { CalculateOsMA(i); CatchBullishDivergence(i + 2); CatchBearishDivergence(i + 2); } } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void CalculateOsMA(int i) { OsMA = iOsMA(NULL, 0, fastEMA, slowEMA, signal, PRICE_CLOSE, i); //---- if(OsMA > 0) { upOsMA = OsMA; downOsMA = 0; } else if(OsMA < 0) { downOsMA = OsMA; upOsMA = 0; } else { upOsMA = 0; downOsMA = 0; } } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void CatchBullishDivergence(int shift) { if(IsIndicatorTrough(shift) == false) return; int currentTrough = shift; int lastTrough = GetIndicatorLastTrough(shift); if(OsMA[currentTrough] > OsMA[lastTrough] && Low[currentTrough] < Low[lastTrough]) { bullishDivergence[currentTrough] = OsMA[currentTrough]; if(drawDivergenceLines == true) { DrawPriceTrendLine(Time[currentTrough], Time[lastTrough], Low[currentTrough], Low[lastTrough], Green, STYLE_SOLID); DrawIndicatorTrendLine(Time[currentTrough], Time[lastTrough], OsMA[currentTrough], OsMA[lastTrough], Green, STYLE_SOLID); } if(displayAlert == true) DisplayAlert("Classical bullish divergence on: ", currentTrough); } if(OsMA[currentTrough] < OsMA[lastTrough] && Low[currentTrough] > Low[lastTrough]) { bullishDivergence[currentTrough] = OsMA[currentTrough]; if(drawDivergenceLines == true) { DrawPriceTrendLine(Time[currentTrough], Time[lastTrough], Low[currentTrough], Low[lastTrough], Green, STYLE_DOT); DrawIndicatorTrendLine(Time[currentTrough], Time[lastTrough], OsMA[currentTrough], OsMA[lastTrough], Green, STYLE_DOT); } if(displayAlert == true) DisplayAlert("Reverse bullish divergence on: ", currentTrough); } } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void CatchBearishDivergence(int shift) { if(IsIndicatorPeak(shift) == false) return; int currentPeak = shift; int lastPeak = GetIndicatorLastPeak(shift); if(OsMA[currentPeak] < OsMA[lastPeak] && High[currentPeak] > High[lastPeak]) { bearishDivergence[currentPeak] = OsMA[currentPeak]; if(drawDivergenceLines == true) { DrawPriceTrendLine(Time[currentPeak], Time[lastPeak], High[currentPeak], High[lastPeak], Red, STYLE_SOLID); DrawIndicatorTrendLine(Time[currentPeak], Time[lastPeak], OsMA[currentPeak], OsMA[lastPeak], Red, STYLE_SOLID); } if(displayAlert == true) DisplayAlert("Classical bearish divergence on: ", currentPeak); } if(OsMA[currentPeak] > OsMA[lastPeak] && High[currentPeak] < High[lastPeak]) { bearishDivergence[currentPeak] = OsMA[currentPeak]; if(drawDivergenceLines == true) { DrawPriceTrendLine(Time[currentPeak], Time[lastPeak], High[currentPeak], High[lastPeak], Red, STYLE_DOT); DrawIndicatorTrendLine(Time[currentPeak], Time[lastPeak], OsMA[currentPeak], OsMA[lastPeak], Red, STYLE_DOT); } if(displayAlert == true) DisplayAlert("Reverse bearish divergence on: ", currentPeak); } } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ bool IsIndicatorPeak(int shift) { if(OsMA[shift] > 0 && OsMA[shift] > OsMA[shift+1] && OsMA[shift] > OsMA[shift-1]) { for(int i = shift + 1; i < Bars; i++) { if(OsMA < 0) return(true); if(OsMA > OsMA[shift]) break; } } return(false); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ bool IsIndicatorTrough(int shift) { if(OsMA[shift] < 0 && OsMA[shift] < OsMA[shift+1] && OsMA[shift] < OsMA[shift-1]) { for(int i = shift + 1; i < Bars; i++) { if(OsMA > 0) return(true); if(OsMA < OsMA[shift]) break; } } return(false); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ int GetIndicatorLastPeak(int shift) { for(int i = shift + 5; i < Bars; i++) { if(OsMA >= OsMA[i+1] && OsMA > OsMA[i+2] && OsMA >= OsMA[i-1] && OsMA > OsMA[i-2]) return(i); } return(-1); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ int GetIndicatorLastTrough(int shift) { for(int i = shift + 5; i < Bars; i++) { if(OsMA <= OsMA[i+1] && OsMA < OsMA[i+2] && OsMA <= OsMA[i-1] && OsMA < OsMA[i-2]) return(i); } return(-1); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void DisplayAlert(string message, int shift) { if(shift <= 2 && Time[shift] != lastAlertTime) { lastAlertTime = Time[shift]; Alert(message, Symbol(), " , ", Period(), " minutes chart"); } } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void DrawPriceTrendLine(datetime x1, datetime x2, double y1, double y2, color lineColor, double style) { string label = "DivergenceLine2.1# " + DoubleToStr(x1, 0); ObjectDelete(label); ObjectCreate(label, OBJ_TREND, 0, x1, y1, x2, y2, 0, 0); ObjectSet(label, OBJPROP_RAY, 0); ObjectSet(label, OBJPROP_COLOR, lineColor); ObjectSet(label, OBJPROP_STYLE, style); } //+------------------------------------------------------------------+ //| | //+------------------------------------------------------------------+ void DrawIndicatorTrendLine(datetime x1, datetime x2, double y1, double y2, color lineColor, double style) { int indicatorWindow = WindowFind("FX5_Divergence_v2.1(" + fastEMA + "," + slowEMA + "," + signal + ")"); if(indicatorWindow < 0) return; string label = "DivergenceLine2.1$# " + DoubleToStr(x1, 0); ObjectDelete(label); ObjectCreate(label, OBJ_TREND, indicatorWindow, x1, y1, x2, y2, 0, 0); ObjectSet(label, OBJPROP_RAY, 0); ObjectSet(label, OBJPROP_COLOR, lineColor); ObjectSet(label, OBJPROP_STYLE, style); } //+------------------------------------------------------------------+ FX5_Divergence_V2%5B1%5D.1.jpgFX5_Divergence_V2%5B1%5D.1.jpg
TK29帖子1楼右侧xm竖版广告90-240
个性签名

阅尽天下指标
搬砖开始,始于2014

广告
TK30+TK31帖子一樓廣告
TK30+TK31帖子一樓廣告
flyinglala
注册时间2015-04-18
发表于:2015-04-20 11:58只看该作者
2楼
缺钱,灌水赚通宝,谢谢分享!!

本站免责声明:

1、本站所有广告及宣传信息均与韬客无关,如需投资请依法自行决定是否投资、斟酌资金安全及交易亏损风险;

2、韬客是独立的、仅为投资者提供交流的平台,网友发布信息不代表韬客的观点与意思表示,所有因网友发布的信息而造成的任何法律后果、风险与责任,均与韬客无关;

3、金融交易存在极高法律风险,未必适合所有投资者,请不要轻信任何高额投资收益的诱导而贸然投资;投资保证金交易导致的损失可能超过您投入的资金和预期。请您考虑自身的投资经验及风险承担能力,进行合法、理性投资;

4、所有投资者的交易帐户应仅限本人使用,不应交由第三方操作,对于任何接受第三方喊单、操盘、理财等操作的投资和交易,由此导致的任何风险、亏损及责任由投资者个人自行承担;

5、韬客不隶属于任何券商平台,亦不受任何第三方控制,韬客不邀约客户投资任何保证金交易,不接触亦不涉及投资者的任何资金及账户信息,不代理任何交易操盘行为,不向客户推荐任何券商平台,亦不存在其他任何推荐行为。投资者应自行选择券商平台,券商平台的任何行为均与韬客无关。投资者注册及使用韬客即表示其接受和认可上述声明,并自行承担法律风险。

版权所有:韬客外汇论坛 www.talkfx.com 联络我们:[email protected]