MQL4の記事一覧

FXメタトレーダー実践プログラミング

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

お久しぶりです。

年末からやたら忙しい状態がつづいていて、部署が変わったから楽になるかと思ったら、もっとひどくなってしまいました。

そんな訳で、更新もままならない状況です。

楽しみにしている方には、申し訳ないと思います。

出来る範囲で、ゆっくりとやっていきたいので期待せずにまっていてください。

ちょっと前に見つけて、今日買った本について

FXメタトレーダー実践プログラミング」という本です。

FXメタトレーダー実践プログラミング

FXメタトレーダー実践プログラミング

価格:2,940円(税込、送料別)

前作の「FXメタトレーダー入門」の続編に当たるものです。

FXメタトレーダー入門

FXメタトレーダー入門

価格:2,940円(税込、送料別)

FXメタトレーダー実践プログラミングは、結構いいですよ。

前作は、メタトレーダーの使い方とプログラムの触りでしたが、今回のはやりたい事をだいたい実現できるだけの情報が載っています。

目次はこんな感じ。

  • 第1章 メタトレーダーの構成を知る(メタトレーダーを使いこなす前に/メタトレーダーとMQL4プログラミング)
  • 第2章 カスタム指標プログラムで独自のテクニカル分析(カスタム指標プログラムの基本/組み込みテクニカル指標関数の使い方/オブジェクトを利用したカスタム指標/テクニカル指標のデータをファイルに出力)
  • 第3章 トレード関数で柔軟な注文を実現(トレード関数を使いこなす/トレード時のエラーチェック/トレード関数のライブラリー化/エキスパートプログラムによる注文)
  • 第4章 エキスパートプログラムでシステムトレード自由自在(売買システムの基本構成/仕掛けのパターン/手仕舞いのパターン/そのほかのシステムのパターン/ストラテジーテスターでの検証)
  • 第5章 MQL4をさらに使いこなしたい人のために(データの型/プリプロセッサ命令/変数の種類/配列の種類/数学関数/オブジェクトの表示/ファイルの入出力/文字列に関する関数/日時に関する関数/マーケット情報/口座情報/関数のライブラリー化)
  • 付録A MQL4関数一覧
  • 付録B 参考図書

いい感じで知りたい情報が分かります。

多少なり、プログラムの経験があればそれなりのプログラムが組めるようになります。

興味のある方は、本屋で立ち読みしてみてください。

タグ

インジケータからEAを作ってみるときに

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

かなりご無沙汰しています。

仕事が忙しくてなかなか更新できなかったり、プライベートでも子供が生まれたりと、どこにいても忙しい毎日をおくっているため、なかなか更新できないでいます。

ちょっと質問を受けたので、その回答を

 

質問:

インジケータのソースが手に入ったので、それをベースにEAを作ろうと思っていますがどこをどうしていいかわかりません。

 

まあ、こんな感じの質問です。

簡単に回答してしまうとインジケータからEAを作るのは、かなりプログラムがわかっていないと難しいです。

理由は簡単で、足単位で計算しているプログラムを必要な足の情報だけを取得するように変更する必要があるからです。

だいたい、ソースが提供されているインジケータは、サンプルみたいなものでかなり適当に作られていることが多いです。

いい感じに関数化してあり、部品として流用可能ならあまりわからなくてもEA化ができるかもしれませんが、再利用など考えていないことが多いので整理しなおす必要があります。

 

この辺は、経験がものを言うのでチャレンジしてもらうことはものすごくいいことです。

でも、難しいじゃないですか。

 

ということで、なるべく簡単にインジケータのデータをEAで利用するには、「iCustom」を利用してインジケータをそのまま利用してしまうことです。

インジケータの情報を取得する2で説明しているので、そっちの方向でまずがんばってみてください。

タグ

オーダーやオーダー変更時に失敗する場合

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

EAでのトレイルストップがうまくいかない質問を受けたので、たぶんこれかな?ってのを回答しておきます。

わたしも初期はこれで悩んだので。。。

OrderSendOrderModifyを行うとエラーになることがあると思います。

