2.1.1. cmlGnLoadDevice


SYNOPSYS

VT_I4 cmlGnLoadDevice ([out] VT_PI4 NumDevices, [out] VT_PI4 BoardIDList,
[out] VT_PI4 NumServos)

DESCRIPTION

  • 시스템에 설치된 하드웨어 장치를 로드하고 장치를 초기화합니다. 이 함수는 ComiMLink2의 다른 함수가 호출되기전에 반드시 한번은 수행되어야 합니다. 일반적으로 프로그램의 시작부분에서 수행해주면 됩니다.

  • 이 함수의 사용과 호출에 있어, 제공된 ㈜커미조아의 함수 헤더 파일에서는 Boland 社의 Delphi나 Microsoft 社의 Visual Basic 에서는 명시적으로 이 동작이 이루어지기 때문에 필요하지 않습니다.

PARAMETER

▶NumDevices:이매개변수를통하여실제로로드(Load)된네트워크모션보드의개수를반환합니 다. 단, 이매개변수에 NULL 을전달하면보드개수를반환하지않습니다.

▶BoardIDList:이매개변수를통하여실제로로드(Load)된네트워크모션보드의 ID 배열을반환합니다. 단, 이매개변수에 NULL 을전달하면보드 ID 배열을반환하지않습니다.

▶NumServos:이매개변수를통하여실제로로드(Load)된서보드라이브의개수를반환합니다. 단, 이매개변수에 NULL 을전달하면제어축수를반환하지않습니다.

RETURN VALUE

Value

Meaning

음수

수행 실패

ERR_NONE

수행 성공

EXAMPLE

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
   C/C++

   #include “ComiMLink2_SDK.h”
   #include “ComiMLink2_SDK_Def.h”

   #include “ComiMLink2_SDK_Def.h”
   void ProgramInitial(void)
   {
   long nNumDevices = 0;
   long DeviceList[16] = {0, };
   long nNumAxes = 0;
   if ( cmlLoadDll() != TRUE ) {
   /* OutputDebugString API 는 GUI 프로그램에서 문자열을 디버거에 보낼 수 있습니다. Borland
   C++ Builder 에서는 DebugWindows에 Event Log 를  확인(確認)할 수 있으며, MS VC++ 에서는
   Debug 윈도우에서 확인(確認)할 수 있습니다. */
   long BoardID = 0;
   OutputDebugString(“DLL 로드에 실패하였습니다”);
   // 이후 적절한 에러처리를 해주시기 바랍니다.
   }
   if cmlGnLoadDevice (&nNumDevices, DeviceList, &nNumAxes) != ERR_NONE ){
   // 에러메시지 출력
   }
   } /* ProgramInitial(void) 함수의 끝 */
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
   Visual Basic

   „ Visual Basic 에서는 명시적인 DLL 로드가 필요 없습니다.
   Private Sub Form_Load()
   Dim IRetVal As Long
   Dim nTotalDevices As Long
   Dim DeviceList(16) As Long
   Dim nTotalAxes As Long
   IRetVal = GnLoadDevice (nTotalDevices, DeviceList(0), nTotalAxes)
   If  IRetVal <> ERR_NONE Then
   MsgBox(“cmlGnLoadDevice has been failed”)
   End If
   End Sub
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
   Delphi

   //* Delphi 에서는 명시적인 DLL 로드가 필요없습니다.
   //* 단, 처음 선언시에 다음과 같은 내용이 포함되어야 합니다.
   /////////////////////////////////////////////////////////////
   // COMZIOA SDK Library 를 위한 인터페이스 파일을 사용합니다.
   uses ComiMLink2;
   ////////////////////////////////////////////////////////////
   procedure TForm1.OnCreate(Sender: TObject);
   var
   g_nDevs : LongInt;
   DevList : Array[0..15] of LongInt
   g_nAxes : LongInt;
   begin
   if ( cmlGnLoadDevice (@g_nDevs, @DevList, @g_nAxes) <> ERR_NONE ) then
   begin
   // 에러메시지 출력
   exit;
   end;
   end;

SEE ALSO