© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB

Qt Cloud Messaging API доступен для встраиваемых систем

Cloud, Messaging, QML

Проблемы с облачными сообщениями для встраиваемых устройств вдохновили команды Kaltiot & SnowGrains на создание кросс-платформенного Qt API, который позволяет легко отправлять сообщения с встраиваемых устройств. API называется Qt Cloud Messaging API , и он построен с гибкостью и расширяемостью.

Мы также решили нацелиться на другие области Qt и сделать API легко расширяемым для любого поставщика услуг, а не только для встраиваемых. Это позволяет разработчикам использовать тот же API для разработки мобильных и настольных приложений.

В настоящее время существует огромное количество поставщиков push-сообщений для мобильных и веб разработок. Тем не менее, в таких отраслях, как автоматизация, автомобилестроение, робототехника и в других встраиваемых устройствах, на самом деле нет поставщиков услуг такого типа. Потребность растет быстрыми темпами, поскольку встраиваемые и IoT устройства все больше и больше отправляют сообщения с устройств владельцев, поставщиков автосервисов, телеметрии, облака и многих других.

API-интерфейс Qt Cloud Messaging прост в усвоении и использовании.

Давайте взглянем на то, как использовать API для встраиваемых систем и мобильных платформ Android. Мы интегрировали SDK Kaltiot Smart IoT и Firebase C++ SDK в бэкэнд, а с помощью Qt Cloud Messaging API мы можем легко создать, например, приложение чата поверх него.

Как использовать Qt Cloud Messaging API для встраиваемых устройств:

Во-первых, клонируйте репозиторий qtcloudmessaging: git clone https://codereview.qt-project.org/qt/qtcloudmessaging


Поставщик услуг

Предварительные требования:

  • Получить SDK Kaltiot для вашего встраиваемого устройства (например, Linux или Raspberry Pi SDK) по https://console.torqhub.io
  • Получить ключ API для отправки каналов и/или создания серверной реализации
  • Добавить следующую строку в .pro файл приложения: QT + = cloudmessagingembeddedkaltiot
  • Определить путь KALTIOT_SDK к вашему application.pro
  • Добавить следующие включения в main.cpp
#include <QtCloudMessaging>
 
#include <QtCloudMessagingEmbeddedKaltiot>
  • Добавить следующие конфигурации QtCloudMessaging в main.cpp
// Создайте экземпляр CloudMessaging библиотеки
QCloudMessaging *pushServices = new QCloudMessaging();

// Добавить поставщика для встраиваемых систем Kaltiot
QCloudMessagingEmbeddedKaltiotProvider *kaltiotPushService = new QCloudMessagingEmbeddedKaltiotProvider()

// Параметры инициализации, основанные на поставщике, предоставляются с помощью QVariantMap
QVariantMap provider_params;
provider_params[“API_KEY”] = “Your API key from the Kaltiot console for server communication”;
// Создание имени поставщика, которое может быть использовано через ваше приложение.
pushServices->registerProvider(“KaltiotService”, kaltiotPushService, provider_params);

QVariantMap client_params;
client_params[“address”] = “IOTSensor1”;
client_params[“version”] = “1.0”;
client_params[“customer_id”] = “Kaltiot”;

// Создание каналов по умолчанию для прослушивания
QVariantList channels;
channels.append(“weather_broadcast_channel”);
client_params[“channels”] = channels;

// Подключение клиента IoT-датчика к системе
pushServices->connectClient(“KaltiotService”, “IOTSensor1”, client_params);

//! Автоматически подписаться на прослушивание еще одного канала, например, WindInfo.
pushServices->subsribeToChannel(“WindInfo”, ” KaltiotService “, ” IOTSensor1″);
  • Обеспечить контекст обмена облачными сообщениями с QML в main.cpp
//! Предоставление контекста QML 
engine.rootContext()->setContextProperty(“pushServices”, pushServices);


QML часть:

в main.qml поймать сообщения, поступающие от сервиса Kaltiot.

Чтобы получить сообщение в QML:

  • Получение сообщений
Connections{
target : pushServices
onMessageReceived:{

      //! Message is received as string and needs parsing to JSON

console.log(message)
}
}
  • Отправление сообщений