こんなとき何が悪いかちょっと確認してほしいことがあります。

1.注文の方向でAskとBidが間違っていないか。

2.StoplossとTakeprofitの幅

の2点です。

1番は、結構よくやります。

2番は、ストップレベルポイントというのがあって、現在のポイントからいくつか離さないといけないというルールがあります。

だいたい、20pipsぐらいだと思います。

この値は、会社などで違ってきます。

調べる方法は、

MarketInfo(Symbol(),MODE_STOPLEVEL);

を使います。

インジケーターでもEAでもいいので、適当なのを作って以下のソースを書いてみてください。

Comment(”ストップレベル:”,MarketInfo(Symbol(),MODE_STOPLEVEL));

これで、最低離さなければいけない値が表示されます。

もう一つ気をつけなければいけないのは、スリップです。

注文するときにスリップページをいくつにするか指定していますよね。

3pipsを指定していたら、20+3で23離す必要があります。

何でもいいけど、20pipsは大きいですよね。

だから、私がEAを作るときは、LossとTakeは保険(通信障害などの)でかける程度にして、実際のクローズはEAにやらせるようにしています。

これだと、1pipsでも狙えます。

あまり細かいとスリップが大きいとダメですがね。

参考にしてみてください。

タグ

iADXって?

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

質問にあったので、iADXについて。

まず、どこの資料を参考にするか。

私の場合は、

mt4 (MetaTrader4)使い倒シストレ

を愛用しています。

無料で利用できるMQL4の日本語リファレンスマニュアルとしては、一番便利だと思います。

MT4関係で調べ物をするときに一番利用しているサイトと言っても過言ではありません。

すべての関数を隅々までのぞいてみると、気がつかなかったことが見えてくると思いますよ。

分からない単語が出てきたら、検索してみてください。

きっとわかりやすい説明のサイトがあると思います。

で、本題のiADX



double iADX( string symbol, int timeframe, int period, int applied_price, int mode, int shift)



symbol – 計算したい通貨名。NULLを指定すると現在の通貨。

timeframe – 時間枠。時間枠列挙型のどれか。0は現在の時間枠。

period – 計算で使用する足の数

applied_price – 適用価格。これは価格定数のどれかをとる。

mode – インジケータの線指定。これはインジケータラインの値をとる。

shift – 現在の足から何本前の値を出したいか



適用価格

PRICE_CLOSE 終値

PRICE_OPEN 始値

PRICE_HIGH 高値

PRICE_LOW 安値

PRICE_MEDIAN 中央値、(high + low)/2

PRICE_TYPICAL 代表値、(high + low + close)/3

PRICE_WEIGHTED 重み付け値、(high + low + close + close)/4



インジケータの線指定

MODE_MAIN インジケータの基本線

MODE_PLUSDI +DIインジケータ線

MODE_MINUSDI -DIインジケータ線

こんな感じの関数仕様です。



質問をくださった方は、MODEの意味が分からないといっていました。

実はこの関数、ADXといいながら、DMIも表示できてしまいます。

ここが分かりにくかったところなんだと思います。

でも、普通は一緒に使うので利用しやすいようにとの配慮でしょう。



ADX(Average Directional Movement Index):トレンドの強さを測定する指標

DMI(Directional Movement Index):一般的に方向性指数といわれる



ADXは、MODE_MAIN。

DMIは、MODE_PLUSDI、MODE_MINUSDI

で表します。



簡単に説明すると、ADXでトレンドの向きを確かめて、DMIで強さを見ます。

いろいろな方法があるので、詳しくは書きませんが一度動きを確かめてみるとおもしろいかもしれませんね。

タグ

メタトレーダーに日本語を表示してみる

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

今回は、メタトレーダーのプログラムで日本語を利用できるようにしてみます。

実は、日本語表示はできないと思っていました。。。

 

あまり困らなかったので、調べようとも思わなかったのが原因です。

やっぱり、こうしたことは興味がないとやりませんね。

 重要指標を表示するインジケータを作ってみるにコメントを下さった犬養さんに感謝です。

 

