커뮤니티

중간선 표시 크기

프로필 이미지
고성
2023-09-04 21:38:55
1070
글번호 172122
답변완료
input : Period(180); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0), date21(0),date22(0),time21(0),time22(0), date31(0),date32(0),time31(0),time32(0); var : TL(0),TL1(0),TX(0),tl4(0),tl5(0),tl9(0); var : box(0),box1(0),txx(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](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]; date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; box = box_new(date11,time11,Value11,date12,time12,Value12); tl = tl_new(date11,time11,(Value11+value12)/2,date12,time12,(Value11+value12)/2); tl1 = tl_new(date11,time11,value11 - abs(Value11-value12)*0.618,date12,time12,value11 - abs(Value11-value12)*0.618); } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; date22 = date[0]; time22 = stime[0]; Box_SetEnd(box,date12,time12,Value12); } TL_SetBegin(tl,date11,time11,(Value11+value12)/2); TL_SetEnd(tl,date12,time12,(Value11+value12)/2); TL_SetBegin(tl1,date11,time11,value11 - abs(Value11-value12)*0.618); TL_SetEnd(tl1,date12,time12,value11 - abs(Value11-value12)*0.618); if value12 > value11-0.7 Then { Box_SetColor(box,LCyan); Box_SetFill(box,true,20); } else if value12 <= value11-0.7 and value12 > value11-1 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,50); } else if value12 <= value11-1 and value12 > value11-1.7 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,40); } else { Box_SetColor(box,Yellow); Box_SetFill(box,true,30); } } 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]; date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; box = box_new(date11,time11,Value11,date12,time12,Value12); tl = tl_new(date11,time11,(Value11+value12)/2,date12,time12,(Value11+value12)/2); tl1 = tl_new(date11,time11,value11 + abs(Value11-value12)*0.618,date12,time12,value11 + abs(Value11-value12)*0.618); } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; date32 = date[0]; time32 = stime[0]; Box_SetEnd(box,date12,time12,Value12); } TL_SetBegin(tl,date11,time11,(Value11+value12)/2); TL_SetEnd(tl,date12,time12,(Value11+value12)/2); TL_SetBegin(tl1,date11,time11,value11 + abs(Value11-value12)*0.618); TL_SetEnd(tl1,date12,time12,value11 + abs(Value11-value12)*0.618); if Value12 >= value11+1 Then { Box_SetColor(box,Magenta); Box_SetFill(box,true,20); } Else { Box_SetColor(box,Orange); Box_SetFill(box,true,20); } } 추세선의 크기가 0.9p 보다 클 때만 중간선(TL,TL1) 표시. 감사합니다.
지표
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2023-09-05 08:38:44