//! Отправка широковещательного сообщения, например, от метеостанции:
//! Структура сообщения для встраиваемых устройств проста:
//! определить полезную нагрузку json:
//! {
//!   “payload_type”:”STRING”,
//!   “payload”: encodeURI(JSON.stringify(payload))
//! }
//! Полезная нагрузка - это ваше приложение. Например:
var payload =
{
  msgType:”NEW_WEATHER_INFO”,
  city: “Oulu”,
  forecast: “full sunlight for whole next week”
}

//! Капсулируйте полезную нагрузку для сообщения и отправляйте ее через API QtCloudMessaging:
var payload_array = [{“payload_type”:”STRING”,”payload”: encodeURI(JSON.stringify(payload))}]

pushServices.sendMessage(JSON.stringify(data), ”KaltiotService”, ”IOTSensor1”, ””, ”weather_broadcast_channel”);


Использование Qt Cloud Messaging API для мобильной разработки Android/iOS с поставщиком услуг Firebase от Google

Предварительные требования:

  • Создать новый проект в консоли Google Firebase: https://firebase.google.com/
  • Загрузить SDK Google Firebase C++ и добавить конфигурационный файл Firebase для Android Gradle:
    DISTFILES += \android/google-services.json
  • Добавить следующую строку в .pro файл приложения: QT + = cloudmessagingfirebase
    Определить путь Firebase Google в файле application.pro с помощью GOOGLE_FIREBASE_SDK
  • Добавить следующие включения в свой файл main.cpp
#include <QtCloudMessaging>

#include <QtCloudMessagingFirebase>
  • Добавить следующую настройку QtCloudMessaging в main.cpp:
// Создайте экземпляр CloudMessaging библиотеки

QCloudMessaging *pushServices = new QCloudMessaging();

QCloudMessagingFirebaseProvider *firebaseService = new QCloudMessagingFirebaseProvider();

QVariantMap provider_params;

// Ключ API сервера не рекомендуется хранить внутри кода приложения из соображений безопасности.
// Но если вы это делаете или если вы выполняете реализацию сервера с помощью C++ и Qt, убедитесь, что он находится внутри скомпилированного файла C.
// SERVER_API_KEY необходимо иметь возможность отправлять сообщения темы с клиента без сервера приложений Firebase.

provider_params[“SERVER_API_KEY”] = “Get your SERVER API KEY from the google firebase console”;

// Регистрация компонента службы firebase Google.
pushServices->registerProvider(“GoogleFireBase”, firebaseService, provider_params);

/*! Для мобильного устройства необходим подключенный клиент.
\param Service name “GoogleFireBase”
\param Client identifier name to be used inside the application
\param Parameters for the client. No params for firebase client.
*/

pushServices->connectClient(“GoogleFireBase”, “MobileClient”, QVariantMap());

//! Автоматически подписаться на прослушивание одной темы
pushServices->subsribeToChannel(“ChatRoom”, “GoogleFireBase”, “MobileClient”);
  • Обеспечить контекст обмена облачными сообщениями с QML в main.cpp
//! Предоставление контекста QML
engine.rootContext()->setContextProperty(“pushServices”, pushServices);

QML часть:

в main.qml поймать сообщения, поступающие с google firebase

  • Получение сообщений:
Connections{
target : pushServices
onMessageReceived:{
//! Сообщение принимается как строка и требует синтаксического анализа для JSON

console.log(message)
}
}
  • Отправление сообщений:
//! Для firebase структура сообщения должна иметь данные как целое сообщение.
//! Уведомления отображаются в центре уведомлений Android/iOS.
function sendMessage(notification_titile, notification_msg, msg){
var data = { “data”:{
“message”: {“text”:msg } },
“notification” : {
“body” : notification_msg,
“title” : notification_titile
}
}

//! Дайте идентификатор поставщика данных и поставщика услуг, а также имя клиента, определенное в коде C++.

pushServices.sendMessage(JSON.stringify(data),”GoogleFireBase”,”MobileClient”,””,”ChatRoom”);
}

Вы можете поиграться с Firebase Qt Cloud Messaging API + из образца https://github.com/snowgrains/qtcloudmessaging-examples