本題の日本語を表示してみる方法です。

メニューとかの表示は、できていますよね。

今回のは、プログラムのコードの中に日本語を利用できるようにして、チャート上にも日本語を表示します。

 

MetaEditorを開いてください。

メニューの

「Tool」-「Options…」を押してください。

「Font」タブを選択すると以下のような画面が表示されます。

jp1

ここで、日本語のフォントを選択し、Scriptの日本語を選択してください。

2箇所あるので間違えないでください。

「OK」ボタンを押してください。

 

これで、全部終了です。

むちゃくちゃ簡単です。

 

これで、ソース内のコメントを日本語化したり、チャートに表示させたりすることができます。

 

サンプルで、インジケータを作って見ました。

単純にコメントを表示するだけのものです。

jp2

こんな感じですね。

Comment(”日本語を表示してみる”);

今まで、日本語が化けていたのが表示できることが確認できると思います。

 

これをコンパイルして、チャートに貼り付けてみます。

jp3

こんな感じです。

赤丸のところに「日本語を表示してみる」が表示されていることが確認できると思います。

 

やっぱり、日本語が表示できると見やすいですね。

プログラムを組むのにも日本語コメントを入れられるだけで作業効率がアップすると思います。

がんばってみてください。

タグ

重要指標を表示するインジケータを作ってみる

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

今回は、重要指標を表示するインジケーターを作成します。

作成するといってもかなり難しいので、慣れてきてから応用してください。
いつもなら関数の説明などもしていますが、今回は省きます。

ダウンロードは、ここから。
ImportantNews 重要指標を表示するインジケータ

今回は、WindowsのAPIを利用してインターネット経由で重要指標を取得。
それを解析して、インジケータとして画面にプロットします。

重要指標の入手元は、

DailyFX
http://www.dailyfx.com/

で、ここはcsv形式で重要指標を入手できます。

こんな感じでcsvを入手できます。
http://www.dailyfx.com/calendar/Dailyfx_Global_Economic_Calendar.csv?direction=none&collector=allInFolderDateDesc&view=week&timezone=GMT

http://www.dailyfx.com/calendar/cal.csv?sort=dateDesc&timezone=&currency=|&importance=|

MT4は、英語しか表示できないので日本は表示可能です)英語のサイトのほうが都合がいいのとcsv形式でリアルタイムに入手できるので解析しやすいのが利点です。

csvファイルを入手して読み込ませる方法もありますが、せっかくなのでインターネットから直接入手します。

MT4には、外部DLLを利用する機能があるので、Windows標準のDLL(wininet.dll)を利用して、インターネットのアクセスを可能にします。
※外部DLLの利用はデフォルトなしになっているので、インジケータ組み込み時にありにする必要があります。

dll

↑赤丸のところ

 

ソースのはじめの方に

#import “使いたいDLL”
使いたい関数
#import

という宣言があると思います。

ここで、インターネット接続関係の関数を利用できるようにします。

・インターネット接続確認
InternetAttemptConnect()
・インターネット接続
InternetOpenA()
・URLオープン
InternetOpenUrlA()
・インターネット読み込み
InternetReadFile()
・インターネットクローズ
InternetCloseHandle()

オリジナルで作成している関数は、
ReadHttp()
StrToSplitArray()
の2つあります。

ReadHttp()は、インターネットに接続し、内容を文字列として読み込みます。

StrToSplitArray()は、文字列を区切り文字で分割して配列に格納します。

今回は、DailyFXへインターネット経由でアクセスして、csvファイルを取得していますから、ReadHttp()を使ってアクセスした結果がcsvファイルの内容で、戻り値にstringとしてメモリ上に展開されます。

csvファイルを取得してもらうと分かりますが、改行など無駄な部分もたくさんあるので、start()の中でStrToSplitArray()を利用して、改行を区切り文字として行データを配列へ格納、行データを「,」で分割して各項目データとして取得しています。

