커뮤니티

추세선 크기 세로선

프로필 이미지
고성
2023-01-13 11:11:41
796
글번호 165383
답변완료
input : Period(17),선두께(2),바닥상1(2),바닥하1(1),봉상(1),봉하(2),pt(0.2); Var:상승색(Red), 하락색(Blue); Var:j(0),T(0),txx(0),txxx(0); Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0), date21(0),date22(0),time21(0),time22(0),tl8(0), date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0),tl9(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0); Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0); Plot1(value12); For j = 0 To 19 { HiBar[j] = HiBar[j] + 1; LoBar[j] = LoBar[j] + 1; } if crossup(c,highest(H,Period)[1]) Then T = 1; if CrossDown(c,Lowest(L,Period)[1]) Then T = -1; If T == -1 Then { If T[1] != -1 Then { For j = 18 DownTo 0 { LoVal[j+1] = LoVal[j]; LoBar[j+1] = LoBar[j]; } LoVal[0] = L; LoBar[0] = 0; date11 = date[HiBar[0]]; time11 = stime[HiBar[0]]; Value11 = HiVal[0]; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_Delete(tl); TL = TL_New_Self(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New_Self(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,하락색); Txx = Text_New_Self(date11,time11,Value11+PriceScale*0,"●"); Text_SetColor(Txx,Blue); Text_SetStyle(Txx,2,2); Text_SetSize(txx,10); if hival[0] <= hival[1]+PriceScale* 봉상 and hival[0] >= hival[1]-PriceScale*봉하 Then { Txx =Text_New_Self(date11,time11,Value11+PriceScale*1,"●"); Text_SetColor(Txx,Cyan); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); } date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; for j = 0 to 6 { fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]); } Text_SetSize(tx,25); Text_SetColor(Tx,Red); Text_SetStyle(tx,1,1); if abs(value12[1]-value11[1]) < 0.9 Then Text_Delete(tx); tx = Text_New_Self(sDate,stime,value12,NumToStr(value12-value11,2)); Text_SetColor(Tx,Blue); Text_SetStyle(tx,1,0); Text_SetSize(tx,30); Text_SetBold(tx,1); } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date22 = date[0]; time22 = stime[0]; Text_SetString(tx,NumToStr(value12-value11,2)); Text_SetLocation(tx,sDate,sTime,value12); } } If T == 1 Then { If T[1] != 1 Then { For j = 18 DownTo 0 { HiVal[j+1] = HiVal[j]; HiBar[j+1] = HiBar[j]; } HiVal[0] = H; HiBar[0] = 0; date11 = date[LoBar[0]]; time11 = stime[LoBar[0]]; Value11 = LoVal[0]; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_Delete(tl); TL = TL_New_Self(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New_Self(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,상승색); if LoVal[2] > 0 and max(LoVal[0],LoVal[1],LoVal[2]) <= min(LoVal[0],LoVal[1],LoVal[2])+pt Then { txx = Text_New_Self(sDate[LoBar[0]],sTime[LoBar[0]],Loval[0],"●"); Text_SetColor(txx,Lime); Text_SetStyle(Txx,2,2); Text_SetSize(txx,30); } Condition1 = False; if Condition1 == False and LoVal[0] <= Loval[1]+PriceScale*바닥상1 and LoVal[0] >= Loval[1]-PriceScale*바닥하1 Then { Condition1 = true; Txx =Text_New_Self(date11,time11,Value11-PriceScale*0,"●"); Text_SetColor(Txx,Magenta); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); } Txx = Text_New_Self(date11,time11,Value11-PriceScale*0,"●"); Text_SetColor(Txx,Red); Text_SetStyle(Txx,2,2); Text_SetSize(txx,10); date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; for j = 0 to 5 { fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]); } Text_SetSize(tx,25); Text_SetColor(Tx,Blue); Text_SetStyle(tx,1,0); if abs(value12[1]-value11[1]) < 0.55 Then Text_Delete(tx); tx = Text_New_Self(sDate,stime,value12,NumToStr(value12-value11,2)); Text_SetColor(Tx,Red); Text_SetStyle(tx,1,1); Text_SetSize(tx,30); Text_SetBold(tx,1); } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date32 = date[0]; time32 = stime[0]; Text_SetString(tx,NumToStr(value12-value11,2)); Text_SetLocation(tx,sDate,sTime,value12); } } Text_SetColor(Txxx,Black); Text_SetSize(txxx,30); TL_SetSize(TL1,선두께); 1.추세선 음선의 크기가 0.55p 보다 클때 양전환되면 세로선 추가. 0.55p 보다 작거나 양선은 무관. 2.음선의 크기가 0.55p에 도달하면, 음추세선 상단 시작점에 동그라미 표시 추가. 양전환시 동그라미는 삭제(세로선이 추가됨). 감사합니다
지표
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2023-01-13 12:47:06

