RI_SDK_exec_RServoDrive_ExtendToModel

!!! ИНФОРМАЦИЯ

RI_SDK - библиотека Robo Intellect Software Development Kit

exec - название группы устройств исполнителей

RServoDrive - название устройства сервопривода вращения

Extend - название метода расширения компонента сервопривода до конкретной модели

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

  • Shared object
RI_SDK_exec_RServoDrive_ExtendToModel(base, descriptor, modelName, errorText):errorCode
  • Golang gRPC
RI_SDK_Exec_RServoDrive_ExtendToModel(baseDescriptor int64, modelName string) (descriptor int64, errorText string, errorCode int64, err error)

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

Расширение сервопривода вращения до модели.

Расширяет компонент устройства сервопривода вращения с дескриптором base. Записывает в параметр descriptor дескриптор нового компонента (компонент конкретной модели сервопривода вращения)

Доступные модели сервопривода: mg996r

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

Параметр Тип для Shared object Тип для Golang gRPC Описание
baseDescriptor int (тип C) int64 Дескриптор компонента сервопривода вращения, который будет расширятся
modelName char[] (тип C) string Модель компонента ("mg996r")
descriptor *int (тип C) int64 Указатель на компонент сервопривода вращения конкретной модели, который получится в результате расширения
errorText char[1000] (тип C) string Текст ошибки (передается как параметр, если происходит ошибка метод записывает в этот параметр текст ошибки)
errorCode int (тип C) int64 Код ошибки

Примеры #

Пример №1 - Расширение компонента сервопривода вращения до модели mg996r #

В данном примере осуществляется расширение сервопривода вращения с дескриптором, записанным в переменную rservo и вывод дескриптора нового компонента устройства сервопривода модели mg996r, который получится в результате расширения.

  • Python
# Расширение компонента сервопривода вращения до модели mg996r
errCode = lib.RI_SDK_exec_RServoDrive_ExtendToModel(rservo, "mg996r".encode(),  descriptor, errTextC)
if errCode != 0:
    print(errCode, errTextC.raw.decode())
    sys.exit(2)

print("descriptor: ", descriptor.value)
    
  • C
// Расширение компонента сервопривода вращения до модели mg996r
errCode = RI_SDK_exec_RServoDrive_ExtendToModel(rservo, "mg996r", &descriptor, errorText);
if (errCode != 0) {
    printf("errorText:%s\n", errorText);
    return errCode;
}

printf("descriptor: %d\n", descriptor);
  • C++
// Расширение компонента сервопривода вращения до модели mg996r
char servoModel[] = "mg996r";
errCode = RI_SDK_exec_RServoDrive_ExtendToModel(rservo, servoModel, &descriptor, errorText);
if (errCode != 0) {
    printf("errorText:%s\n", errorText);
    return errCode;
}

printf("descriptor: %d\n", descriptor);
  • Golang
// Расширение компонента сервопривода вращения до модели mg996r
errCode = C.RI_SDK_exec_RServoDrive_ExtendToModel(rservo, C.CString("mg996r"), &descriptor, &errorTextC[0])
if errCode != 0 {
  fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorTextC[0]))
  return
}

fmt.Println("descriptor: ", descriptor)
  • Golang gRPC
// Расширение компонента сервопривода вращения до модели mg996r
descriptor, errorText, errCode, err = client.RoboSdkApi.RI_SDK_Exec_RServoDrive_ExtendToModel(rservo, "mg996r")
if err != nil {
  fmt.Printf("gRPC Error: %v\n", err)
  return
}
if errCode != 0 {
  fmt.Printf("errorCode:%d - errorText:%s\n", errCode, errorText)
  return
}

fmt.Println("descriptor: ", descriptor)
  • PHP
// Расширение компонента сервопривода вращения до модели mg996r
$errCode = $ffi->RI_SDK_exec_RServoDrive_ExtendToModel($rservo->cdata, "mg996r", FFI::addr($descriptor), $errorText);
if ($errCode) {
    print("errorText:" . FFI::string($errorText). " errCode: " . $errCode . " \n");
    return $errCode;
}