start()で行っていることは、
1.15分ごとの更新
2.表示データの削除
3.csvデータ(重要指標)の取得
4.データの分割
5.年月日など表示用に適した形への変換
6.タイムゾーンの一致
7.データの表示

今回のタイムゾーンは、デフォルト日本時間を採用しています。
server_timezone
show_timezone
で設定しています。

サーバ時間と表示時間を分けていますが、通常は同じでかまわないでしょう。
自分の環境に合わせてください。

データ表示で書かれている文字ですが、今の状態の上のほうから書き始めていますので、スクロールなどすると消えてしまいます。
次の更新で復活しますので、その辺は我慢してください。

デフォルトで取得している重要指標はすべてです。
URLの問い合わせで
&importanceFilter=Medium|Low|

&importance=Medium|Low|
などを追加して、Highのみにすることも可能です。
また、通貨ペアのフィルターも可能です。
¤cyFilter=GBP|CHF|CAD|AUD|NZD|

&currency=GBP|CHF|CAD|AUD|NZD|

今回は、ちょっと難しいので少しずつ理解して行ってください。

慣れてきてから、応用するのもありだと思います。

→この記事の続きを読む

タグ

CSVファイルを出力してみる。

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

今回は、ファイル出力を行いたいと思います。

タイトルでは、CSVファイルを出力することになっていますが、なるべく利用しやすいように文字列の行書きだしの関数を作ります。

CSVファイルも出力できますし、ログとして出力することもできます。

EAでもインジケータでもいいのですが、とりあえず、インジケーターで作成してみましょう。

何でもいいので、MetaEditorでインジケーターを作成してください。

別にパラメータなど入りませんので、適当でかまいません。

以下の関数をコピーして、最後にでもペースとしてください。

int LogWrite(string strFileName,string strText)
{
int handle;
handle=FileOpen(strFileName, FILE_BIN|FILE_READ|FILE_WRITE);
if(handle<1)
{
Print(”can’t open file error-”,GetLastError());
return(-1);
}
FileSeek(handle, 0, SEEK_END);
strText = strText + “\r\n”;
FileWriteString(handle, strText, StringLen(strText));
FileClose(handle);
return(0);
}

int LogWrite(string strFileName,string strText)

{

int handle;

handle=FileOpen(strFileName, FILE_BIN|FILE_READ|FILE_WRITE);

if(handle<1)

{

Print(”can’t open file error-”,GetLastError());

return(-1);

}

FileSeek(handle, 0, SEEK_END);

strText = strText + “\r\n”;

FileWriteString(handle, strText, StringLen(strText));

FileClose(handle);

return(0);

}

この関数は、

1.ファイルを開く

2.ファイルの最後に移動

3.ファイルへ出力

4.ファイルを閉じる

このことを行っています。

ちょこっと難しいというか、分かりにくいのが、

FileOpen(strFileName, FILE_BIN|FILE_READ|FILE_WRITE);

FILE_BIN|FILE_READ|FILE_WRITE

バイナリーモードで読み書きするという意味ですが、

その他にもファイルの中身を消去しないという意味があります。

今回は、書くだけなので「FILE_WRITE」だけでいいような気がしますが、

これだけだと、ファイルの中身を消してしまいます。

ということで、消したくないときは「FILE_READ|FILE_WRITE」の2つを指定する必要があります。

たぶん、ここが分かりにくいでしょうね。

FileSeek(handle, 0, SEEK_END);

は、ファイルの一番最後へ移動。

strText = strText + “\r\n”;

は、指定された文字の最後に改行コードを入れています。

これを入れないと改行されずに、連続した文字になってしまいます。

FileWriteString(handle, strText, StringLen(strText));

で、文字を指定した文字数分書き出しています。

FileClose(handle);

でファイルを閉じています。

この関数を使うと、簡単にファイルを出力できます。

LogWrite(ファイル名,出力したい文字列)

を指定すればいいだけです。

ちなみにファイルですが、

インストールパス\MetaTrader\experts\files

に出力されます。

EAのテストモードだけ出力先が変わって、

インストールパス\MetaTrader\tester\files

です。

では、関数を呼び出す部分を作ってみましょう。

