예스스탁
예스스탁 답변
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]
// --------------------------------------------------------------------------------------------------------------------}
// 📌 𝙑𝙄𝙎𝙐𝘼𝙇𝙄𝙕𝘼𝙏𝙄𝙊𝙉
// --------------------------------------------------------------------------------------------------------------------{
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)
// --------------------------------------------------------------------------------------------------------------------}