커뮤니티

변환 부탁드립니다.

프로필 이미지
다올
2025-07-29 19:28:49
188
글번호 192856
답변완료
트레이팅 뷰 수식입니다. 적용가능하도록 부탁 드립니다. indicator("RSI Shift Zone [ChartPrime]", overlay = false, max_labels_count = 500) // --------------------------------------------------------------------------------------------------------------------{ rsi_len = input.int(14, "RSI length") upper_level = input.int(70, "Upper RSI Level", minval = 50) lower_level = input.int(30, "Lower RSI Level", maxval = 50) min_channel_len = input.int(15, "Minimal bars length of the channel") display_rsi_val = input.bool(false, "Display RSI Values at the Zones") upper_col = input.color(#21c997, "↑", inline = "colors") lower_col = input.color(#cc24e2, "↓", inline = "colors") var start = int(na) var trigger = false var float upper = na var float lower = na var channel_color = color(na) color bar_color = na // --------------------------------------------------------------------------------------------------------------------{ rsi = ta.rsi(close, rsi_len) channel_upper = ta.crossover(rsi, 70) and not trigger channel_lower = ta.crossunder(rsi, 30) and not trigger rsi_color = color.from_gradient(rsi, 30, 70, lower_col, upper_col) if channel_upper label.new(bar_index, rsi, style = label.style_circle, size = size.tiny, color = color.new(rsi_color, 45)) label.new(bar_index, rsi, str.tostring(upper_level), style = label.style_label_center, size = size.small, color = color.new(rsi_color, 100)) start := bar_index trigger := true upper := high lower := low channel_color := rsi_color bar_color := rsi_color if display_rsi_val label.new(bar_index, hl2, "RSI: " + str.tostring(upper_level), style = label.style_label_right, color = color.new(rsi_color, 100), textcolor = chart.fg_color, force_overlay = true) if channel_lower label.new(bar_index, rsi, style = label.style_circle, size = size.tiny, color = color.new(rsi_color, 45)) label.new(bar_index, rsi, str.tostring(lower_level), style = label.style_label_center, size = size.small, color = color.new(rsi_color, 100)) start := bar_index trigger := true upper := high lower := low channel_color := rsi_color bar_color := rsi_color if display_rsi_val label.new(bar_index, hl2, "RSI: " + str.tostring(lower_level), style = label.style_label_right, color = color.new(rsi_color, 100), textcolor = chart.fg_color, force_overlay = true) if bar_index-start >= min_channel_len trigger := false trigger_change = channel_upper != channel_upper[1] or channel_lower != channel_lower[1] // --------------------------------------------------------------------------------------------------------------------} // &#128204; &#120401;&#120388;&#120398;&#120400;&#120380;&#120391;&#120388;&#120405;&#120380;&#120399;&#120388;&#120394;&#120393; // --------------------------------------------------------------------------------------------------------------------{ barcolor(bar_color) prsi = plot(rsi, "RSI", color = rsi_color, linewidth = 2) p50 = plot(50, color = color.gray, editable = false) plower = plot(lower_level, "Lower RSI Level", color = bar_index % 3 == 0 ? na : color.gray) pupper = plot(upper_level, "Upper RSI Level", color = bar_index % 3 == 0 ? na : color.gray) fill(prsi, pupper, rsi >= upper_level ? color.new(rsi_color, 80) : na) fill(prsi, plower, rsi <= lower_level ? color.new(rsi_color, 80) : na) plot(trigger_change ? float(na) : upper, force_overlay = true, style = plot.style_linebr, offset = -1, color = channel_color, editable = false) plot(trigger_change ? float(na) : lower, force_overlay = true, style = plot.style_linebr, offset = -1, color = channel_color, editable = false) p1 = plot(trigger_change ? float(na) : upper, force_overlay = true, style = plot.style_linebr, color = color.new(channel_color, 70), linewidth = 3, editable = false) p2 = plot(trigger_change ? float(na) : lower, force_overlay = true, style = plot.style_linebr, color = color.new(channel_color, 70), linewidth = 3, editable = false) fill(p1, p2, color.new(channel_color, 90)) plot(trigger_change ? float(na) : math.avg(upper, lower), force_overlay = true, style = plot.style_linebr, offset = -1, color = color.gray, editable = false) plot(trigger_change ? float(na) : math.avg(upper, lower), force_overlay = true, style = plot.style_linebr, color = color.gray, editable = false) // --------------------------------------------------------------------------------------------------------------------}
지표
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2025-07-30 10:10:25