int start()

の中に、以下の行を追加してください。

string strText = StringConcatenate(Year(),”/”,Month(),”/”,Day(),” “,Hour(),”:”,Minute(),”:”,Seconds(),”,”,Ask,”,”,Bid);

LogWrite(”AskBid.csv”,strText);

レートが変化したときの買値と売値を出力します。
ファイルの形式は、以下のようになります。

YYYY/MM/DD hh:mm:ss,買値,売値

CSVファイルで出力していますが、CSVファイルはカンマ区切りのテキストファイルです。

本当は、もう少し細かいルールがありますが、とりあえず問題ないはずです。

詳しく知りたい人は、ぐぐってみてください。

これで、コンパイルして適当な表にドラッグすれば、ファイルができあがっているはずです。

この関数は、文字なら何でも出力できるので、重宝すると思います。

せっかくなので、もう一つ出力例を

init()の上あたりに以下の宣言を追加してください。

datetime timeNow;

start()の中に以下の処理を追加してください。

if(timeNow != iTime(NULL,0,1))

{

timeNow = iTime(NULL,0,1);

string strTextAshi = StringConcatenate(TimeYear(timeNow),”/”,TimeMonth(timeNow),”/”,TimeDay(timeNow),” “,TimeHour(timeNow),”:”,TimeMinute(timeNow),”:”,TimeSeconds(timeNow),”,”,iHigh(NULL,0,1),”,”,iOpen(NULL,0,1),”,”,iClose(NULL,0,1),”,”,iLow(NULL,0,1));

LogWrite(”Ashi.csv”,strTextAshi);

}

今度のは、足が確定したときの高値、始値、終値、安値を出力しています。

レートが変わるたびに出力しても意味がないので、1本前の時間が変わったときに出力するようにしています。

こんな感じです。

ファイル出力は、分かりましたか?

他にも出力の仕方は、色々あるので試してみてくださいね。

タグ

インジケータの情報を取得する

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

インジケータから、情報を取得することを考えたいと思います。

 

有料のインジケータを買った(右の広告みたいなところから)ときに、そのインジケータを元にEAを作りたくなった。

インジケータとインジケータを組み合わせたときのあるタイミングで、シグナルを出したい。

 

たぶん、こんなこと思う人が結構いると思います。

 

ということで、インジケータのデータは、どうやってみるか?

ということを考えてみます。

 

リクエストにもあったので、標準で付いてくるインジケータで「ZigZag」というので考えてみます。

まず、どこの通貨ペアでもいいので、「ZigZag」を張り付けてみてください。

ほかのインジケータを使っていない状態の方が、わかりやすいので「ZigZag」だけにしてください。

 

アップダウンが、ジグザグに表示されるおもしろいインジケータですね。

「ZigZag」はソースが付いていますが、わからないと仮定します。

 

データウィンドウを表示してください。

スコープみたいなアイコンをクリックするか、「Ctrl+D」で表示できます。

datawindow

こんな感じのものが表示されたはずです。

マウスカーソルの位置のデータが表示されて、大変便利です。

 

で、「ZigZag」のデータは、

ZigZag、Value2、Value3の3つです。

実際に、マウスを動かして、データがどうなっているか調べていきます。

 

調べていくと、ZigZagというところが、山と谷の位置でデータが入っていることがわかります。

ということは、表示されている線のデータですね。

Value2、Value3は、山と思わしき場所、谷と思わしき場所の値が入っています。

 

ZigZagの値が、線のデータでほかのデータも使えそうですね。

 

次は、プログラムでデータを取得してみます。

タグ

週末にまとめてクローズするEA

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

サンプルプログラムばかりであまり役に立っていないと思うので、ほしい人はほしいもの。

 

週末持ち越しは、いやだけどEAがポジション持ちっぱなしなんだよね!

という人のために、週末に強制的にクローズするEAです。

 

121証券のようにサーバが日本時間であることを前提に話します。

別の時間帯を採用しているFX会社と契約している方は、時間を調整してください。

 

EAを作ってみるを参考にEAを作ってください。