안녕하세요 예스스탁입니다. input : Period(17),선두께(2),바닥상1(2),바닥하1(1),봉상(1),봉하(2),pt(0.2); Var:상승색(Red), 하락색(Blue); Var:j(0),T(0),txx(0),txxx(0); Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0), date21(0),date22(0),time21(0),time22(0),tl8(0), date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0),tl9(0),tx4(0),vTL(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0); Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0); Plot1(value12); For j = 0 To 19 { HiBar[j] = HiBar[j] + 1; LoBar[j] = LoBar[j] + 1; } if crossup(c,highest(H,Period)[1]) Then T = 1; if CrossDown(c,Lowest(L,Period)[1]) Then T = -1; If T == -1 Then { If T[1] != -1 Then { For j = 18 DownTo 0 { LoVal[j+1] = LoVal[j]; LoBar[j+1] = LoBar[j]; } LoVal[0] = L; LoBar[0] = 0; date11 = date[HiBar[0]]; time11 = stime[HiBar[0]]; Value11 = HiVal[0]; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_Delete(tl); TL = TL_New_Self(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New_Self(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,하락색); Txx = Text_New_Self(date11,time11,Value11+PriceScale*0,"●"); Text_SetColor(Txx,Blue); Text_SetStyle(Txx,2,2); Text_SetSize(txx,10); if hival[0] <= hival[1]+PriceScale* 봉상 and hival[0] >= hival[1]-PriceScale*봉하 Then { Txx =Text_New_Self(date11,time11,Value11+PriceScale*1,"●"); Text_SetColor(Txx,Cyan); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); } date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; for j = 0 to 6 { fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]); } Text_SetSize(tx,25); Text_SetColor(Tx,Red); Text_SetStyle(tx,1,1); if abs(value12[1]-value11[1]) < 0.9 Then Text_Delete(tx); tx = Text_New_Self(sDate,stime,value12,NumToStr(value12-value11,2)); Text_SetColor(Tx,Blue); Text_SetStyle(tx,1,0); Text_SetSize(tx,30); Text_SetBold(tx,1); Condition1 = False; if Condition1 == False and Value12 < value11-0.55 Then { Tx4=Text_New_Self(date11,time11,Value11+PriceScale*1,"●"); Condition1 = true; Text_SetColor(Tx4,Cyan); Text_SetStyle(tx4,2,1); Text_SetSize(tx4,30); Text_SetBold(tx4,1); } } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date22 = date[0]; time22 = stime[0]; Text_SetString(tx,NumToStr(value12-value11,2)); Text_SetLocation(tx,sDate,sTime,value12); if Condition1 == False and Value12 < value11-0.55 Then { Tx4 =Text_New_Self(date11,time11,Value11+PriceScale*1,"●"); Condition1 = true; } } } If T == 1 Then { If T[1] != 1 Then { if Condition1 == true Then Text_Delete(tx4); if abs(value11-value12) >= 0.55 Then { vTL = TL_New(date12,time12,0,date12,time12,9999999999); TL_SetColor(vTL,Cyan); } For j = 18 DownTo 0 { HiVal[j+1] = HiVal[j]; HiBar[j+1] = HiBar[j]; } HiVal[0] = H; HiBar[0] = 0; date11 = date[LoBar[0]]; time11 = stime[LoBar[0]]; Value11 = LoVal[0]; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_Delete(tl); TL = TL_New_Self(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New_Self(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,상승색); if LoVal[2] > 0 and max(LoVal[0],LoVal[1],LoVal[2]) <= min(LoVal[0],LoVal[1],LoVal[2])+pt Then { txx = Text_New_Self(sDate[LoBar[0]],sTime[LoBar[0]],Loval[0],"●"); Text_SetColor(txx,Lime); Text_SetStyle(Txx,2,2); Text_SetSize(txx,30); } Condition1 = False; if Condition1 == False and LoVal[0] <= Loval[1]+PriceScale*바닥상1 and LoVal[0] >= Loval[1]-PriceScale*바닥하1 Then { Condition1 = true; Txx =Text_New_Self(date11,time11,Value11-PriceScale*0,"●"); Text_SetColor(Txx,Magenta); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); } Txx = Text_New_Self(date11,time11,Value11-PriceScale*0,"●"); Text_SetColor(Txx,Red); Text_SetStyle(Txx,2,2); Text_SetSize(txx,10); date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; for j = 0 to 5 { fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]); } Text_SetSize(tx,25); Text_SetColor(Tx,Blue); Text_SetStyle(tx,1,0); if abs(value12[1]-value11[1]) < 0.55 Then Text_Delete(tx); tx = Text_New_Self(sDate,stime,value12,NumToStr(value12-value11,2)); Text_SetColor(Tx,Red); Text_SetStyle(tx,1,1); Text_SetSize(tx,30); Text_SetBold(tx,1); } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date32 = date[0]; time32 = stime[0]; Text_SetString(tx,NumToStr(value12-value11,2)); Text_SetLocation(tx,sDate,sTime,value12); } } Text_SetColor(Txxx,Black); Text_SetSize(txxx,30); TL_SetSize(TL1,선두께); 즐거운 하루되세요 > 고성 님이 쓴 글입니다. > 제목 : 추세선 크기 세로선 > input : Period(17),선두께(2),바닥상1(2),바닥하1(1),봉상(1),봉하(2),pt(0.2); Var:상승색(Red), 하락색(Blue); Var:j(0),T(0),txx(0),txxx(0); Var: date11(0),date12(0),time11(0),time12(0),TL1(0),TL(0), date21(0),date22(0),time21(0),time22(0),tl8(0), date31(0),date32(0),time31(0),time32(0),tx(0),tx1(0),tl4(0),tl9(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](0); Array:r[7](0),fr[7](0),TL2[7](0),TL3[7](0),TX2[7](0),TX3[7](0); Plot1(value12); For j = 0 To 19 { HiBar[j] = HiBar[j] + 1; LoBar[j] = LoBar[j] + 1; } if crossup(c,highest(H,Period)[1]) Then T = 1; if CrossDown(c,Lowest(L,Period)[1]) Then T = -1; If T == -1 Then { If T[1] != -1 Then { For j = 18 DownTo 0 { LoVal[j+1] = LoVal[j]; LoBar[j+1] = LoBar[j]; } LoVal[0] = L; LoBar[0] = 0; date11 = date[HiBar[0]]; time11 = stime[HiBar[0]]; Value11 = HiVal[0]; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_Delete(tl); TL = TL_New_Self(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New_Self(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,하락색); Txx = Text_New_Self(date11,time11,Value11+PriceScale*0,"●"); Text_SetColor(Txx,Blue); Text_SetStyle(Txx,2,2); Text_SetSize(txx,10); if hival[0] <= hival[1]+PriceScale* 봉상 and hival[0] >= hival[1]-PriceScale*봉하 Then { Txx =Text_New_Self(date11,time11,Value11+PriceScale*1,"●"); Text_SetColor(Txx,Cyan); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); } date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; for j = 0 to 6 { fr[j] = LoVal[1] + ((HiVal[0] - LoVal[1]) * r[j]); } Text_SetSize(tx,25); Text_SetColor(Tx,Red); Text_SetStyle(tx,1,1); if abs(value12[1]-value11[1]) < 0.9 Then Text_Delete(tx); tx = Text_New_Self(sDate,stime,value12,NumToStr(value12-value11,2)); Text_SetColor(Tx,Blue); Text_SetStyle(tx,1,0); Text_SetSize(tx,30); Text_SetBold(tx,1); } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date22 = date[0]; time22 = stime[0]; Text_SetString(tx,NumToStr(value12-value11,2)); Text_SetLocation(tx,sDate,sTime,value12); } } If T == 1 Then { If T[1] != 1 Then { For j = 18 DownTo 0 { HiVal[j+1] = HiVal[j]; HiBar[j+1] = HiBar[j]; } HiVal[0] = H; HiBar[0] = 0; date11 = date[LoBar[0]]; time11 = stime[LoBar[0]]; Value11 = LoVal[0]; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_Delete(tl); TL = TL_New_Self(sdate,stime,Value12,NextBarSdate,NextBarStime,NextBarOpen); TL1 = TL_New_Self(date11,time11,Value11,date12,time12,Value12); TL_SetColor(TL1,상승색); if LoVal[2] > 0 and max(LoVal[0],LoVal[1],LoVal[2]) <= min(LoVal[0],LoVal[1],LoVal[2])+pt Then { txx = Text_New_Self(sDate[LoBar[0]],sTime[LoBar[0]],Loval[0],"●"); Text_SetColor(txx,Lime); Text_SetStyle(Txx,2,2); Text_SetSize(txx,30); } Condition1 = False; if Condition1 == False and LoVal[0] <= Loval[1]+PriceScale*바닥상1 and LoVal[0] >= Loval[1]-PriceScale*바닥하1 Then { Condition1 = true; Txx =Text_New_Self(date11,time11,Value11-PriceScale*0,"●"); Text_SetColor(Txx,Magenta); Text_SetStyle(Txx,2,2); Text_SetSize(txx,20); } Txx = Text_New_Self(date11,time11,Value11-PriceScale*0,"●"); Text_SetColor(Txx,Red); Text_SetStyle(Txx,2,2); Text_SetSize(txx,10); date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; for j = 0 to 5 { fr[j] = LoVal[0] + ((HiVal[1] - LoVal[0]) * r[j]); } Text_SetSize(tx,25); Text_SetColor(Tx,Blue); Text_SetStyle(tx,1,0); if abs(value12[1]-value11[1]) < 0.55 Then Text_Delete(tx); tx = Text_New_Self(sDate,stime,value12,NumToStr(value12-value11,2)); Text_SetColor(Tx,Red); Text_SetStyle(tx,1,1); Text_SetSize(tx,30); Text_SetBold(tx,1); } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; TL_SetEnd(TL1, date12,time12,Value12); date32 = date[0]; time32 = stime[0]; Text_SetString(tx,NumToStr(value12-value11,2)); Text_SetLocation(tx,sDate,sTime,value12); } } Text_SetColor(Txxx,Black); Text_SetSize(txxx,30); TL_SetSize(TL1,선두께); 1.추세선 음선의 크기가 0.55p 보다 클때 양전환되면 세로선 추가. 0.55p 보다 작거나 양선은 무관. 2.음선의 크기가 0.55p에 도달하면, 음추세선 상단 시작점에 동그라미 표시 추가. 양전환시 동그라미는 삭제(세로선이 추가됨). 감사합니다