한국어
Qt
 

Qt 로 작성된 iOS 에서 앱이 외부장치와 Serial 통신을 해본다.

 

일반적으로 크로스 플랫폼 프레임워크 애플리케이션은 iOS에서 외부장치와 시리얼 통신이 불가능하다. Apple 디바이스에서는 Apple에서 인증하고 MFi 배지가 있는 액세서리만 사용하고 독점 프로토콜(iAP2)과 소프트웨어로만 작동되게 했기 때문이다.

 

Redpark 의 Lightning Serial Cable은 RS-232 통신이 가능한 애플의 MFi 액세서리중 하나다. 함께 제공되는 SDK(라이브러리)는 External Accessory Framework의 관련된 세부 구현을 추상화하고 단순화하여 쉽게 앱을 개발할 수 있게 해준다. 따라서 Redpark 시리얼 케이블을 iPhone에 연결하고 Qt/C++로 작성하는 애플리케이션에서 Redpark 라이브러리를 링크하여 최대 115.2Kbps의 전송 속도로 다른 직렬 장치에 연결할 수 있다.

 

시리얼 케이블 구매와 SDK 및 샘플 프로젝트는 Redpark 웹사이트에서 얻을 수 있다. SDK는 Objective-C를 위해서도 제공되며 Objective-C코드에서 우리의 C++ 코드를 혼합할 수 있다. qmake는 “mm” 확장자를 컴파일러에게 이것이 Objective-C++ 파일임을 알려준다.

QMAKE_LFLAGS += -ObjC


....
OBJECTIVE_HEADERS += \
    IOSSerialPort.h \
...


OBJECTIVE_SOURCES += \
    ios/IOSSerialPort.mm \
...


기본적인 iOS 용 Qt 앱을 구축하는 방법에 대해서 다음 블로그를 참고하면 많은 도움이 된다.
https://appbus.wordpress.com/

 

테스트를 위해 아주 단순한 사용자 인터페이스를 구현한다.

스크린샷, 2022-04-29 오후 6.17.41.png

 

main.qml

import QtQuick 2.12
import QtQuick.Window 2.12
import QtQuick.Controls 2.12

Window {
    width: 640
    height: 480
    visible: true
    title: qsTr("Hello World")

    Connections {
        target: serial

        function onDebugMessage(message){
            info.append(message)
        }
    }

    Rectangle {
        anchors.fill: parent

        TextEdit {
            id: info
            anchors.top: parent.top
            anchors.topMargin: 20
            anchors.left: parent.left
            anchors.right: parent.right

            horizontalAlignment: Text.AlignLeft

            font.pixelSize: 20
        }

        Column {
            anchors.horizontalCenter: parent.horizontalCenter
            anchors.bottom: parent.bottom
            anchors.bottomMargin: 15
            spacing: 10

            Button{
                width: 200
                height: 50
                anchors.horizontalCenter: parent.horizontalCenter

                text: "Open"

                onClicked: {
                    serial.open()
                }
            }

            Button{
                width: 200
                height: 50
                anchors.horizontalCenter: parent.horizontalCenter

                text: "Send"

                onClicked: {
                    serial.send("Hello Makersweb.net")
                }
            }
        }
    }
}


serial 인스턴스의 클래스 구현은 Redpark 의 샘플 프로젝트 코드에서 많은 부분을 사용하며 실제 sendData 및 recvData를 호출하여 시리얼 포트를 통해 바이트를 보내거나 받을 수 있다.

#include "Serialdevice.h"
#include "IOSSerialPort.h"

#include <QDebug>

SerialDevice::SerialDevice(QObject *parent)
    : QObject{parent}
    , backend(new IOSSerialPort())
{
    connect(backend, &IOSSerialPort::receivedMessage, this, [&](QString msg){
        emit debugMessage(msg);
    });
}

SerialDevice::~SerialDevice()
{
    if(backend){
        backend->close();
        delete backend;
        backend = nullptr;
    }
}

void SerialDevice::open()
{
    backend->open();
}

void SerialDevice::send(const QString &text)
{
    if(text.isEmpty())
        return;

    backend->sendMessage(text);
}

 

데이터를 수신하면 바이트를 화면에 표시한다. Send 버튼을 누르면 문자열을 송신한다.

스크린샷, 2022-04-29 오후 6.18.39.png

 

Windows 터미널 에뮬레이터 측

rs232.png

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 85343
156 단일 인스턴스 Qt 응용 프로그램(Single-instance Application) makersweb 2022.06.23 693
» Qt로 작성된 iOS 앱에서 시리얼 통신 file makersweb 2022.04.30 807
154 VirtualKeyboard 스타일 커스터 마이징 makersweb 2022.03.13 448
153 성능 고려 및 제안 사항 makersweb 2022.03.07 493
152 Binding 타입으로 객체 속성 간 묶기 makersweb 2022.03.04 404
151 Qt Bluetooth Low Energy 개요 makersweb 2022.02.13 650
150 Qt Android 앱에 AdMob 배너달기 file makersweb 2021.12.04 385
149 Qt 6의 C++ 프로퍼티 바인딩 예제 makersweb 2021.11.01 845
148 QML에서 앵커(anchors)로 위치 지정 file makersweb 2021.10.05 3700
147 안드로이드용 Qt 6.2 makersweb 2021.10.02 490
146 Qt 응용프로그램에서 PDF 문서 렌더링 file makersweb 2021.09.23 652
145 QML에서 Websocket 서버와 통신 file makersweb 2021.09.18 806
144 QML 코딩 규칙 makersweb 2021.09.05 3174
143 QML 에서 QR코드 생성 file makersweb 2021.08.20 882
142 앱을 종료할 때 QML 바인딩 오류를 피하는 방법 makersweb 2021.08.08 487
141 Qt 응용프로그램에서 Lottie Animation사용 file makersweb 2021.05.30 867
140 싱글 샷(Single-Shot) 시그널/슬롯 연결 makersweb 2021.05.12 740
139 응용프로그램 자동실행 설정 (on Windows) makersweb 2021.05.08 555
138 Qt 6 에서 프로퍼티 바인딩 makersweb 2021.04.03 761
137 QML과 JavaScript 의 숫자 관련 내장된 함수 makersweb 2021.03.28 1352