名前は、WeekendCloseとします。

 

パラメータは、ウィザードで設定してもらっても構いませんし、コードに以下のように指定してもらっても構いません。

extern int CloseWeek=6;

extern int CloseTime=5;

CloseWeekの6は、土曜日。

CloseTimeの5は、5時です。

 

曜日は、日曜日が0で、月曜日が1。

順番になっています。

 

まず、曜日と時刻をチェックする関数を追加します。

int ChkCloseTime()

{

    int ChkWeek=DayOfWeek();

    int ChkHour=Hour();

 

    if((ChkWeek==CloseWeek && ChkHour>=CloseTime))

    {

        return(1);

    }

    return(0);

}

 

曜日と時間を取得して、指定した曜日と時間以上なら、1を返します。

 

次に、チケット番号をクローズする関数を追加します。

 

void ClosingTicket(int CloseTicket)

{

    if(OrderSelect(CloseTicket, SELECT_BY_TICKET)==true)

    {

        if(OrderType() == OP_SELL || OrderType() == OP_SELLLIMIT || OrderType() == OP_SELLSTOP)

        {

            // Closing

            if(OrderClose(OrderTicket(),OrderLots(),Ask,3,Green) == false)

            {

                OrderDelete(OrderTicket());

            }

        }

        else

        {

            // Closing

            if(OrderClose(OrderTicket(),OrderLots(),Bid,3,Green) == false)

            {

                OrderDelete(OrderTicket());

            }

        }

    }

}

 

指定された、チケットのオーダーをコントロールできるようにしてからクローズします。

クローズに失敗したときは、未確定の注文として注文の取り消しを行っています。

 

次に、実装部分を作ります。

 

int start()

  {

    if(ChkCloseTime() == 0) return(0);

 

    int total=OrdersTotal();

    int i;

    for(i=0;i < total;i++){

        if(OrderSelect(i, SELECT_BY_POS)==true)

        {

           ClosingTicket(OrderTicket());

        }

    }

 

   return(0);

  }

 

まず、終了時間かチェックします。

まだなら、そのまま関数を抜けます。

 

終了時間の場合は、現在もっているポジションを調べ、すべてのポジションをクローズしていきます。

 

サンプルを参考に改造して使ってみてください。

 

 

今回のプログラムは、以下からダウンロードできます。

ここから、ダウンロード

 

EA(自動売買)は、

インストールパス\MetaTrader\experts

に入れてください。

タグ

ちょっと賢いボリンジャーバンドインジケータ

4XP => メタトレーダー対応、固定スプレッド、最小1000通貨
50種類以上の通貨ペア、各種CFD(金、株など)対応

前回に引き続き、「簡単インジケータ作成テンプレート」を使ったサンプルを作ってみます。

今回もボリンジャーバンドを利用します。

 

ボリンジャーバンドにタッチしたら、売ったり買ったりすることが結構あると思います。

でも、本当にタッチしているかどうか分かりにくいですよね。

なので、タッチしているときだけ色を変えるようなインジケータを作ってみます。

 

まだ、テンプレートをダウンロードしていない人は、「簡単インジケータ作成テンプレート」からダウンロードしてください。

 

indicator_temp.mq4をコピーして、適当な名前にしてください。

例として、BB_I.mq4とします。

このファイルは、

インストールパス\MetaTrader\experts\indicators

に入れてくださいね。

 

いつものようにメタトレーダーを起動して、メタエディターを開いてください。

そこで、先ほど作ったBB_I.mq4を開きます。

 

変更する場所は、一番下の関数

DataSetだけです。

 

以下のように修正してみてください。

 

void DataSet(int i)