안녕하세요 예스스탁입니다. input : Period(180); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0), date21(0),date22(0),time21(0),time22(0), date31(0),date32(0),time31(0),time32(0); var : TL(0),TL1(0),TX(0),tl4(0),tl5(0),tl9(0); var : box(0),box1(0),txx(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](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]; date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; box = box_new(date11,time11,Value11,date12,time12,Value12); Condition1 = False; } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; date22 = date[0]; time22 = stime[0]; Box_SetEnd(box,date12,time12,Value12); } if Condition1 == False and abs(value11-value12) >= 0.9 Then { Condition1 = true; tl = tl_new(date11,time11,(Value11+value12)/2,date12,time12,(Value11+value12)/2); tl1 = tl_new(date11,time11,value11 - abs(Value11-value12)*0.618,date12,time12,value11 - abs(Value11-value12)*0.618); } if Condition1 == true Then { TL_SetBegin(tl,date11,time11,(Value11+value12)/2); TL_SetEnd(tl,date12,time12,(Value11+value12)/2); TL_SetBegin(tl1,date11,time11,value11 - abs(Value11-value12)*0.618); TL_SetEnd(tl1,date12,time12,value11 - abs(Value11-value12)*0.618); } if value12 > value11-0.7 Then { Box_SetColor(box,LCyan); Box_SetFill(box,true,20); } else if value12 <= value11-0.7 and value12 > value11-1 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,50); } else if value12 <= value11-1 and value12 > value11-1.7 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,40); } else { Box_SetColor(box,Yellow); Box_SetFill(box,true,30); } } 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]; date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; box = box_new(date11,time11,Value11,date12,time12,Value12); Condition2 = false; } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; date32 = date[0]; time32 = stime[0]; Box_SetEnd(box,date12,time12,Value12); } if Condition2 == False and abs(value12-value11) >= 0.9 Then { Condition2 = true; tl = tl_new(date11,time11,(Value11+value12)/2,date12,time12,(Value11+value12)/2); tl1 = tl_new(date11,time11,value11 + abs(Value11-value12)*0.618,date12,time12,value11 + abs(Value11-value12)*0.618); } if Condition2 == true Then { TL_SetBegin(tl,date11,time11,(Value11+value12)/2); TL_SetEnd(tl,date12,time12,(Value11+value12)/2); TL_SetBegin(tl1,date11,time11,value11 + abs(Value11-value12)*0.618); TL_SetEnd(tl1,date12,time12,value11 + abs(Value11-value12)*0.618); } if Value12 >= value11+1 Then { Box_SetColor(box,Magenta); Box_SetFill(box,true,20); } Else { Box_SetColor(box,Orange); Box_SetFill(box,true,20); } } 즐거운 하루되세요 > 고성 님이 쓴 글입니다. > 제목 : 중간선 표시 크기 > input : Period(180); Var:j(0),T(0); Var: date11(0),date12(0),time11(0),time12(0), date21(0),date22(0),time21(0),time22(0), date31(0),date32(0),time31(0),time32(0); var : TL(0),TL1(0),TX(0),tl4(0),tl5(0),tl9(0); var : box(0),box1(0),txx(0); Array:HiVal[20](0),LoVal[20](0),HiBar[20](0),LoBar[20](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]; date21 = date[HiBar[0]]; time21 = stime[HiBar[0]]; date22 = date[0]; time22 = stime[0]; box = box_new(date11,time11,Value11,date12,time12,Value12); tl = tl_new(date11,time11,(Value11+value12)/2,date12,time12,(Value11+value12)/2); tl1 = tl_new(date11,time11,value11 - abs(Value11-value12)*0.618,date12,time12,value11 - abs(Value11-value12)*0.618); } If LoVal[0] > L Then { LoVal[0] = L; LoBar[0] = 0; date12 = date[LoBar[0]]; time12 = stime[LoBar[0]]; Value12 = LoVal[0]; date22 = date[0]; time22 = stime[0]; Box_SetEnd(box,date12,time12,Value12); } TL_SetBegin(tl,date11,time11,(Value11+value12)/2); TL_SetEnd(tl,date12,time12,(Value11+value12)/2); TL_SetBegin(tl1,date11,time11,value11 - abs(Value11-value12)*0.618); TL_SetEnd(tl1,date12,time12,value11 - abs(Value11-value12)*0.618); if value12 > value11-0.7 Then { Box_SetColor(box,LCyan); Box_SetFill(box,true,20); } else if value12 <= value11-0.7 and value12 > value11-1 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,50); } else if value12 <= value11-1 and value12 > value11-1.7 Then { Box_SetColor(box,Cyan); Box_SetFill(box,true,40); } else { Box_SetColor(box,Yellow); Box_SetFill(box,true,30); } } 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]; date31 = date[LoBar[0]]; time31 = stime[LoBar[0]]; date32 = date[0]; time32 = stime[0]; box = box_new(date11,time11,Value11,date12,time12,Value12); tl = tl_new(date11,time11,(Value11+value12)/2,date12,time12,(Value11+value12)/2); tl1 = tl_new(date11,time11,value11 + abs(Value11-value12)*0.618,date12,time12,value11 + abs(Value11-value12)*0.618); } If HiVal[0] < H Then { HiVal[0] = H; HiBar[0] = 0; date12 = date[HiBar[0]]; time12 = stime[HiBar[0]]; Value12 = HiVal[0]; date32 = date[0]; time32 = stime[0]; Box_SetEnd(box,date12,time12,Value12); } TL_SetBegin(tl,date11,time11,(Value11+value12)/2); TL_SetEnd(tl,date12,time12,(Value11+value12)/2); TL_SetBegin(tl1,date11,time11,value11 + abs(Value11-value12)*0.618); TL_SetEnd(tl1,date12,time12,value11 + abs(Value11-value12)*0.618); if Value12 >= value11+1 Then { Box_SetColor(box,Magenta); Box_SetFill(box,true,20); } Else { Box_SetColor(box,Orange); Box_SetFill(box,true,20); } } 추세선의 크기가 0.9p 보다 클 때만 중간선(TL,TL1) 표시. 감사합니다.