커뮤니티
부탁드림니다
2017-02-23 14:46:38
206
글번호 107198
그림과같이 파란추세선환성에 고점에
빨강추세선완성에 저점에
번호를 넣고 싶습니다
미리 감사드림니다
----------------------
Input:length(3);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),처리구분(""),T(0),Color(0);
var:tx1(0),tx2(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL_SetSize(TL1,2);
if 고점[2,1] == 0 or (고점[2,1] > 0 and 고점[2,1] < 고점[1,1]) Then
color = red;
TL_SetColor(TL1,color);
if TL_SetColor(TL1,color)>1 then {
}
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL_SetSize(TL1,2);
if 저점[2,1] == 0 or (저점[2,1] > 0 and 저점[2,1] > 저점[1,1]) Then
color = blue;
TL_SetColor(TL1,color);
}
}
- 1. 107734_사용자_지정_2.png (0.06 MB)
답변 1
예스스탁 예스스탁 답변
2017-02-23 19:12:27
안녕하세요
예스스탁입니다.
Input:length(3);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),처리구분(""),T(0),Color(0);
var:tx1(0),tx2(0),x(0),y(0),tx11(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL_SetSize(TL1,2);
if 고점[2,1] == 0 or (고점[2,1] > 0 and 고점[2,1] < 고점[1,1]) Then{
color = red;
}
TL_SetColor(TL1,color);
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL_SetSize(TL1,2);
if 저점[2,1] == 0 or (저점[2,1] > 0 and 저점[2,1] > 저점[1,1]) Then{
color = blue;
}
TL_SetColor(TL1,color);
}
}
if TL1 != TL1[1] and (color == red or color[1] ==red) and 처리구분 == "저점처리" Then{
X = X+1;
tx11 = Text_New(TL_GetBeginDate(TL1[1]),TL_GetBeginTime(TL1[1]),TL_GetBeginVal(TL1[1]),NumToStr(X,0));
Text_SetColor(tx11,RED);
}
if TL1 != TL1[1] and (color == blue or color[1] == blue) and 처리구분 == "고점처리" Then{
Y = Y+1;
tx11 = Text_New(TL_GetBeginDate(TL1[1]),TL_GetBeginTime(TL1[1]),TL_GetBeginVal(TL1[1]),NumToStr(Y,0));
Text_SetColor(tx11,blue);
}
if color == blue Then
X = 0;
if color == red Then
Y = 0;
즐거운 하루되세요
> djhsfg 님이 쓴 글입니다.
> 제목 : 부탁드림니다
> 그림과같이 파란추세선환성에 고점에
빨강추세선완성에 저점에
번호를 넣고 싶습니다
미리 감사드림니다
----------------------
Input:length(3);
Var:j(0),lastHiVal(0),lastLoVal(0),sBar(0),eBar(0),TL1(0),처리구분(""),T(0),Color(0);
var:tx1(0),tx2(0);
Array:고점[10,2](0),저점[10,2](0); //가격,위치
처리구분 = "";
If Highest(H,length) == H and lastHiVal <> H and
Lowest(L,length) == L and lastLoVal <> L Then
{
If 저점[1,1] > L Then 처리구분 = "저점처리";
If 고점[1,1] < H Then 처리구분 = "고점처리";
}
Else If Highest(H,length) == H and lastHiVal <> H Then
처리구분 = "고점처리";
Else If Lowest(L,length) == L and lastLoVal <> L Then
처리구분 = "저점처리";
If 처리구분 == "고점처리" Then
{
lastHiVal = H;
If 고점[1,2] < 저점[1,2] Then
{
For j = 10 DownTo 2
{
고점[j,1] = 고점[j-1,1];
고점[j,2] = 고점[j-1,2];
}
}
If 고점[1,2] < 저점[1,2] or 고점[1,1] < H Then
{
고점[1,1] = H;
고점[1,2] = Index;
sBar = Index - 저점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],저점[1,1],sDate[eBar],sTime[eBar],고점[1,1]);
TL_SetSize(TL1,2);
if 고점[2,1] == 0 or (고점[2,1] > 0 and 고점[2,1] < 고점[1,1]) Then
color = red;
TL_SetColor(TL1,color);
if TL_SetColor(TL1,color)>1 then {
}
}
}
If 처리구분 == "저점처리" Then
{
lastLoVal = L;
If 저점[1,2] < 고점[1,2] then
{
For j = 10 DownTo 2
{
저점[j,1] = 저점[j-1,1];
저점[j,2] = 저점[j-1,2];
}
}
If 저점[1,2] < 고점[1,2] or 저점[1,1] > L then
{
저점[1,1] = L;
저점[1,2] = Index;
sBar = Index - 고점[1,2];
eBar = 0;
If TL_GetBeginDate(TL1) == sDate[sBar] and TL_GetBeginTime(TL1) == sTime[sBar] Then
{
TL_Delete(TL1);
}
TL1 = TL_New(sDate[sBar],sTime[sBar],고점[1,1],sDate[eBar],sTime[eBar],저점[1,1]);
TL_SetSize(TL1,2);
if 저점[2,1] == 0 or (저점[2,1] > 0 and 저점[2,1] > 저점[1,1]) Then
color = blue;
TL_SetColor(TL1,color);
}
}