API-интерфейс Qt Cloud Messaging предоставляет кросс-платформенный API, который позволяет нам включать новых поставщиков и поддерживать API разработки таким же.

API Qt Cloud Messaging разработан так, чтобы быть легко доступным для любого поставщика услуг. Взгляните на него на https://codereview.qt-project.org/qt/qtcloudmessaging и внесите свой собственный вклад в бэкэнд в сообществе.

Kaltiot разрабатывает и обслуживает облачные сервисы IoT с 2008 года. Ей доверяет Microsoft. Через Kaltiot проходит 10М сообщений каждый час.

SnowGrains предоставляет полные программные решения.

Статья написана: Ari Salmi | Вторник, Январь 2, 2018г.

Комментарии

Комментарии

Только авторизованные пользователи могут оставлять комментарии.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
24 сентября 2018 г. 17:42
edorofeeva

C++ - Тест 001. Первая программа и типы данных

  • Результат 100баллов,
  • Очки рейтинга10
24 сентября 2018 г. 17:37
edorofeeva

C++ - Тест 001. Первая программа и типы данных

  • Результат 66баллов,
  • Очки рейтинга-1
23 сентября 2018 г. 14:38
No Names

C++ - Тест 001. Первая программа и типы данных

  • Результат 60баллов,
  • Очки рейтинга-1
Последние комментарии
24 сентября 2018 г. 15:09
Евгений Легоцкой

Qt Linux - Урок 001. Автозапуск Qt приложения под Linux

А вот здесь у меня есть пример использования supervisor. https://evileg.com/ru/post/3/ Вся статья вам там не интересна, интересен только шаг с настройкой supervisor. Он получается ...
24 сентября 2018 г. 15:00
avovana

Qt Linux - Урок 001. Автозапуск Qt приложения под Linux

Не могли бы дать ссылку на пример? Какое-то рабочее использование. Т.е. у меня есть Qt Gui App, которое я бы хотел запускать при старте системы и в случае, если оно грохнется. Если о чем Вы го...
24 сентября 2018 г. 14:55
Евгений Легоцкой

Qt Linux - Урок 001. Автозапуск Qt приложения под Linux

Если честно, то я не уверен, что это вообще можно реализовать через *.desktop файл. Я сделал предположение на основе того, что вы сказали про *.desktop и рестарт. Все варианты, котор...
24 сентября 2018 г. 14:47
avovana

Qt Linux - Урок 001. Автозапуск Qt приложения под Linux

Просто сейчас правлю сам файл example.desktop. Пытаюсь понять какую пару key=value мне нужно дописать.
24 сентября 2018 г. 14:42
Евгений Легоцкой

Qt Linux - Урок 001. Автозапуск Qt приложения под Linux

Ну я имел ввиду, что дописать в коде вот сюда то, о чём вы говорили про рестарт QString autorunContent("[Desktop Entry]\n" "Type=Application\n" ...
Сейчас обсуждают на форуме
24 сентября 2018 г. 16:47
Евгений_Канусовский@1981

Чтение файлов в python

Добрый вечер Евгений и форумчане! Столкнулся с проблемой чтения файлов в python: файлы с обычным текстом в формате las и txt читаются, например: ~Version information VERS.          ...
24 сентября 2018 г. 13:29
Евгений Легоцкой

Трансляция видео с помощью VLC по RTP

Добрый день! Я не сталкивался, но предположу, что нужно настроить Input Codec в VLC. В настройках есть секция Input Codec, возможно, что там установлено низкое разрешение. ...
21 сентября 2018 г. 8:25
Евгений Легоцкой

Прокси-модель, содержащая на 1 столбец больше, чем модель-источник.

Попробуйте ещё PySide 2 - это официально поддерживаемый пакет привязок Python к Qt, возможно, что там не будет таких проблем.
20 сентября 2018 г. 20:06
Евгений Легоцкой

Qt Installer Framework

Добрый день. Зачем собирать Qt Installer Framework-то из исходников? Я ещё понимаю Qt собирают из исходников статически (хотя тоже считаю по большей части бесполезной тратой времени),...
Присоединяйтесь к нам в социальных сетях