커뮤니티

문의 드립니다.

프로필 이미지
뮬리
2018-11-14 15:57:00
179
글번호 123666
답변완료
항상 고맙습니다. data2의 자료가 data1의 차트에 나타 나도록 수정 부탁 드립니다. Input:chngRate(0.1); Var:j(0),lastHiVal(0),lastLoVal(0),turnPntBit(""),TL1(0),TL2(0),TL3(0); Array:valArr[10](0),barArr[10](0),turnPntArr[10](""); For j = 0 To 9 { barArr[j] = barArr[j] + 1; } Condition1 = Min(valArr[1],valArr[2]) * (1 + (chngRate/100)) < H and lastHiVal < H; Condition2 = Max(valArr[1],valArr[2]) * (1 - (chngRate/100)) > L and (lastLoVal > L || lastLoVal == 0); If Condition1 Then { lastHiVal = H; lastLoVal = 0; } If Condition2 Then { lastLoVal = L; lastHiVal = 0; } turnPntBit = ""; If Condition1 and Condition2 Then { If Max(valArr[1],valArr[2]) < H and Min(valArr[1],valArr[2]) > L Then turnPntBit = "HiLo"; Else If Max(valArr[1],valArr[2]) < H Then turnPntBit = "Hi"; Else If Min(valArr[1],valArr[2]) > L Then turnPntBit = "Lo"; } Else If Condition1 Then turnPntBit = "Hi"; Else If Condition2 Then turnPntBit = "Lo"; If turnPntBit <> "" Then { If turnPntBit == "HiLo" Then { valArr[1] = IFF(turnPntArr[1] == "Hi",H,L); barArr[1] = 0; TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else turnPntBit = "Hi"; } If turnPntBit <> turnPntArr[1] Then { for j = 8 downto 1 { valArr[j+1] = valArr[j]; barArr[j+1] = barArr[j]; turnPntArr[j+1] = turnPntArr[j]; } } If turnPntBit <> turnPntArr[1] or (turnPntBit == turnPntArr[1] and ((turnPntBit == "Hi" and valArr[1] < H) or (turnPntBit == "Lo" and valArr[1] > L))) Then { valArr[1] = IFF(turnPntBit == "Hi",H,L); barArr[1] = 0; turnPntArr[1] = turnPntBit; If turnPntArr[1][1] <> turnPntArr[1][0] Then TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],sDate[barArr[1]],sTime[barArr[1]],valArr[1]); Else TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1][1] <> turnPntArr[1][0] Then{ if turnPntArr[1][0] == "Lo" then{ TL_Delete(TL2); TL_SetExtRight(TL2,true); TL_SetColor(TL2,yellow); } if turnPntArr[1][0] == "Hi" then{ TL_Delete(TL3); TL_SetExtRight(TL3,true); TL_SetColor(TL3,yellow); } } } TL_SetSize(TL1,0); TL_SetColor(TL1,white); var : AA(0),BB(0),CC(0),DD(0); var : TL51(0),TL52(0),TL53(0),TL54(0),TL55(0),TL56(0),TL57(0),TL59(0); if turnPntBit=="Hi" Then{ AA = valarr[1]; BB = valarr[2]; CC = valarr[3]; DD = valarr[4]; TL_Delete(TL51); TL51 = TL_New(sdate[1],stime[1],CC+abs(CC-DD),sdate,stime,CC+abs(CC-DD)); TL_SetExtRight(TL51,true); TL_SetExtLeft(TL51,true); TL_Delete(TL52); TL52 = TL_New(sdate[1],stime[1],CC+abs(CC-DD)/2,sdate,stime,CC+abs(CC-DD)/2); TL_SetExtRight(TL52,true); TL_SetExtLeft(TL52,true); TL_SetColor(TL52,GREEN); TL_Delete(TL54); TL54 = TL_New(sdate[1],stime[1],CC+(BB-DD),sdate,stime,CC+(BB-DD)); TL_SetExtRight(TL54,true); TL_SetExtLeft(TL54,true); TL_SetColor(TL54,MAGENTA); TL_Delete(TL57); TL57 = TL_New(sdate[barArr[3]],stime[barArr[3]],cc,sdate,stime,cc); TL_SetExtRight(TL57,true); TL_SetExtleft(TL57,true); } if turnPntBit=="Lo" Then{ AA = valarr[1]; BB = valarr[2]; CC = valarr[3]; DD = valarr[4]; TL_Delete(TL51); TL51 = TL_New(sdate[1],stime[1],CC-abs(CC-DD),sdate,stime,CC-abs(CC-DD)); TL_SetExtRight(TL51,true); TL_SetExtLeft(TL51,true); TL_Delete(TL52); TL52 = TL_New(sdate[1],stime[1],CC-abs(CC-DD)/2,sdate,stime,CC-abs(CC-DD)/2); TL_SetExtRight(TL52,true); TL_SetExtLeft(TL52,true); TL_Delete(TL53); TL53 = TL_New(sdate[1],stime[1],CC-abs(BB-CC),sdate,stime,CC-abs(BB-CC)); TL_SetExtRight(TL53,true); TL_SetExtLeft(TL53,true); TL_Delete(TL54); TL54 = TL_New(sdate[1],stime[1],CC-(-BB+DD),sdate,stime,CC-(-BB+DD)); TL_SetExtRight(TL54,true); TL_SetExtLeft(TL54,true); TL_Delete(TL57); TL57 = TL_New(sdate[barArr[3]],stime[barArr[3]],cc,sdate,stime,cc); TL_SetExtRight(TL57,true); TL_SetExtleft(TL57,true); }}
지표
답변 1
프로필 이미지

