這是一款具備「可自由調整在 K 棒收盤前 0 秒至 5 分鐘內,何時開始實時(Real-time)繪圖」功能的 DMI。此外也整合了其他多項實用的輔助功能。
[DMI]
DMI(動向指標)是一套計算當日最高價與最低價相較於前一日最高價與最低價,朝著哪個方向突破了多少幅度的系統。它能透過三條線,將市場的「上漲推力」、「下跌推力」以及「趨勢的綜合強度」視覺化。該指標以「+DI 與 -DI 的交叉」來定義趨勢發生的方向,並藉由「ADX 的上升」來證明該趨勢為真(具備充足的推力)。
來源: TradingView
[NOTICE & LICENSE]
・僅供學習與提供資訊之用,不構成投資建議。對於因使用本工具而產生之任何經濟損失,概不負責。
・已於 Pine Script v6 測試運作。以「現狀 (As-is)」提供,不保證因未來 TradingView 系統規格變更而進行更新,亦不接受個別的安裝支援或修改請求。
・適用 MIT 授權條款。
// SPDX-FileCopyrightText: 2026 NK-report https://www.nk-report.com/
// SPDX-License-Identifier: MIT
//
// Disclaimer: This script is for educational purposes only and does not constitute investment advice.
//@version=6
indicator("NK-Fixed DMI", shorttitle="NK-Fixed DMI", overlay=false)
// ==============================================================================
// 【01】 免責・ライセンス
// ==============================================================================
//
// 本指標免費公開: https://www.nk-report.com/p/tw-tradingview.html
//
// 免責聲明:本腳本僅供學習與資訊參考之用,不構成任何投資建議。
//
// 1. 本程式碼截至 2026 年,已在 Pine Script v6 環境下完成運作測試。
// 日後若因規格變動而導致任何異常,恕不提供個別的技術支援或修改服務。
// 2. 本腳本係基於一般的計算邏輯,並透過 LLM 獨立編寫而成。
// 本程式碼採用 MIT 授權條款 (MIT License) 進行發布。
// ------------------------------------------------------------------------------
// MIT License
//
// Copyright 2026 NK-report https://www.nk-report.com/
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of
// this software and associated documentation files (the "Software"), to deal in
// the Software without restriction, including without limitation the rights to
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
// of the Software, and to permit persons to whom the Software is furnished to do
// so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
// ==============================================================================
// 【02】 UI設定と言語
// ==============================================================================
// 1. 言語辞書の定義(テキストの定数化)
const string GRP_FIXED = "▼ 繪圖控制"
const string LBL_SEC = "即時繪圖開始 (K棒收盤前X秒)"
const string TT_SEC = "可在0秒至300秒(5分鐘)之間調整。在達到指定時間(例如:收盤前10秒)之前,將隱藏當前K棒的繪圖。\n若輸入0秒,則停用隱藏功能,並始終即時繪圖。"
const string GRP_DMI = "▼ DMI設定"
const string LBL_LEN = "DI 長度"
const string LBL_ADX_LEN = "ADX 平滑化長度"
// 2. UI(ユーザー入力画面)の構築 & 3. トップダウン処理への適合
i_sec = input.int(0, title=LBL_SEC, minval=0, maxval=300, group=GRP_FIXED, tooltip=TT_SEC)
i_len = input.int(14, title=LBL_LEN, minval=1, group=GRP_DMI, inline="DMI1")
i_adx_len = input.int(14, title=LBL_ADX_LEN, minval=1, group=GRP_DMI, inline="DMI1")
// ==============================================================================
// 【03】 全コード共通仕様(タイムゾーン・時間インフラ処理)
// ==============================================================================
// 1. 基本時間単位のシステム定義(定数化)
const int MS_PER_SEC = 1000
// ==============================================================================
// 【04】 各カテゴリ共通仕様 (NK-Fixed Core Logic)
// ==============================================================================
// 1. カテゴリ固有のインフラ構築(コア機能の定義)
bool is_draw_ready = true
// リアルタイム足であり、かつユーザーが0秒より大きい数値を設定している場合のみ処理
if barstate.isrealtime and i_sec > 0
if not na(time_close)
int time_left_ms = time_close - timenow
int threshold_ms = i_sec * MS_PER_SEC
if time_left_ms > threshold_ms
is_draw_ready := false
// ==============================================================================
// 【05】 このコード固有の計算仕様 (Specific Indicator Logic)
// ==============================================================================
// 1. インジケーター固有の純粋な数学的処理
// ※標準関数 ta.dmi() を使わず、公式「Directional Movement Index」と完全一致する生の計算式を採用
float up = ta.change(high)
float down = -ta.change(low)
float plusDM = na(up) ? na : (up > down and up > 0 ? up : 0)
float minusDM = na(down) ? na : (down > up and down > 0 ? down : 0)
float trur = ta.rma(ta.tr, i_len)
float calc_pdi = fixnan(100 * ta.rma(plusDM, i_len) / trur)
float calc_mdi = fixnan(100 * ta.rma(minusDM, i_len) / trur)
float sum_di = calc_pdi + calc_mdi
float calc_adx = 100 * ta.rma(math.abs(calc_pdi - calc_mdi) / (sum_di == 0 ? 1 : sum_di), i_adx_len)
// 2. ロジックの完全な隔離と差し替えの容易性
// 3. 視覚的装飾の排除とデータの引き渡し
float final_pdi = is_draw_ready ? calc_pdi : na
float final_mdi = is_draw_ready ? calc_mdi : na
float final_adx = is_draw_ready ? calc_adx : na
// ==============================================================================
// 【06】 描画と出力 (Rendering & Outputs)
// ==============================================================================
// 1. チャートへの視覚的出力(プロットと装飾)
plot(final_pdi, title="+DI Line", color=#26A69A, linewidth=2)
plot(final_mdi, title="-DI Line", color=#EF5350, linewidth=2)
plot(final_adx, title="ADX Line", color=#F6C309, linewidth=2)
// 水平線の描画処理(スタイルタブから表示/非表示や色を変更可能)
hline(20, title="水平線 1 (20)", color=color.new(color.gray, 50), linestyle=hline.style_solid)
hline(40, title="水平線 2 (40)", color=color.new(color.gray, 50), linestyle=hline.style_solid)
// 2. ロジックとデザインの完全分離
// 3. アラート(通知)条件の統合
// ※投資助言を回避するため、方向性を指示する言葉(Buy/Sell等)は使わず、純粋な事実・状態のみを通知します
bool cross_over_di = ta.crossover(calc_pdi, calc_mdi) and is_draw_ready
bool cross_under_di = ta.crossunder(calc_pdi, calc_mdi) and is_draw_ready
bool adx_break_hl1 = ta.crossover(calc_adx, 20) and is_draw_ready
alertcondition(cross_over_di, title="+DI Cross Over -DI", message="+DI line crossed over -DI line")
alertcondition(cross_under_di, title="+DI Cross Under -DI", message="+DI line crossed under -DI line")
alertcondition(adx_break_hl1, title="ADX Break Level 1", message="ADX line crossed over Level 1 (20)")
* 設定好喜歡的顏色配置後,請在設定分頁中點擊「儲存為預設值」。
* 若未按照「新增 → 指標 → 貼上」的順序操作,可能無法正確顯示。