ChartScreenShot 関数
この関数は、現在のチャートのスクリーンショットを拡張子 GIF、PNG、BMP形式のいずれかを指定してファイル保存します。
WindowScreenShot関数でも厳密には違いますが同様の処理を行なうことができます。
データ型と構成・戻り値
bool ChartScreenShot(①, ②, ③, ④, ⑤);
戻り値は、処理が成功した場合は true、それ以外は falseが返されます。
発生するエラーについては、GetLastError関数で取得することができます。
引数 [5]
ChartScreenShot関数は 5個の引数で構成されます。
番 号 | 引数名 | データ型 | 単位 | 初期値 | 説明 |
---|---|---|---|---|---|
① | chart_id | long | - | - | 対象とするチャートID。 0は現在のチャートを表します。 |
② | filename | string | - | - | スクリーンショットのファイル名。拡張子名(gif,png,bmp)も含めて指定してください。 |
③ | width | int | pixel | - | スクリーンショットの幅(ピクセル単位)。 |
④ | height | int | pixel | - | スクリーンショットの高さ(ピクセル単位)。 |
⑤ | align_mode | enum | - | ALIGN_RIGHT | スクリーンショットの出力モード。 ENUM_ALIGN_MODE 列挙値から選択。 初期値の ALIGN_RIGHTは右端から出力する事を意味します。 |
取得したスクリーンショットは、使用しているMT4のメニューのファイルから「データフォルダを開く」のフォルダの「MQL4」→「Files」フォルダの中に保存されます。
data:image/s3,"s3://crabby-images/03a2c/03a2c1cc8e93b431d4a1d9ae56fe1035a214e6d0" alt=""
使用例
ChartScreenShot関数によるスクリーンショットの保存
ChartScreenShot関数を使って現在のチャートのスクリーンショットを保存します。
コード
// ChartScreenShot関数によるスクリーンショットの保存
#property strict
void OnInit() {
bool tf1 = ChartScreenShot(0, "Pscshot.png", 300, 200);
bool tf2 = ChartScreenShot(0, "Gscshot.gif", 150, 100);
bool tf3 = ChartScreenShot(0, "Bscshot.bmp", 75, 50);
Print("PNGスクリーンショットの成否:", tf1);
Print("GIFスクリーンショットの成否:", tf2);
Print("BMPスクリーンショットの成否:", tf3);
}
コードをコンパイルして実行する方法はこちらを参考にしてください。(デモ口座でお試しください)
結果
次のように画像が「Files」フォルダの中に保存されます。
data:image/s3,"s3://crabby-images/3240a/3240a625f2cb25a65d6f6a62f25635e8ea422515" alt="Pscshot.png"
Pscshot.png
data:image/s3,"s3://crabby-images/65bc0/65bc042cfc110156cee5fd1910480bccce1c6b5a" alt="Gscshot.gif"
Gscshot.gif
data:image/s3,"s3://crabby-images/3e5fa/3e5fa327ca1dc16cf7d48efe6f48bcc3e1a2dfe4" alt="Bscshot.bmp"
Bscshot.bmp
data:image/s3,"s3://crabby-images/768f2/768f26a291fae5ba38f529554492aa6f4871c702" alt=""