11. Urządzenia peryferyjne robota
11.1. Konfiguracja chwytaka
Prototyp |
|
|---|---|
Opis |
Konfiguracja chwytaka |
Parametry wymagane |
|
Parametry domyślne |
|
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.2. Pobieranie konfiguracji chwytaka
Prototyp |
|
|---|---|
Opis |
Pobieranie konfiguracji chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.3. Aktywacja chwytaka
Prototyp |
|
|---|---|
Opis |
Aktywacja chwytaka |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.4. Sterowanie chwytakiem
Prototyp |
|
|---|---|
Opis |
Sterowanie chwytakiem |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.5. Pobieranie stanu ruchu chwytaka
Prototyp |
|
|---|---|
Opis |
Pobieranie stanu ruchu chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.6. Pobieranie stanu aktywacji chwytaka
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie stanu aktywacji chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.7. Pobieranie pozycji chwytaka
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie pozycji chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.8. Pobieranie prędkości chwytaka
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie prędkości chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.9. Pobieranie prądu chwytaka
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie prądu chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.10. Pobieranie napięcia chwytaka
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie napięcia chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.11. Pobieranie temperatury chwytaka
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie temperatury chwytaka |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.12. Obliczenie punktu wstępnego chwytania - wizja
Prototyp |
|
|---|---|
Opis |
Obliczenie punktu wstępnego chwytania - wizja |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.13. Obliczenie punktu wycofania - wizja
Prototyp |
|
|---|---|
Opis |
Obliczenie punktu wycofania - wizja |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.14. Przykład kodu operacji chwytakiem robota
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4company = 4
5device = 0
6softversion = 0
7bus = 2
8index = 2
9act = 0
10max_time = 30000
11block = 0
12status = 0
13fault = 0
14active_status = 0
15current_pos = 0
16current = 0
17voltage = 0
18temp = 0
19speed = 0
20robot.SetGripperConfig(company, device, softversion, bus)
21time.sleep(1)
22error,[company, device, softversion, bus] = robot.GetGripperConfig()
23print(f"gripper config:{company},{device},{softversion},{bus}")
24robot.ActGripper(index, act)
25time.sleep(1)
26act = 1
27robot.ActGripper(index, act)
28time.sleep(1)
29error = robot.MoveGripper(index, 90, 50, 50, max_time, block, 0, 0, 0, 0)
30print(f"MoveGripper retval is:{error}")
31time.sleep(1)
32error = robot.MoveGripper(index, 30, 50, 0, max_time, block, 0, 0, 0, 0)
33print(f"MoveGripper retval is:{error}")
34error, [fault, status] = robot.GetGripperMotionDone()
35print(f"motion status:{fault},{status}")
36error, [fault, active_status] = robot.GetGripperActivateStatus()
37print(f"gripper active fault is:{fault},status is:{active_status}")
38error, [fault, current_pos] = robot.GetGripperCurPosition()
39print(f"fault is:{fault},current position is:{current_pos}")
40error, [fault, current] = robot.GetGripperCurCurrent()
41print(f"fault is:{fault},current current is:{current}")
42error, [fault, voltage] = robot.GetGripperVoltage()
43print(f"fault is:{fault},current voltage is:{voltage}")
44error, [fault, temp] = robot.GetGripperTemp()
45print(f"fault is:{fault},current temperature is:{temp}")
46error, [fault, speed] = robot.GetGripperCurSpeed()
47print(f"fault is:{fault},current speed is:{speed}")
48retval = 0
49prepick_pose = [0.0]*6
50postpick_pose = [0.0]*6
51p1Desc = [-419.524, -13.000, 351.569, -178.118, 0.314, 3.833]
52p2Desc = [-321.222, 185.189, 335.520, -179.030, -1.284, -29.869]
53retval, prepick_pose = robot.ComputePrePick(p1Desc, 10, 0)
54print(f"ComputePrePick retval is:{retval}")
55print(f"xyz is:{prepick_pose[0]},{prepick_pose[1]},{prepick_pose[2]};rpy is:{prepick_pose[3]},{prepick_pose[4]},{prepick_pose[5]}")
56retval, postpick_pose = robot.ComputePostPick(p2Desc, -10, 0)
57print(f"ComputePostPick retval is:{retval}")
58print(f"xyz is:{postpick_pose[0]},{postpick_pose[1]},{postpick_pose[2]};rpy is:{postpick_pose[3]},{postpick_pose[4]},{postpick_pose[5]}")
59robot.CloseRPC()
11.15. Pobieranie liczby obrotów chwytaka obrotowego
Nowe w wersji python: SDK-v2.0.7
Prototyp |
|
|---|---|
Opis |
Pobieranie liczby obrotów chwytaka obrotowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.16. Pobieranie procentu prędkości obrotowej chwytaka obrotowego
Nowe w wersji python: SDK-v2.0.7
Prototyp |
|
|---|---|
Opis |
Pobieranie procentu prędkości obrotowej chwytaka obrotowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.17. Pobieranie procentu momentu obrotowego chwytaka obrotowego
Nowe w wersji python: SDK-v2.0.7
Prototyp |
|
|---|---|
Opis |
Pobieranie procentu momentu obrotowego chwytaka obrotowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.18. Przykład kodu pobrania stanu chwytaka obrotowego
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4fault = 0
5rotNum = 0.0
6rotSpeed = 0
7rotTorque = 0
8error,fault, rotNum = robot.GetGripperRotNum()
9error,fault, rotSpeed = robot.GetGripperRotSpeed()
10error,fault, rotTorque = robot.GetGripperRotTorque()
11print(f"gripper rot num:{rotNum},gripper rotSpeed:{rotSpeed},gripper rotTorque:{rotTorque}")
12robot.CloseRPC()
11.19. Uruchomienie, zatrzymanie przenośnika taśmowego
Prototyp |
|
|---|---|
Opis |
Uruchomienie, zatrzymanie przenośnika taśmowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.20. Rejestracja punktu detekcji IO
Prototyp |
|
|---|---|
Opis |
Rejestracja punktu detekcji IO |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.21. Rejestracja punktu A
Prototyp |
|
|---|---|
Opis |
Rejestracja punktu A |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.22. Rejestracja punktu odniesienia
Prototyp |
|
|---|---|
Opis |
Rejestracja punktu odniesienia |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.23. Rejestracja punktu B
Prototyp |
|
|---|---|
Opis |
Rejestracja punktu B |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.24. Detekcja IO przedmiotu na przenośniku
Prototyp |
|
|---|---|
Opis |
Detekcja IO przedmiotu na przenośniku |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.25. Pobieranie bieżącej pozycji przedmiotu
Prototyp |
|
|---|---|
Opis |
Pobieranie bieżącej pozycji przedmiotu |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.26. Rozpoczęcie śledzenia przenośnika
Prototyp |
|
|---|---|
Opis |
Rozpoczęcie śledzenia przenośnika |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.27. Zatrzymanie śledzenia przenośnika
Prototyp |
|
|---|---|
Opis |
Zatrzymanie śledzenia przenośnika |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.28. Konfiguracja parametrów przenośnika
Prototyp |
|
|---|---|
Opis |
Konfiguracja parametrów przenośnika |
Parametry wymagane |
|
Parametry domyślne |
|
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.29. Kompensacja punktu chwytania przenośnika
Prototyp |
|
|---|---|
Opis |
Kompensacja punktu chwytania przenośnika |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.30. Ruch liniowy
Prototyp |
|
|---|---|
Opis |
Ruch liniowy |
Parametry wymagane |
|
Parametry domyślne |
|
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.31. Detekcja wejścia komunikacyjnego przenośnika
Nowe w wersji python: SDK-v2.1.1
Prototyp |
|
|---|---|
Opis |
Detekcja wejścia komunikacyjnego przenośnika |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.32. Wyzwolenie detekcji wejścia komunikacyjnego przenośnika
Nowe w wersji python: SDK-v2.1.1
Prototyp |
|
|---|---|
Opis |
Wyzwolenie detekcji wejścia komunikacyjnego przenośnika |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.33. Przykład kodu operacji przenośnika robota
1from fairino import Robot
2import time
3import threading
4# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
5robot = Robot.RPC('192.168.58.2')
6retval = robot.ConveyorStartEnd(1)
7print(f"ConveyorStartEnd retval is:{retval}")
8retval = robot.ConveyorPointIORecord()
9print(f"ConveyorPointIORecord retval is:{retval}")
10retval = robot.ConveyorPointARecord()
11print(f"ConveyorPointARecord retval is:{retval}")
12retval = robot.ConveyorRefPointRecord()
13print(f"ConveyorRefPointRecord retval is:{retval}")
14retval = robot.ConveyorPointBRecord()
15print(f"ConveyorPointBRecord retval is:{retval}")
16retval = robot.ConveyorStartEnd(0)
17print(f"ConveyorStartEnd retval is:{retval}")
18param = [1.0, 10000.0, 200.0, 0.0, 0.0, 20.0]
19retval = robot.ConveyorSetParam(param,0)
20print(f"ConveyorSetParam retval is:{retval}")
21cmp = [0.0, 0.0, 0.0]
22retval = robot.ConveyorCatchPointComp(cmp)
23print(f"ConveyorCatchPointComp retval is:{retval}")
24index = 1
25max_time = 30000
26block = 0
27retval = 0
28p1Desc = [-419.524, -13.000, 351.569, -178.118, 0.314, 3.833]
29p2Desc = [-321.222, 185.189, 335.520, -179.030, -1.284, -29.869]
30retval = robot.MoveCart(p1Desc, 1, 0, 100.0)
31print(f"MoveCart retval is:{retval}")
32retval = robot.WaitMs(1)
33print(f"WaitMs retval is:{retval}")
34retval = robot.ConveyorIODetect(10000)
35print(f"ConveyorIODetect retval is:{retval}")
36retval = robot.ConveyorGetTrackData(1)
37print(f"ConveyorGetTrackData retval is:{retval}")
38retval = robot.ConveyorTrackStart(1)
39print(f"ConveyorTrackStart retval is:{retval}")
40retval = robot.ConveyorTrackMoveL("cvrCatchPoint", 1, 0, 100)
41print(f"TrackMoveL retval is:{retval}")
42retval = robot.MoveGripper(index, 51, 40, 30, max_time, block, 0, 0, 0, 0)
43print(f"MoveGripper retval is:{retval}")
44retval = robot.ConveyorTrackMoveL("cvrRaisePoint", 1, 0, 100)
45print(f"TrackMoveL retval is:{retval}")
46retval = robot.ConveyorTrackEnd()
47print(f"ConveyorTrackEnd retval is:{retval}")
48robot.MoveCart(p2Desc, 1, 0, 100.0, 100.0)
49retval = robot.MoveGripper(index, 100, 40, 10, max_time, block, 0, 0, 0, 0)
50print(f"MoveGripper retval is:{retval}")
51robot.CloseRPC()
11.34. Konfiguracja czujnika końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Konfiguracja czujnika końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.35. Pobieranie konfiguracji czujnika końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Pobieranie konfiguracji czujnika końcowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.36. Aktywacja czujnika końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Aktywacja czujnika końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.37. Zapis do rejestru czujnika końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Zapis do rejestru czujnika końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.38. Przykład kodu czujnika końcowego
1from fairino import Robot
2import time
3import threading
4# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
5robot = Robot.RPC('192.168.58.2')
6robot.AxleSensorConfig(18, 0, 0, 1)
7error, company, type = robot.AxleSensorConfigGet()
8print(f"company is:{company},type is:{type}")
9rtn = robot.AxleSensorActivate(1)
10print(f"AxleSensorActivate rtn is:{rtn}")
11time.sleep(1)
12rtn = robot.AxleSensorRegWrite(1, 4, 6, 1, 0, 0, 0)
13print(f"AxleSensorRegWrite rtn is:{rtn}")
14robot.CloseRPC()
11.39. Pobieranie protokołu urządzeń peryferyjnych robota
Nowe w wersji python: SDK-v2.0.3
Prototyp |
|
|---|---|
Opis |
Pobieranie protokołu urządzeń peryferyjnych robota |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.40. Ustawianie protokołu urządzeń peryferyjnych robota
Nowe w wersji python: SDK-v2.0.3
Prototyp |
|
|---|---|
Opis |
Ustawianie protokołu urządzeń peryferyjnych robota |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.41. Przykład kodu ustawiania protokołu urządzeń peryferyjnych robota
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4protocol = 4096
5rtn = robot.SetExDevProtocol(protocol)
6print(f"SetExDevProtocol rtn:{rtn}")
7rtn, protocol = robot.GetExDevProtocol()
8print(f"GetExDevProtocol rtn:{rtn},protocol is:{protocol}")
9robot.CloseRPC()
11.42. Pobieranie parametrów komunikacji końcowej
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Pobieranie parametrów komunikacji końcowej |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.43. Ustawianie parametrów komunikacji końcowej
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Ustawianie parametrów komunikacji końcowej |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.44. Ustawianie typu transferu pliku końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Ustawianie typu transferu pliku końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.45. Ustawianie włączenia wykonania LUA końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Ustawianie włączenia wykonania LUA końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.46. Odnowienie błędu wyjątkowego pliku LUA końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Odnowienie błędu wyjątkowego pliku LUA końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.47. Pobieranie stanu włączenia wykonania LUA końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Pobieranie stanu włączenia wykonania LUA końcowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.48. Ustawianie typu włączenia urządzenia końcowego LUA
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Ustawianie typu włączenia urządzenia końcowego LUA |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.49. Pobieranie typu włączenia urządzenia końcowego LUA
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Pobieranie typu włączenia urządzenia końcowego LUA |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.50. Pobieranie aktualnie skonfigurowanego urządzenia końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Pobieranie aktualnie skonfigurowanego urządzenia końcowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.51. Ustawianie włączenia funkcji sterowania ruchem chwytaka
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Ustawianie włączenia funkcji sterowania ruchem chwytaka |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.52. Pobieranie włączenia funkcji sterowania ruchem chwytaka
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Pobieranie włączenia funkcji sterowania ruchem chwytaka |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.53. Zapis pliku węzła podrzędnego Ethercat robota
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Zapis pliku węzła podrzędnego Ethercat robota |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.54. Przesłanie pliku protokołu otwartego LUA końcowego
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Przesłanie pliku protokołu otwartego LUA końcowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.55. Wprowadzenie węzła podrzędnego Ethercat robota w tryb boot
Nowe w wersji python: SDK-v2.0.5
Prototyp |
|
|---|---|
Opis |
Wprowadzenie węzła podrzędnego Ethercat robota w tryb boot |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.56. Przykład kodu operacji na pliku LUA końcowego robota
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4robot.AxleLuaUpload("D://zUP/AXLE_LUA_End_DaHuan.lua")
5param = [7, 8, 1, 0, 5, 3, 1] # parametry odpowiadające AxleComParam
6robot.SetAxleCommunicationParam(7, 8, 1, 0, 5, 3, 1)
7error,getParam0,getParam1,getParam2,getParam3,getParam4,getParam5,getParam6 = robot.GetAxleCommunicationParam()
8print(f"GetAxleCommunicationParam param is:{getParam0} {getParam1} {getParam2} {getParam3} {getParam4} {getParam5} {getParam6}")
9robot.SetAxleLuaEnable(1)
10error,luaEnableStatus = robot.GetAxleLuaEnableStatus()
11robot.SetAxleLuaEnableDeviceType(0, 1, 0)
12error,forceEnable, gripperEnable, ioEnable = robot.GetAxleLuaEnableDeviceType()
13print(f"GetAxleLuaEnableDeviceType param is:{forceEnable} {gripperEnable} {ioEnable}")
14func = [1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1]
15robot.SetAxleLuaGripperFunc(1, func)
16error,getFunc = robot.GetAxleLuaGripperFunc(1)
17error,getforceEnable, getgripperEnable, getioEnable = robot.GetAxleLuaEnableDevice()
18print("\ngetforceEnable status:", end=" ")
19for i in range(8):
20 print(f"{getforceEnable[i]},", end="")
21print("\ngetgripperEnable status:", end=" ")
22for i in range(8):
23 print(f"{getgripperEnable[i]},", end="")
24print("\ngetioEnable status:", end=" ")
25for i in range(8):
26 print(f"{getioEnable[i]},", end="")
27print()
28robot.ActGripper(1, 0)
29time.sleep(2)
30robot.ActGripper(1, 1)
31time.sleep(2)
32robot.MoveGripper(1, 90, 10, 100, 50000, 0, 0, 0, 0, 0)
33while True:
34 error,pkg = robot.GetRobotRealTimeState()
35 print(f"gripper pos is:{pkg.gripper_position}")
36 time.sleep(0.1)
37robot.CloseRPC()
11.57. Pobieranie stanu przycisków SmartTool
Nowe w wersji python: SDK-v2.1.2
Prototyp |
|
|---|---|
Opis |
Pobieranie stanu przycisków SmartTool |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.58. Przykład kodu przycisków SmartTool
1from fairino import Robot
2import time
3# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
4robot = Robot.RPC('192.168.58.2')
5while True:
6 error,state = robot.GetSmarttoolBtnState()
7 print(f"{state:016b}")
8 time.sleep(0.1)
11.59. Ustawianie wykrywania siły obciążenia przed włączeniem przeciągania
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Ustawianie wykrywania siły obciążenia przed włączeniem przeciągania |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.60. Funkcja włączania/wyłączania urządzenia peryferyjnego laserowego
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Funkcja włączania/wyłączania urządzenia peryferyjnego laserowego |
Parametry wymagane |
|
Parametry domyślne |
|
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.61. Funkcja rozpoczęcia/zakończenia śledzenia laserowego
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Funkcja rozpoczęcia/zakończenia śledzenia laserowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.62. Poszukiwanie pozycji laserowej - stały kierunek
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Poszukiwanie pozycji laserowej - stały kierunek |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.63. Poszukiwanie pozycji laserowej - dowolny kierunek
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Poszukiwanie pozycji laserowej - dowolny kierunek |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.64. Konfiguracja IP lasera
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Konfiguracja IP lasera |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.65. Konfiguracja okresu próbkowania urządzenia peryferyjnego laserowego
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Konfiguracja okresu próbkowania urządzenia peryferyjnego laserowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.66. Ładowanie sterownika urządzenia peryferyjnego laserowego
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Ładowanie sterownika urządzenia peryferyjnego laserowego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.67. Rozładowanie sterownika urządzenia peryferyjnego laserowego
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Rozładowanie sterownika urządzenia peryferyjnego laserowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.68. Rejestracja ścieżki spoiny laserowej
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Rejestracja ścieżki spoiny laserowej |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.69. Odtwarzanie ścieżki spoiny laserowej
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Odtwarzanie ścieżki spoiny laserowej |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.70. Odtwarzanie śledzenia laserowego
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Odtwarzanie śledzenia laserowego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.71. Odtwarzanie ścieżki spoiny laserowej
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Odtwarzanie ścieżki spoiny laserowej |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.72. Ruch do początku zapisu ścieżki spoiny
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Ruch do początku zapisu ścieżki spoiny |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.73. Ruch do końca zapisu ścieżki spoiny
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Ruch do końca zapisu ścieżki spoiny |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.74. Ruch do punktu poszukiwanego przez czujnik laserowy
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Ruch do punktu poszukiwanego przez czujnik laserowy |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.75. Pobieranie informacji o współrzędnych punktu poszukiwanego przez czujnik laserowy
Nowe w wersji python: SDK-v2.1.6
Prototyp |
|
|---|---|
Opis |
Pobieranie informacji o współrzędnych punktu poszukiwanego przez czujnik laserowy |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.76. Przykład kodu konfiguracji parametrów i debugowania urządzenia peryferyjnego laserowego
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4robot.LaserTrackingSensorConfig("192.168.58.20", 5020)
5robot.LaserTrackingSensorSamplePeriod(20)
6robot.LoadPosSensorDriver(101)
7robot.LaserTrackingLaserOnOff(0, 0)
8time.sleep(3)
9robot.LaserTrackingLaserOnOff(1, 0)
10robot.CloseRPC()
11.77. Przykład kodu skanowania i odtwarzania ścieżki laserowej
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4robot.OpenLuaUpload("D://zUP/CtrlDev_laser_ruiniu-0117.lua")
5time.sleep(2)
6robot.SetCtrlOpenLUAName(0, "CtrlDev_laser_ruiniu-0117.lua")
7robot.UnloadCtrlOpenLUA(0)
8robot.LoadCtrlOpenLUA(0)
9time.sleep(8)
10i = 0
11while i<10:
12 startjointPos = [56.205, -117.951, 141.872, -118.149, -94.217, -122.176]
13 startdescPose = [-97.552, -282.855, 26.675, 174.182, -1.338, -91.707]
14 exaxisPos = [0.0] * 4
15 offdese = [0.0] * 6
16 robot.MoveL(desc_pos=startdescPose,tool= 1,user= 0,vel= 100,acc= 100,ovl= 100,blendR= -1,exaxis_pos= exaxisPos,search= 0,offset_flag= 0, offset_pos= offdese,overSpeedStrategy= 1,speedPercent= 1)
17 robot.LaserSensorRecord1(2, 10)
18 endjointPos = [68.809, -87.100, 121.120, -127.233, -95.038, -109.555]
19 enddescPose = [-103.555, -464.234, 13.076, 174.179, -1.344, -91.709]
20 robot.MoveL(desc_pos=enddescPose,tool= 1,user= 0,vel= 50,acc= 100,ovl= 100,blendR= -1,exaxis_pos= exaxisPos,search= 0,offset_flag= 0, offset_pos= offdese,overSpeedStrategy= 1,speedPercent= 1)
21 robot.LaserSensorRecord1(0, 10)
22 robot.MoveToLaserRecordStart(1, 30)
23 robot.LaserSensorReplay(10, 100)
24 robot.MoveLTR()
25 robot.LaserSensorRecord1(0, 10)
26 i = i+1
27robot.CloseRPC()
11.78. Przykład kodu poszukiwania pozycji laserowej i śledzenia w czasie rzeczywistym
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4robot.OpenLuaUpload("D://zUP/CtrlDev_laser_ruiniu-0117.lua")
5time.sleep(2)
6robot.SetCtrlOpenLUAName(0, "CtrlDev_laser_ruiniu-0117.lua")
7robot.UnloadCtrlOpenLUA(0)
8robot.LoadCtrlOpenLUA(0)
9time.sleep(8)
10time.sleep(8)
11i = 0
12while i < 10:
13 startjointPos = [56.205, -117.951, 141.872, -118.149, -94.217, -122.176]
14 startdescPose = [-97.552, -282.855, 26.675, 174.182, -1.338, -91.707]
15 exaxisPos = [0.0] * 4
16 offdese = [0.0] * 6
17 directionPoint = [0.0] * 3
18 robot.MoveL(desc_pos=startdescPose,tool= 1,user= 0,vel= 100,acc= 100,ovl= 100,blendR= -1,exaxis_pos= exaxisPos,search= 0,offset_flag= 0, offset_pos= offdese,overSpeedStrategy= 1,speedPercent= 1)
19 robot.LaserTrackingSearchStart_xyz(3, 100, 300, 1000, 3)
20 robot.LaserTrackingSearchStop()
21 robot.MoveToLaserSeamPos(1, 30, 0, 0, 0, offdese)
22 robot.LaserTrackingTrackOnOff(1, 3)
23 endjointPos = [68.809, -87.100, 121.120, -127.233, -95.038, -109.555]
24 enddescPose = [-103.555, -464.234, 13.076, 174.179, -1.344, -91.709]
25 robot.MoveL(desc_pos=enddescPose,tool= 1,user= 0,vel= 20,acc= 100,ovl= 100,blendR= -1,exaxis_pos= exaxisPos,search= 0,offset_flag= 0, offset_pos= offdese,overSpeedStrategy= 1,speedPercent= 1)
26 robot.LaserTrackingTrackOnOff(0, 3)
27 i = i + 1
28 print(i)
29robot.CloseRPC()
11.79. Przykład kodu śledzenia laserowego z osią rozszerzenia synchronicznie z robotem
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4startexaxisPos = [0.0, 0.0, 0.0, 0.0]
5seamexaxisPos = [-10.0, 0.0, 0.0, 0.0]
6endexaxisPos = [-30.0, 0.0, 0.0, 0.0]
7offdese = [0.0] * 6
8seamjointPos = [0.0] * 6
9seamdescPose = [0.0] * 6
10i=0
11while i < 10:
12 startjointPos = [58.337, -119.628, 146.037, -116.358, -92.224, -117.654]
13 startdescPose = [-53.375, -255.363, 0.919, 178.054, 1.077, -94.026]
14 robot.ExtAxisSyncMoveJ(joint_pos=startjointPos, tool=1,user= 0,vel= 100,acc= 100, ovl=100,exaxis_pos= startexaxisPos,blendT= -1,offset_flag= 0,offset_pos= offdese)
15 ret = robot.LaserTrackingSearchStart_xyz(3, 100, 300, 1000, 2)
16 robot.LaserTrackingSearchStop()
17 tool = 0
18 user = 0
19 rnte, seamjointPos, seamdescPose, tool, user, startexaxisPos = robot.GetLaserSeamPos(0, offdese)
20 print(f"{seamjointPos[0]},{seamjointPos[1]},{seamjointPos[2]},{seamjointPos[3]},{seamjointPos[4]},{seamjointPos[5]},{seamdescPose[0]},{seamdescPose[1]},{seamdescPose[2]},{seamdescPose[3]},{seamdescPose[4]},{seamdescPose[5]}")
21 if ret == 0:
22 robot.ExtAxisSyncMoveJ(joint_pos=seamjointPos, tool=1,user= 0,vel= 100,acc= 100, ovl=100,exaxis_pos= seamexaxisPos,blendT= -1,offset_flag= 0,offset_pos= offdese)
23 robot.LaserTrackingTrackOnOff(1, 2)
24 endjointPos = [70.580, -90.918, 126.593, -125.154, -92.162, -105.403]
25 enddescPose = [-53.375, -419.020, 0.920, 178.054, 1.076, -94.026]
26 robot.ExtAxisSyncMoveL(desc_pos=enddescPose, tool=1,user= 0,vel= 20,acc= 100, ovl=100,blendR= -1,exaxis_pos= endexaxisPos,offset_pos= offdese)
27 robot.LaserTrackingTrackOnOff(0, 2)
28 i = i+1
29 print(i)
30robot.CloseRPC()
11.80. Sterowanie matrycową przyssawką
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Sterowanie matrycową przyssawką |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.81. Pobieranie stanu matrycowej przyssawki
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Pobieranie stanu matrycowej przyssawki |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.82. Oczekiwanie na stan przyssawki
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Oczekiwanie na stan przyssawki |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.83. Przykład kodu instrukcji sterowania matrycową przyssawką
Nowe w wersji python: SDK-v2.1.5
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4robot.OpenLuaUpload("C://项目/外设SDK/CtrlDev_sucker.lua")
5time.sleep(2)
6robot.UnloadCtrlOpenLUA(1)
7robot.LoadCtrlOpenLUA(1)
8time.sleep(1)
9ctrl = bytearray(20)
10ctrl[0] = 1
11robot.SetSuckerCtrl(0, 1, ctrl)
12for i in range(100):
13 rtn, state, press_value, error = robot.GetSuckerState(1)
14 print(f"sucker1 state is {state}, pressValue is {press_value}, error num is {error}")
15 rtn, state, press_value, error = robot.GetSuckerState(12)
16 print(f"sucker12 state is {state}, pressValue is {press_value}, error num is {error}")
17 time.sleep(0.1)
18ret = robot.WaitSuckerState(1, 1, 100)
19print(f"WaitSuckerState result is {ret}")
20ctrl[0] = 3
21robot.SetSuckerCtrl(1, 1, ctrl)
22robot.SetSuckerCtrl(12, 1, ctrl)
23robot.CloseRPC()
11.84. Przesłanie pliku LUA protokołu otwartego
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Przesłanie pliku LUA protokołu otwartego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.85. Pobieranie parametrów karty węzła podrzędnego
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Pobieranie parametrów karty węzła podrzędnego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.86. Zapis DO węzła podrzędnego
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Zapis DO węzła podrzędnego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.87. Zapis AO węzła podrzędnego
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Zapis AO węzła podrzędnego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.88. Odczyt DI węzła podrzędnego
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Odczyt DI węzła podrzędnego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.89. Odczyt AI węzła podrzędnego
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Odczyt AI węzła podrzędnego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
|
11.90. Oczekiwanie na wejście rozszerzonego DI
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Oczekiwanie na wejście rozszerzonego DI |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.91. Oczekiwanie na wejście rozszerzonego AI
Nowe w wersji python: SDK-v2.1.5
Prototyp |
|
|---|---|
Opis |
Oczekiwanie na wejście rozszerzonego AI |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.92. Przykład kodu instrukcji interfejsów trybu węzła podrzędnego
Nowe w wersji python: SDK-v2.1.5
1from fairino import Robot
2# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
3robot = Robot.RPC('192.168.58.2')
4robot.OpenLuaUpload("D://zUP/外设/CtrlDev_field.lua")
5time.sleep(2)
6robot.SetCtrlOpenLUAName(3,"CtrlDev_field.lua")
7robot.UnloadCtrlOpenLUA(3)
8robot.LoadCtrlOpenLUA(3)
9time.sleep(8)
10rtn,type, version, conn_state = robot.GetFieldBusConfig()
11print(f"type is {type}, version is {version}, connState is {conn_state}")
12# Zapis wyjść cyfrowych
13ctrl = [1, 0, 1] # DO0=1, DO1=0, DO2=1
14robot.FieldBusSlaveWriteDO(0, 3, ctrl)
15# Zapis wyjścia analogowego
16ctrl_ao = [0x1000] # AO2 = 0x1000
17robot.FieldBusSlaveWriteAO(2, 1, ctrl_ao)
18for i in range(100):
19 rtn,di = robot.FieldBusSlaveReadDI(0, 4)
20 print(f"DI0 is {di[0]}, DI1 is {di[1]}, DI2 is {di[2]}, DI3 is {di[3]}")
21 rtn, ai = robot.FieldBusSlaveReadAI(0, 3)
22 print(f"AI0 is {ai[0]}, AI1 is {ai[1]}, AI2 is {ai[2]}")
23 time.sleep(0.01)
24ret = robot.FieldBusSlaveWaitDI(0, 1, 100)
25print(f"FieldBusSlaveWaitDI result is {ret}")
26ret = robot.FieldBusSlaveWaitAI(0, 0, 400.00, 100)
27print(f"FieldBusSlaveWaitAI result is {ret}")
28robot.CloseRPC()
11.93. Interfejs SDK włączania/wyłączania funkcji przezroczystej transmisji końcowej
Prototyp |
|
|---|---|
Opis |
Włączenie ogólnej funkcji przezroczystej transmisji końcowej |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.94. Interfejs SDK wysyłania i odbierania danych aperiodycznych funkcji przezroczystej transmisji końcowej
Prototyp |
|
|---|---|
Opis |
Wysłanie danych aperiodycznych przez końcówkę i oczekiwanie na odpowiedź |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.95. Przykład kodu komunikacji danych aperiodycznych głowicy moxibuscyjnej Beiyikang w oparciu o funkcję przezroczystej transmisji końcowej
1from time import sleep
2from fairino import Robot
3from ctypes import sizeof
4# Połączenie z kontrolerem robota, po pomyślnym połączeniu zwraca obiekt robota
5robot = Robot.RPC('192.168.58.2')
6
7import time
8
9
10def testAxleGenCom(self):
11
12 led_on = [0xAB, 0xBA, 0x12, 0x01, 0x01, 0x79]
13 led_off = [0xAB, 0xBA, 0x12, 0x01, 0x00, 0x78]
14 version = [0xAB, 0xBA, 0x11, 0x00, 0x76]
15 state = [0xAB, 0xBA, 0x1B, 0x01, 0xAA, 0x2B]
16 cycleState = [0xAB, 0xBA, 0x12, 0x01, 0x00, 0x78]
17 cnt = 1
18
19 p1Joint = [88.708, -86.178, 140.989, -141.825, -89.162, -49.879]
20 p1Desc = [188.007, -377.850, 260.207, 178.715, 2.823, -131.466]
21 p2Joint = [112.131, -75.554, 126.989, -139.027, -88.044, -26.477]
22 p2Desc = [368.003, -377.848, 260.211, 178.715, 2.823, -131.465]
23
24 exaxisPos = [0, 0, 0, 0]
25 offdese = [0, 0, 0, 0, 0, 0]
26
27 # Włączenie funkcji przezroczystej transmisji końcowej
28 robot.SetAxleGenComEnable(1)
29 robot.SetAxleLuaEnable(1)
30
31 while cnt <= 10000:
32 # Odczyt numeru wersji
33 ret,rcvdata = robot.SndRcvAxleGenComCmdData(len_snd=5, sndBuff=version, len_rcv=10)
34 print(ret)
35 print(rcvdata)
36 print(f"hard version : {rcvdata[4]},hard code:{rcvdata[5]}, soft version:{rcvdata[6]} {rcvdata[7]}, soft code:{rcvdata[8]}")
37 if ret != 0:
38 break
39 time.sleep(1)
40 # Odczyt stanu obecności głowicy moxibuscyjnej
41 ret,rcvdata = robot.SndRcvAxleGenComCmdData(6, state, 6)
42 print(f"state : {rcvdata[4]} ")
43 time.sleep(1)
44 # Włączenie lasera głowicy moxibuscyjnej
45 ret,rcvdata = robot.SndRcvAxleGenComCmdData(6, led_on, 6)
46 print(f"led on rcv data is: {rcvdata[0]}, {rcvdata[1]}, {rcvdata[2]}, {rcvdata[3]}, {rcvdata[4]}, {rcvdata[5]}")
47 robot.MoveJ(joint_pos=p1Joint, tool=0, user=0, vel=100, acc=100, ovl=100, exaxis_pos=exaxisPos, blendT=-1,
48 offset_flag=0, offset_pos=offdese)
49 time.sleep(4)
50 # Wyłączenie lasera głowicy moxibuscyjnej
51 ret, rcvdata = robot.SndRcvAxleGenComCmdData(6, led_off, 6)
52 print(f"led off rcv data is: {rcvdata[0]}, {rcvdata[1]}, {rcvdata[2]}, {rcvdata[3]}, {rcvdata[4]}, {rcvdata[5]}")
53 robot.MoveJ(joint_pos=p2Joint, tool=0, user=0, vel=100, acc=100, ovl=100, exaxis_pos=exaxisPos, blendT=-1,offset_flag=0, offset_pos=offdese)
54 time.sleep(1)
55 print(f"***********************complate No. {cnt} SDK test*****************************")
56 cnt = cnt + 1
57
58 robot.CloseRPC()
59 return 0
60
61testAxleGenCom(robot)
11.96. Pobranie pliku LUA protokołu otwartego
Prototyp |
|
|---|---|
Opis |
Pobranie pliku LUA protokołu otwartego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.97. Usunięcie określonego pliku LUA protokołu otwartego
Prototyp |
|
|---|---|
Opis |
Usunięcie określonego pliku LUA protokołu otwartego |
Parametry wymagane |
|
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.98. Usunięcie wszystkich plików LUA protokołu otwartego
Prototyp |
|
|---|---|
Opis |
Usunięcie wszystkich plików LUA protokołu otwartego |
Parametry wymagane |
Brak |
Parametry domyślne |
Brak |
Wartość zwracana |
Kod błędu sukces-0 błąd- errcode |
11.99. Przykład kodu SDK operacji na pliku lua protokołu otwartego
1from time import sleep
2import time
3from fairino import Robot
4
5# Połączenie z kontrolerem robota
6robot = Robot.RPC('192.168.58.2')
7
8
9def TestCtrlOpenLuaOperate(self):
10 # Przesłanie pliku Lua do robota
11 rtn = robot.OpenLuaUpload("D://zUP/openlua/CtrlDev_WELDING_A.lua")
12 print(f"OpenLuaUpload rtn is {rtn}")
13
14 rtn = robot.OpenLuaUpload("D://zUP/openlua/CtrlDev_SWDPOLISH.lua")
15 print(f"OpenLuaUpload rtn is {rtn}")
16
17 # Pobranie pliku Lua z robota
18 rtn = robot.OpenLuaDownload("CtrlDev_WELDING_A.lua", "D://zDOWN/")
19 print(f"OpenLuaDownload rtn is {rtn}")
20
21 rtn = robot.OpenLuaDownload("CtrlDev_SWDPOLISH.lua", "D://zDOWN/")
22 print(f"OpenLuaDownload rtn is {rtn}")
23
24 # Ustawienie nazwy pliku Lua otwartego sterowania
25 rtn = robot.SetCtrlOpenLUAName(0, "CtrlDev_WELDING_A.lua")
26 print(f"SetCtrlOpenLUAName rtn is {rtn}")
27
28 rtn = robot.SetCtrlOpenLUAName(1, "CtrlDev_SWDPOLISH.lua")
29 print(f"SetCtrlOpenLUAName rtn is {rtn}")
30
31 # Pobranie nazwy pliku Lua otwartego sterowania
32 rtn, name = robot.GetCtrlOpenLUAName()
33 print(f"ctrl open lua names : {name[0]}, {name[1]}, {name[2]}, {name[3]}")
34
35 # Załadowanie Lua otwartego sterowania
36 rtn = robot.LoadCtrlOpenLUA(1)
37 print(f"LoadCtrlOpenLUA rtn is {rtn}")
38 time.sleep(2)
39
40 # Rozładowanie Lua otwartego sterowania
41 rtn = robot.UnloadCtrlOpenLUA(1)
42 print(f"UnloadCtrlOpenLUA rtn is {rtn}")
43
44 # Usunięcie określonego pliku Lua
45 rtn = robot.OpenLuaDelete("CtrlDev_WELDING_A.lua")
46 print(f"OpenLuaDelete rtn is {rtn}")
47
48 # Usunięcie wszystkich plików Lua
49 rtn = robot.AllOpenLuaDelete()
50 print(f"AllOpenLuaDelete rtn is {rtn}")
51
52 # Zamknięcie połączenia
53 robot.CloseRPC()
54 time.sleep(1)
55
56
57# Wywołanie funkcji testowej
58TestCtrlOpenLuaOperate(robot)