커뮤니티
문의 드립니다.
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);
}}