print("descriptor: " . $descriptor->cdata . "\n");
Полный текст примера
  • Python

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_CreateDeviceComponent.argtypes = [c_char_p, c_char_p, POINTER(c_int), c_char_p]
lib.RI_SDK_exec_RServoDrive_ExtendToModel.argtypes = [c_int, c_char_p, POINTER(c_int), c_char_p]

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

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

    # Создание компонента сервопривода вращения
    errCode = lib.RI_SDK_CreateDeviceComponent("executor".encode(), "servodrive_rotate".encode(),  rservo, errTextC)
    if errCode != 0:
        print(errCode, errTextC.raw.decode())
        sys.exit(2)

    print("servodrive rotate: ", rservo.value)

    # Расширение компонента сервопривода вращения до модели mg996r
    errCode = lib.RI_SDK_exec_RServoDrive_ExtendToModel(rservo, "mg996r".encode(),  descriptor, errTextC)
    if errCode != 0:
        print(errCode, errTextC.raw.decode())
        sys.exit(2)

    print("descriptor: ", descriptor.value)

    print("Success")

main()
 
 
  • C
#include "./librisdk.h" // Подключение библиотеки

int main(){
    char errorText[1000]; // текст ошибки. Передается как входной параметр,при возникновении ошибки в эту переменную будет записан текст ошибки
    int errCode; //код ошибки
    int rservo;
    int descriptor;

    // Инициализация библиотеки RI SDK с уровнем логирования 3
    errCode = RI_SDK_InitSDK(3, errorText);
    if (errCode != 0) {
        printf("errorText:%s\n", errorText);
        return errCode;
    }

    // Создание компонента сервопривода вращения
    errCode = RI_SDK_CreateDeviceComponent("executor", "servodrive_rotate", &rservo, errorText);
    if (errCode != 0) {
        printf("errorText:%s\n", errorText);
        return errCode;
    }

    printf("servodrive rotate: %d\n", rservo);

    // Расширение компонента сервопривода вращения до модели mg996r
    errCode = RI_SDK_exec_RServoDrive_ExtendToModel(rservo, "mg996r", &descriptor, errorText);
    if (errCode != 0) {
        printf("errorText:%s\n", errorText);
        return errCode;
    }

    printf("descriptor: %d\n", descriptor);

    printf("Success");
    return 0;
}
  • C++
#include <stdbool.h>
#include "./librisdk.h" // Подключение библиотеки

int main(){
    char errorText[1000]; // текст ошибки. Передается как входной параметр,при возникновении ошибки в эту переменную будет записан текст ошибки
    int errCode; //код ошибки
    int rservo;
    int descriptor;

    // Инициализация библиотеки RI SDK с уровнем логирования 3
    errCode = RI_SDK_InitSDK(3, errorText);
    if (errCode != 0) {
        printf("errorText:%s\n", errorText);
        return errCode;
    }

    // Создание компонента сервопривода вращения
    char servoGroup[] = "executor";
    char servoDevice[] = "servodrive_rotate";
    errCode = RI_SDK_CreateDeviceComponent(servoGroup, servoDevice, &rservo, errorText);
    if (errCode != 0) {
        printf("errorText:%s\n", errorText);
        return errCode;
    }

    printf("servodrive rotate: %d\n", rservo);

    // Расширение компонента сервопривода вращения до модели mg996r
    char servoModel[] = "mg996r";
    errCode = RI_SDK_exec_RServoDrive_ExtendToModel(rservo, servoModel, &descriptor, errorText);
    if (errCode != 0) {
        printf("errorText:%s\n", errorText);
        return errCode;
    }

    printf("descriptor: %d\n", descriptor);

    printf("Success");
    return 0;
}
  • Golang
package main

/*
#cgo CFLAGS: -I.
#cgo LDFLAGS: -L. -lrisdk
#include <librisdk.h> // Подключаем внешнюю библиотеку для работы с SDK.
*/
import "C"
import "fmt"

var (
    errorTextC [1000]C.char // Текст ошибки. C type: char*
    errCode    C.int        // Код ошибки. C type: int
    rservo     C.int
    descriptor C.int
)

