한국어
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
176 클라우드용 Qt file makersweb 2024.01.16 434
175 QRhi 에 대해서 file makersweb 2023.12.29 412
174 Android 애플리케이션 서명 구성 file makersweb 2023.12.17 374
173 QML의 사용자 정의 Image makersweb 2023.09.17 423
172 Base64로 인코딩된 파일을 복원 makersweb 2023.08.06 336
171 QML에서 D-Bus 통신 file makersweb 2023.03.15 546
170 Qt 하이브리드 애플리케이션(Hybrid App) 개발 file makersweb 2023.02.08 752
169 Widgets(C++) 기반의 기본 스타일을 Dark 테마 및 Material 디자인 스타일로 바꾸기 file makersweb 2023.01.28 1005
168 OpacityMask 예제 file makersweb 2023.01.26 456
167 QProcess 예제 (프로그램 재시작) file makersweb 2023.01.25 662
166 하드디스크 드라이브 여유 공간 계산 file makersweb 2023.01.15 398
165 Qt Property(속성) 시스템 makersweb 2023.01.08 1526
164 VTK 를 사용해서 강력한 시각화(3D, Plotting, Chart)Qt 응용프로그램 개발하기 file makersweb 2022.10.16 1463
163 QProcess 보안 권고 리뷰 file makersweb 2022.09.18 510
162 QMake 프로젝트를 CMake 프로젝트로 변환 with qmake2cmake makersweb 2022.09.17 937
161 Qt Safe Renderer 개요 file makersweb 2022.09.08 468
160 clazy 로 13개의 시그널, 슬롯 오류 해결 makersweb 2022.08.23 522
159 Qt 스마트 포인터 (QSharedPointer, QScopedPointer, QPointer) makersweb 2022.08.18 1041
158 Qt 6.4에 추가될 Qt Quick 3D Physics file makersweb 2022.08.07 330
157 HTTPS URL을 연결할 때 SslHandshakeFailedError 오류 makersweb 2022.07.31 340