{

   double dBBUp = iBands(NULL,0,Param1,2,0,PRICE_CLOSE,MODE_UPPER,i);

   double dBBDown = iBands(NULL,0,Param1,2,0,PRICE_CLOSE,MODE_LOWER,i);

   if(dBBUp < High[i])

   {

      ExtMapBuffer1[i]=dBBUp;

   }

   else

   {

      ExtMapBuffer2[i]=dBBUp;

   }

   if(dBBDown > Low[i])

   {

      ExtMapBuffer3[i]=dBBDown;

   }

   else

   {

      ExtMapBuffer4[i]=dBBDown;

   }

//   ExtMapBuffer5[i]=iMA(NULL,0,14,0,MODE_SMA,PRICE_WEIGHTED,i);

//   ExtMapBuffer6[i]=iMA(NULL,0,14,0,MODE_EMA,PRICE_WEIGHTED,i);

//   ExtMapBuffer7[i]=iMA(NULL,0,14,0,MODE_SMMA,PRICE_WEIGHTED,i);

//   ExtMapBuffer8[i]=iMA(NULL,0,14,0,MODE_LWMA,PRICE_WEIGHTED,i);

}

今回は、上下2色使うので、上側にExtMapBuffer1、ExtMapBuffer2

下側に、ExtMapBuffer3、ExtMapBuffer4を割り当てます。

ボリンジャーバンドの上側のラインより高値が高い場合に、ExtMapBuffer1に値をセット。

低い場合に、ExtMapBuffer2にセットします。

下側も同様にセットしています。

 

ボリンジャーバンドで利用する足の数を変えられるように、Param1を使いました。

 

コンパイルして、描画させたいグラフにドロップしてみてください。

Param1は0になっているので、21とか適当な値にしてください。

線の太さや色もパラメータで設定できますので、いじってみてくださいね。

 

表示させた結果、ちゃんと色が変わっているのが分かりましたか?

 

 

でも、なんか線が飛んでいませんか?

データを入れていないところは、デフォルトでEMPTY_VALUEという描画しない値が、入っています。

ちょうど、書き始めに値が入っていないため抜けているんですね。

 

というわけで、ちょっと気持ち悪いので、たりない情報を別のバッファからもらうように修正してみます。

 

void DataSet(int i)

{

   double dBBUp = iBands(NULL,0,Param1,2,0,PRICE_CLOSE,MODE_UPPER,i);

   double dBBDown = iBands(NULL,0,Param1,2,0,PRICE_CLOSE,MODE_LOWER,i);

   if(dBBUp < High[i])

   {

      ExtMapBuffer1[i]=dBBUp;

      if(ExtMapBuffer1[i+1] == EMPTY_VALUE)ExtMapBuffer1[i+1] = ExtMapBuffer2[i+1];

   }

   else

   {

      ExtMapBuffer2[i]=dBBUp;

      if(ExtMapBuffer2[i+1] == EMPTY_VALUE)ExtMapBuffer2[i+1] = ExtMapBuffer1[i+1];

   }

   if(dBBDown > Low[i])

   {

      ExtMapBuffer3[i]=dBBDown;

      if(ExtMapBuffer3[i+1] == EMPTY_VALUE)ExtMapBuffer3[i+1] = ExtMapBuffer4[i+1];

   }

   else

   {

      ExtMapBuffer4[i]=dBBDown;

      if(ExtMapBuffer4[i+1] == EMPTY_VALUE)ExtMapBuffer4[i+1] = ExtMapBuffer3[i+1];

   }

//   ExtMapBuffer5[i]=iMA(NULL,0,14,0,MODE_SMA,PRICE_WEIGHTED,i);

//   ExtMapBuffer6[i]=iMA(NULL,0,14,0,MODE_EMA,PRICE_WEIGHTED,i);

//   ExtMapBuffer7[i]=iMA(NULL,0,14,0,MODE_SMMA,PRICE_WEIGHTED,i);

//   ExtMapBuffer8[i]=iMA(NULL,0,14,0,MODE_LWMA,PRICE_WEIGHTED,i);

}

これで、試してみてください。

うまくいったでしょ。

ちなみにコンパイルするとパラメータの設定が初期化されてしまいます。

 

気になる人は、上の方の

#property indicator_color1 Red

#property indicator_color2 Blue

#property indicator_color3 Green

#property indicator_color4 Yellow

extern int Param1=0;

 

の値を変えてみてくださいね。

タグ