안녕하세요 예스스탁입니다. // --------------------------------------------------------------------------------------------------------------------{ input : rsi_len(14); input : upper_level(70); input : lower_level(30); input : min_channel_len(15); input : display_rsi_val(False); input : upper_col(Lime); input : lower_col(Violet); var : start(nan); var : trigger(false); var : upper(nan); var : lower(nan); var : channel_color(Nan),bar_color(Nan); var : R(0),channel_upper(False),channel_lower(False),rsi_color(0); var : tx1(0),tx2(0),tx3(0),trigger_change(False); R = rsi(rsi_len); channel_upper = CrossUp(R, 70) and trigger == False; channel_lower = CrossDown(R, 30) and trigger == False; rsi_color = IFf(R>=50,upper_col,lower_col); if channel_upper == true Then { tx1= Text_New_Self(sDate,sTime,R,"●"); Text_SetColor(tx1,rsi_color); Text_SetStyle(tx1,2,2); Text_SetSize(tx1,20); tx2 = Text_New_Self(sDate,sTime,R,NumToStr(upper_level,0)); Text_SetColor(tx2,Black); Text_SetStyle(tx2,2,2); start = index; trigger = true; upper = high; lower = low; channel_color = rsi_color; bar_color = rsi_color; if display_rsi_val == true Then { tx3= Text_New(sDate,sTime,(h+l)/2,"RSI:"+NumToStr(upper_level,0)); Text_SetColor(tx3,Black); Text_SetStyle(tx3,1,2); } } if channel_lower == true Then { tx1= Text_New_Self(sDate,sTime,R,"●"); Text_SetColor(tx1,rsi_color); Text_SetStyle(tx1,2,2); Text_SetSize(tx1,20); tx2 = Text_New_Self(sDate,sTime,R,NumToStr(lower_level,0)); Text_SetColor(tx2,Black); Text_SetStyle(tx2,2,2); start = index; trigger = true; upper = high; lower = low; channel_color = rsi_color; bar_color = rsi_color; if display_rsi_val == true Then { tx3= Text_New(sDate,sTime,(h+l)/2,"RSI:"+NumToStr(lower_level,0)); Text_SetColor(tx3,Black); Text_SetStyle(tx3,1,2); } } if index-start >= min_channel_len Then trigger = false; trigger_change = channel_upper != channel_upper[1] or channel_lower != channel_lower[1]; plot1(R, "RSI", rsi_color); plot2(50, "50",gray); plot3(lower_level, "Lower RSI Level",gray); plot4(upper_level, "Upper RSI Level",gray); var : TL1(0),TL2(0),TL3(0); if trigger_change == False Then { if trigger_change != trigger_change[1] Then { TL1 = TL_New(sDate[1],sTime[1],upper,sDate,sTime,upper); TL2 = TL_New(sDate[1],sTime[1],lower,sDate,sTime,lower); TL3 = TL_New(sDate[1],sTime[1],(upper+lower)/2,sDate,sTime,(upper+lower)/2); TL_SetColor(TL1,channel_color); TL_SetColor(TL2,channel_color); TL_SetColor(TL3,Gray); } Else { TL_SetEnd(TL1,sDate,sTime,upper); TL_SetEnd(TL2,sDate,sTime,lower); TL_SetEnd(TL3,sDate,sTime,(upper+lower)/2); } } 즐거운 하루되세요 > 다올 님이 쓴 글입니다. > 제목 : 변환 부탁드립니다. > 트레이팅 뷰 수식입니다. 적용가능하도록 부탁 드립니다. indicator("RSI Shift Zone [ChartPrime]", overlay = false, max_labels_count = 500) // --------------------------------------------------------------------------------------------------------------------{ rsi_len = input.int(14, "RSI length") upper_level = input.int(70, "Upper RSI Level", minval = 50) lower_level = input.int(30, "Lower RSI Level", maxval = 50) min_channel_len = input.int(15, "Minimal bars length of the channel") display_rsi_val = input.bool(false, "Display RSI Values at the Zones") upper_col = input.color(#21c997, "↑", inline = "colors") lower_col = input.color(#cc24e2, "↓", inline = "colors") var start = int(na) var trigger = false var float upper = na var float lower = na var channel_color = color(na) color bar_color = na // --------------------------------------------------------------------------------------------------------------------{ rsi = ta.rsi(close, rsi_len) channel_upper = ta.crossover(rsi, 70) and not trigger channel_lower = ta.crossunder(rsi, 30) and not trigger rsi_color = color.from_gradient(rsi, 30, 70, lower_col, upper_col) if channel_upper label.new(bar_index, rsi, style = label.style_circle, size = size.tiny, color = color.new(rsi_color, 45)) label.new(bar_index, rsi, str.tostring(upper_level), style = label.style_label_center, size = size.small, color = color.new(rsi_color, 100)) start := bar_index trigger := true upper := high lower := low channel_color := rsi_color bar_color := rsi_color if display_rsi_val label.new(bar_index, hl2, "RSI: " + str.tostring(upper_level), style = label.style_label_right, color = color.new(rsi_color, 100), textcolor = chart.fg_color, force_overlay = true) if channel_lower label.new(bar_index, rsi, style = label.style_circle, size = size.tiny, color = color.new(rsi_color, 45)) label.new(bar_index, rsi, str.tostring(lower_level), style = label.style_label_center, size = size.small, color = color.new(rsi_color, 100)) start := bar_index trigger := true upper := high lower := low channel_color := rsi_color bar_color := rsi_color if display_rsi_val label.new(bar_index, hl2, "RSI: " + str.tostring(lower_level), style = label.style_label_right, color = color.new(rsi_color, 100), textcolor = chart.fg_color, force_overlay = true) if bar_index-start >= min_channel_len trigger := false trigger_change = channel_upper != channel_upper[1] or channel_lower != channel_lower[1] // --------------------------------------------------------------------------------------------------------------------} // &#128204; &#120401;&#120388;&#120398;&#120400;&#120380;&#120391;&#120388;&#120405;&#120380;&#120399;&#120388;&#120394;&#120393; // --------------------------------------------------------------------------------------------------------------------{ barcolor(bar_color) prsi = plot(rsi, "RSI", color = rsi_color, linewidth = 2) p50 = plot(50, color = color.gray, editable = false) plower = plot(lower_level, "Lower RSI Level", color = bar_index % 3 == 0 ? na : color.gray) pupper = plot(upper_level, "Upper RSI Level", color = bar_index % 3 == 0 ? na : color.gray) fill(prsi, pupper, rsi >= upper_level ? color.new(rsi_color, 80) : na) fill(prsi, plower, rsi <= lower_level ? color.new(rsi_color, 80) : na) plot(trigger_change ? float(na) : upper, force_overlay = true, style = plot.style_linebr, offset = -1, color = channel_color, editable = false) plot(trigger_change ? float(na) : lower, force_overlay = true, style = plot.style_linebr, offset = -1, color = channel_color, editable = false) p1 = plot(trigger_change ? float(na) : upper, force_overlay = true, style = plot.style_linebr, color = color.new(channel_color, 70), linewidth = 3, editable = false) p2 = plot(trigger_change ? float(na) : lower, force_overlay = true, style = plot.style_linebr, color = color.new(channel_color, 70), linewidth = 3, editable = false) fill(p1, p2, color.new(channel_color, 90)) plot(trigger_change ? float(na) : math.avg(upper, lower), force_overlay = true, style = plot.style_linebr, offset = -1, color = color.gray, editable = false) plot(trigger_change ? float(na) : math.avg(upper, lower), force_overlay = true, style = plot.style_linebr, color = color.gray, editable = false) // --------------------------------------------------------------------------------------------------------------------}