指定されたファイルから特定のテンプレートをチャートに適用します。このコマンドはチャートメッセージキューに追加され、以前のすべてのコマンドが処理された後にのみ実行されます。
bool ChartApplyTemplate( |
パラメーター
chart_id
[in]チャートID。0は現在のチャートを意味します。
ファイル名
[入力]テンプレートを含むファイルの名前。
戻り値
コマンドがチャートキューに追加された場合はtrueを、それ以外の場合はfalseを返します。エラーの詳細を取得するには、GetLastError()関数を使用します。
注意
Expert Advisorはアンロードされ、新しいテンプレートが添付されているチャートに正常にロードされた場合、動作を継続できなくなります。
ライブトレーディングとDLLインポート
ユーザーは、チャートで起動されたmql4プログラムに対して次のアクションを許可または禁止できます。
- 取引操作(ライブ取引)の実行、
- DLLのインポート。
ターミナルでは、構成されたチャートをテンプレートとして保存し、すべてのインジケーターとExpert Advisorを起動できます。したがって、テンプレート設定を他のすべてのチャートにすばやく適用できます。テンプレートを保存すると、起動されたプログラムの許可(ライブトレーディングとDLLインポート)も保存されます。テンプレートをチャートに適用するとき、これらの権限はセキュリティ上の理由により制限される場合があります。
ChartApplyTemplate()関数を使用してテンプレートを適用することにより起動されたExpert Advisorsに対して、ライブトレーディングおよびDLLインポート許可を拡張することはできません。 |
ChartApplyTemplate()関数を呼び出すmql4プログラムにトレードの許可がない場合、テンプレートを介して起動されたExpert Advisorも、テンプレートの設定に関係なくトレードできません。
ChartApplyTemplate()関数を呼び出すmql4プログラムに取引許可があり、テンプレート設定にそのような許可がない場合、テンプレートを介して起動されたExpert Advisorは取引できません。
テンプレートを使用する
MQL4言語のリソースでは、ChartSetInteger()関数を使用した色を含む複数のチャートプロパティを設定できます。
- チャートの背景色。
- 軸、スケール、OHLCラインの色。
- グリッドの色。
- ボリュームの色とオープンレベルの位置。
- 強気ローソク足のアップバー、シャドウ、およびエッジの色。
- 下降バーの色、影、および弱気のローソク足の端。
- チャートラインと童子燭台の色。
- 強気のローソク足本体の色。
- 弱気のローソク足本体の色。
- 入札価格ラインの色。
- 売値ラインの色。
- 最終取引価格のラインの色(Last);
- ストップオーダーレベルの色(ストップロスとテイクプロフィット)。
また、チャート上に複数のグラフィカルオブジェクトとインジケーターが存在する場合があります。必要なすべてのインジケータを含むチャートを一度セットアップしてから、テンプレートとして保存できます。このようなテンプレートは、どのチャートにも適用できます。
ChartApplyTemplate()関数は、以前に保存したテンプレートを使用するために意図され、そしてそれは任意MQL4プログラムで使用することができます。テンプレートを保存するファイルへのパスは、2番目のパラメーターとしてChartApplyTemplate()に渡されます。テンプレートファイルは、次のルールに従って検索されます。
- バックスラッシュ「」セパレータ(「\」と表記)がパスの先頭に配置されている場合、テンプレートはパス_terminal_data_directory MQL4に関連して検索されます。
- バックスラッシュがない場合は、ChartApplyTemplate()が呼び出される実行可能EX4ファイルに関連してテンプレートが検索されます。
- 最初の2つのバリアントでテンプレートが見つからない場合、検索はterminal_directory Profiles Templates フォルダーで実行されます。
ここで、terminal_directoryはMetaTrader 4クライアントターミナルが実行されているフォルダーで、terminal_data_directoryは編集可能なファイルが保存されているフォルダーです。その場所はオペレーティングシステム、ユーザー名、コンピューターのセキュリティ設定によって異なります。通常、これらは異なるフォルダですが、場合によっては一致する場合があります。
terminal_data_directoryフォルダーとterminal_directoryフォルダーの場所は、TerminalInfoString()関数を使用して取得できます。
//— directory from which the terminal is started |
例えば:
//— search for a template in terminal_data_directoryMQL4 |
テンプレートはリソースではなく、実行可能なEX4ファイルに含めることはできません。
例:
//+——————————————————————+ |