더 많은 특성 및 핸들러 추가

기기 모델에 특성을 원하는 만큼 추가할 수 있습니다. 이러한 특성은 한 가지 기기 유형에만 국한된 것이 아니며, 원하는 대로 사용할 수 있습니다.

다음은 트레잇을 추가하고 수신 명령어를 처리하는 프로세스입니다.

  1. 추가할 트레잇을 결정합니다.

  2. pushtotalk.py 파일을 엽니다.

    cd assistant-sdk-python/google-assistant-sdk/googlesamples/assistant/grpc
    nano pushtotalk.py
  3. action.devices.commands.OnOff 명령어를 처리하는 기존 코드 블록 아래에 다음 코드 블록을 추가합니다 (기존 코드 블록을 삭제하지 않음).

    @device_handler.command('action.devices.commands.command-name')
    def my-function(parameter-name):
        if conditional:
            logging.info('Something happened.')
        else:
            logging.info('Something else happened.')
    
  4. 위 코드 블록에서 각 변수에 필요한 정보를 찾습니다.

    command-name1단계의 특정 trait 페이지로 이동합니다 (예: ColorTemperature). 기기 명령어 표의 명령어를 사용합니다.
    my-function핸들러 함수의 이름을 원하는 대로 지정합니다.
    parameter-nametrait 페이지에서 기기 명령어 표를 다시 살펴보세요. 각 명령어에는 하나 이상의 매개변수가 연결되어 있습니다. 이는 EXECUTE 요청 JSON의 "params" 아래에 나열됩니다. 정확한 매개변수 이름을 사용합니다. 이러한 매개변수 중 일부는 다른 매개변수를 포함하는 객체입니다. 최상위 객체만 사용하세요.
    conditional핸들러 코드에서 조건부를 반드시 사용할 필요는 없지만 기기에서 명령어를 실행하는 방법을 차별화하는 데 도움이 될 수 있습니다.

    다음은 특성 밝기ColorTemperature에 관한 몇 가지 예입니다.

    @device_handler.command('action.devices.commands.BrightnessAbsolute')
    def brightnessCheck(brightness):
        if brightness > 50:
            logging.info('brightness > 50')
        else:
            logging.info('brightness <= 50')
    
    @device_handler.command('action.devices.commands.ColorAbsolute')
    def color(color):
        if color.get('name') == "blue":
            logging.info('color is blue')
        else:
            logging.info('color is not blue')
    
  5. 1단계에서 추가한 특성으로 기기 모델을 업데이트합니다.

  6. 수정된 소스 코드를 실행합니다.

    cd assistant-sdk-python/google-assistant-sdk/googlesamples/assistant/grpc
    python pushtotalk.py
  7. Enter 키를 누르고 쿼리해 보세요.

    예를 들면 다음과 같습니다.

    밝기 65%로 설정해 줘.

    파란색으로 표시합니다.

다음 단계

맞춤 기기 작업 등록