예스스탁 예스스탁 답변

2018-11-15 10:10:17

안녕하세요 예스스탁입니다. 참조데이터를 이용해 기본차트에 추세선을 긋도록 작성하기는 어렵습니다. 도움을 드리지 못해 죄송합니다. 즐거운 하루되세요 > 뮬리 님이 쓴 글입니다. > 제목 : 문의 드립니다. > 항상 고맙습니다. data2의 자료가 data1의 차트에 나타 나도록 수정 부탁 드립니다. Input:chngRate(0.1); Var:j(0),lastHiVal(0),lastLoVal(0),turnPntBit(""),TL1(0),TL2(0),TL3(0); Array:valArr[10](0),barArr[10](0),turnPntArr[10](""); For j = 0 To 9 { barArr[j] = barArr[j] + 1; } Condition1 = Min(valArr[1],valArr[2]) * (1 + (chngRate/100)) < H and lastHiVal < H; Condition2 = Max(valArr[1],valArr[2]) * (1 - (chngRate/100)) > L and (lastLoVal > L || lastLoVal == 0); If Condition1 Then { lastHiVal = H; lastLoVal = 0; } If Condition2 Then { lastLoVal = L; lastHiVal = 0; } turnPntBit = ""; If Condition1 and Condition2 Then { If Max(valArr[1],valArr[2]) < H and Min(valArr[1],valArr[2]) > L Then turnPntBit = "HiLo"; Else If Max(valArr[1],valArr[2]) < H Then turnPntBit = "Hi"; Else If Min(valArr[1],valArr[2]) > L Then turnPntBit = "Lo"; } Else If Condition1 Then turnPntBit = "Hi"; Else If Condition2 Then turnPntBit = "Lo"; If turnPntBit <> "" Then { If turnPntBit == "HiLo" Then { valArr[1] = IFF(turnPntArr[1] == "Hi",H,L); barArr[1] = 0; TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1] == "Hi" Then turnPntBit = "Lo"; Else turnPntBit = "Hi"; } If turnPntBit <> turnPntArr[1] Then { for j = 8 downto 1 { valArr[j+1] = valArr[j]; barArr[j+1] = barArr[j]; turnPntArr[j+1] = turnPntArr[j]; } } If turnPntBit <> turnPntArr[1] or (turnPntBit == turnPntArr[1] and ((turnPntBit == "Hi" and valArr[1] < H) or (turnPntBit == "Lo" and valArr[1] > L))) Then { valArr[1] = IFF(turnPntBit == "Hi",H,L); barArr[1] = 0; turnPntArr[1] = turnPntBit; If turnPntArr[1][1] <> turnPntArr[1][0] Then TL1 = TL_New(sDate[barArr[2]],sTime[barArr[2]],valArr[2],sDate[barArr[1]],sTime[barArr[1]],valArr[1]); Else TL_SetEnd(TL1,sDate[barArr[1]],sTime[barArr[1]],valArr[1]); If turnPntArr[1][1] <> turnPntArr[1][0] Then{ if turnPntArr[1][0] == "Lo" then{ TL_Delete(TL2); TL_SetExtRight(TL2,true); TL_SetColor(TL2,yellow); } if turnPntArr[1][0] == "Hi" then{ TL_Delete(TL3); TL_SetExtRight(TL3,true); TL_SetColor(TL3,yellow); } } } TL_SetSize(TL1,0); TL_SetColor(TL1,white); var : AA(0),BB(0),CC(0),DD(0); var : TL51(0),TL52(0),TL53(0),TL54(0),TL55(0),TL56(0),TL57(0),TL59(0); if turnPntBit=="Hi" Then{ AA = valarr[1]; BB = valarr[2]; CC = valarr[3]; DD = valarr[4]; TL_Delete(TL51); TL51 = TL_New(sdate[1],stime[1],CC+abs(CC-DD),sdate,stime,CC+abs(CC-DD)); TL_SetExtRight(TL51,true); TL_SetExtLeft(TL51,true); TL_Delete(TL52); TL52 = TL_New(sdate[1],stime[1],CC+abs(CC-DD)/2,sdate,stime,CC+abs(CC-DD)/2); TL_SetExtRight(TL52,true); TL_SetExtLeft(TL52,true); TL_SetColor(TL52,GREEN); TL_Delete(TL54); TL54 = TL_New(sdate[1],stime[1],CC+(BB-DD),sdate,stime,CC+(BB-DD)); TL_SetExtRight(TL54,true); TL_SetExtLeft(TL54,true); TL_SetColor(TL54,MAGENTA); TL_Delete(TL57); TL57 = TL_New(sdate[barArr[3]],stime[barArr[3]],cc,sdate,stime,cc); TL_SetExtRight(TL57,true); TL_SetExtleft(TL57,true); } if turnPntBit=="Lo" Then{ AA = valarr[1]; BB = valarr[2]; CC = valarr[3]; DD = valarr[4]; TL_Delete(TL51); TL51 = TL_New(sdate[1],stime[1],CC-abs(CC-DD),sdate,stime,CC-abs(CC-DD)); TL_SetExtRight(TL51,true); TL_SetExtLeft(TL51,true); TL_Delete(TL52); TL52 = TL_New(sdate[1],stime[1],CC-abs(CC-DD)/2,sdate,stime,CC-abs(CC-DD)/2); TL_SetExtRight(TL52,true); TL_SetExtLeft(TL52,true); TL_Delete(TL53); TL53 = TL_New(sdate[1],stime[1],CC-abs(BB-CC),sdate,stime,CC-abs(BB-CC)); TL_SetExtRight(TL53,true); TL_SetExtLeft(TL53,true); TL_Delete(TL54); TL54 = TL_New(sdate[1],stime[1],CC-(-BB+DD),sdate,stime,CC-(-BB+DD)); TL_SetExtRight(TL54,true); TL_SetExtLeft(TL54,true); TL_Delete(TL57); TL57 = TL_New(sdate[barArr[3]],stime[barArr[3]],cc,sdate,stime,cc); TL_SetExtRight(TL57,true); TL_SetExtleft(TL57,true); }}