func main() {

    // Инициализация библиотеки RI SDK с уровнем логирования 3
    errCode = C.RI_SDK_InitSDK(3, &errorTextC[0])
    if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorTextC[0]))
        return
    }

    // Создание компонента сервопривода вращения
    errCode = C.RI_SDK_CreateDeviceComponent(C.CString("executor"), C.CString("servodrive_rotate"), &rservo, &errorTextC[0])
    if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorTextC[0]))
        return
    }

    fmt.Println("servodrive rotate: ", rservo)

    // Расширение компонента сервопривода вращения до модели mg996r
    errCode = C.RI_SDK_exec_RServoDrive_ExtendToModel(rservo, C.CString("mg996r"), &descriptor, &errorTextC[0])
    if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, C.GoString(&errorTextC[0]))
        return
    }

    fmt.Println("descriptor: ", descriptor)

    fmt.Println("Success")

}
  • Golang gRPC
package main

import (
    "fmt"

    "github.com/rbs-ri/go-risdk"
)

var (
    client     *risdk.ClientRPC // Объект взяимодействия с API SDK
    errorText  string           // Текст ошибки
    errCode    int64            // Код ошибки
    err        error            // Ошибка gRPC
    rservo     int64
    descriptor int64
)

func main() {

    // Открываем соединение для работы с API SDK по RPC
    client = risdk.GetClientRPC()

    // Закрываем соединение с RPC
    defer client.Client.Kill()

    // Инициализация библиотеки RI SDK с уровнем логирования 3
    errorText, errCode, err = client.RoboSdkApi.RI_SDK_InitSDK(3)
    if err != nil {
        fmt.Printf("gRPC Error: %v\n", err)
        return
    }
    if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, errorText)
        return
    }

    // Создание компонента сервопривода вращения
    rservo, errorText, errCode, err = client.RoboSdkApi.RI_SDK_CreateDeviceComponent("executor", "servodrive_rotate")
    if err != nil {
        fmt.Printf("gRPC Error: %v\n", err)
        return
    }
    if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, errorText)
        return
    }

    fmt.Println("servodrive rotate: ", rservo)

    // Расширение компонента сервопривода вращения до модели mg996r
    descriptor, errorText, errCode, err = client.RoboSdkApi.RI_SDK_Exec_RServoDrive_ExtendToModel(rservo, "mg996r")
    if err != nil {
        fmt.Printf("gRPC Error: %v\n", err)
        return
    }
    if errCode != 0 {
        fmt.Printf("errorCode:%d - errorText:%s\n", errCode, errorText)
        return
    }

    fmt.Println("descriptor: ", descriptor)

    fmt.Println("Success")

}
  • PHP
<?php
// Подключаем внешнюю библиотеку для работы с SDK
$RELATIVE_PATH = '';
$headers = file_get_contents(__DIR__ . $RELATIVE_PATH . '/librisdk.h');
$headers = preg_replace(['/#ifdef __cplusplus\s*extern "C" {\s*#endif/i', '/#ifdef __cplusplus\s*}\s*#endif/i'], '', $headers);
$ffi = FFI::cdef($headers, __DIR__ . $RELATIVE_PATH . '/librisdk.dll');

$errorText = $ffi->new('char[1000]', 0); // Текст ошибки. Передается как входной параметр,при возникновении ошибки в эту переменную будет записан текст ошибки
$rservo = $ffi->new('int', 0);
$descriptor = $ffi->new('int', 0);

// Инициализация библиотеки RI SDK с уровнем логирования 3
$errCode = $ffi->RI_SDK_InitSDK(3, $errorText);
if ($errCode) {
    print("errorText:" . FFI::string($errorText) . " errCode: " . $errCode . " \n");
    return $errCode;
}

// Создание компонента группы исполнителей
$errCode = $ffi->RI_SDK_CreateDeviceComponent("executor", "servodrive_rotate", FFI::addr($rservo), $errorText);
if ($errCode) {
    print("errorText:" . FFI::string($errorText). " errCode: " . $errCode . " \n");
    return $errCode;
}

print("servodrive rotate: " . $rservo->cdata . "\n");

// Расширение компонента сервопривода вращения до модели mg996r
$errCode = $ffi->RI_SDK_exec_RServoDrive_ExtendToModel($rservo->cdata, "mg996r", FFI::addr($descriptor), $errorText);
if ($errCode) {
    print("errorText:" . FFI::string($errorText). " errCode: " . $errCode . " \n");
    return $errCode;
}

print("descriptor: " . $descriptor->cdata . "\n");

print("Success \n");
?>

198 просмотров0 комментариев

Комментарии (0)

Для участия в обсуждении Вы должны быть авторизованным пользователем
Разделы

Навигация

ВойтиРегистрация