Перейти к основному содержимому

RI_SDK_connector_i2c_State

Информация

RI_SDK - библиотека Robo Intellect Software Development Kit
connector - название группы устройств коннекторов
i2c - название устройства i2c адаптера
State - название метода получения состояния i2c адаптера

Сигнатура функции

RI_SDK_connector_i2c_State(descriptor, state, errorText):errorCode

Описание метода

Чтение состояния адаптера.

Записывает константу состояния i2c адаптера с дескриптором descriptor в параметр state

Состояние I2C соединения:

  • 0 - Линия свободна - означает, что в данный момент времени не выполняется никакая функция чтения/записи с данного i2c адаптера.
  • 1 - Линия занята. Означает, что уже выполняется какая-либо функция чтения/записи для данного i2c адаптера.

Если линия у какого-либо i2c адаптера занята, то при выполнении функций чтения/записи для данного i2c адаптера программа будет ожидать, пока линия освободится.

Параметры и возвращаемые значения

ПараметрТип для Shared objectТип для Golang gRPCОписание
descriptorint (тип C)int64Дескриптор компонента
state*int (тип C)int64Указатель на код состояния i2c адаптера
errorTextchar[1000] (тип C)stringТекст ошибки (передается как параметр, если происходит ошибка метод записывает в этот параметр текст ошибки)
errorCodeint (тип C)int64Код ошибки

Примеры

Пример №1 - Чтение состояния у i2c адаптера

В данном примере в переменную state записывается состояние компонента i2c адаптера с дескриптором, записанным в переменную descriptor, и последующий вывод значения переменной state.

# Получение состояния i2c адаптера
errCode = lib.RI_SDK_connector_i2c_State(descriptor, state, errTextC)
if errCode != 0:
print(errCode, errTextC.raw.decode())
sys.exit(2)

print("state: ", state.value)

Полный текст примера


from ctypes.util import find_library
import platform
import sys
from ctypes import *

# Подключаем внешнюю библиотеку для работы с SDK
platform = platform.system()
if platform == "Windows":
libName = "librisdk.dll"
if platform == "Linux":
libName = "librisdk.so"

pathLib = find_library(libName)
lib = cdll.LoadLibrary(pathLib)


# Указываем типы аргументов для функций библиотеки RI_SDK
lib.RI_SDK_InitSDK.argtypes = [c_int, c_char_p]
lib.RI_SDK_CreateModelComponent.argtypes = [c_char_p, c_char_p, c_char_p, POINTER(c_int), c_char_p]
lib.RI_SDK_connector_i2c_State.argtypes = [c_int, POINTER(c_int), c_char_p]

def main():
errTextC = create_string_buffer(1000) # Текст ошибки. C type: char*
descriptor = c_int()
state = c_int()

# Инициализация библиотеки RI SDK с уровнем логирования 3
errCode = lib.RI_SDK_InitSDK(3, errTextC)
if errCode != 0:
print(errCode, errTextC.raw.decode())
sys.exit(2)

# Создание компонента i2c адаптера модели ch341
errCode = lib.RI_SDK_CreateModelComponent("connector".encode(), "i2c_adapter".encode(), "ch341".encode(), descriptor, errTextC)
if errCode != 0:
print(errCode, errTextC.raw.decode())
sys.exit(2)

print("descriptor: ", descriptor.value)

# Получение состояния i2c адаптера
errCode = lib.RI_SDK_connector_i2c_State(descriptor, state, errTextC)
if errCode != 0:
print(errCode, errTextC.raw.decode())
sys.exit(2)

print("state: ", state.value)


print("Success")

main()