cmlMxIsDone¶
SYNOPSYS¶
VT_I4 cmlMxIsDone ([in] VT_I4 BoardID, [in] VT_I4 NumAxes, [in] VT_PI4 NumChannel, [out] VT_PI4 IsDone)
DESCRIPTION¶
여러 개의 축에 대하여 지정한 모든 축의 모션이 완료됐는지를 확인(確認)합니다. 이 함수는 다축제어뿐 아니라 원점복귀나 단축모션제어 작업시에도 활용할 수 있습니다.
이 함수의 사용과 호출에 있어, 제공된 ㈜커미조아의 함수 헤더 Visual Basic 에서는 함수의 첨두어 cml 가 붙지 않습니다.
PARAMETER¶
▶ BoardID : 사용자가 설정한 디바이스(보드) ID.
▶ NumAxes : 동시에 작업을 수행할 대상 축의 수
▶ NumChannel : 작업완료를 확인(確認)할 대상 축의 배열 주소값. 이 배열의 크기는 NumAxes값과 일치하거나 커야 합니다.
▶ IsDone : 다축구동 완료 여부를 판단할 수 있는 매개변수 입니다.
Value
Meaning
cmlFALSE
모션작업이 완료되지 않음
cmlTRUE
모션작업이 완료됨
RETURN VALUE¶
Value |
Meaning |
---|---|
음수 |
수행 실패 |
ERR_NONE |
수행 성공 |
EXAMPLE¶
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | C/C++
long nIsDone;
long BoardID = 0;
long nNumChannel[2] = {cmX1, cmY1};
double fDistList[2] = {1000, 1000};
if(cmlMxMove(BoardID, 2, nNumChannel, fDistList, cmlFALSE) != ERR_NONE){
//Handle 은 사용자가 생성한 폼의 핸들 값입니다.
// 에러메시지 출력
return;
}
while (1){
cmlMxIsDone(BoardID, 2, nNumChannel, &nIsDone);
if(nIsDone == cmlTRUE) break;
else{
// 다축 모션이 종료되지 않은 경우입니다. 적절한 처리를 합니다.
}
}
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | Visual Basic
Dim BoardID As Long
Dim nNumChannel(2) As Long
Dim fDistList(2) As Double
BoardID = 0
„ 대상 축 설정
nNumChannel(0) = cmX1
nNumChannel(1) = cmY1
„ 대상 축에 대한 이송 거리 설정
fDistList(0) = 1000
fDistList(1) = 1000
If(MxMove(BoardID, 2, nNumChannel(0), fDistList(0), cmlFALSE) <> ERR_NONE) Then
// 에러메시지 출력
Exit Sub
End If
While(MxIsDone(BoardID, 2, nNumChannel(0), cmlTRUE) <> ERR_NONE) Then
// 에러메시지 출력
Exit Sub;
End If
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | Delphi
BoardID := 0;
// 대상 축 설정
nNumChannel[0] := cmX1;
nNumChannel[1] := cmY1;
// 대상 축에 대한 이송 거리 설정
fDistList[0] := 1000;
fDistList[1] := 1000;
if(cmlMxMove(BoardID, 2, @nNumChannel, @fDistList) <> ERR_NONE) then begin
// 에러메시지 출력
end;
while(cmlMxIsDone(BoardID, 2, @nNumChannel, @IsDone) <> ERR_NONE) do begin
// 여기서 IsDone 이 cmlTRUE 이면 Loop 를 탈출하면 됩니다.
…
end;
if(cmlErrGetLastCode() <> ERR_NONE) then begin
// 에러메시지 출력
end;
|
SEE ALSO¶
See also