Browse Source
			
			
			
			
				
		[documentation] Обновление документации See merge request omprussia/flutter/flutter-plugins!30merge-requests/30/merge
				 9 changed files with 648 additions and 77 deletions
			
			
		| 
		 Before Width: | Height: | Size: 134 KiB  | 
| 
		 Before Width: | Height: | Size: 318 KiB  | 
| 
		 After Width: | Height: | Size: 160 KiB  | 
| 
		 After Width: | Height: | Size: 367 KiB  | 
@ -0,0 +1,131 @@ | 
				
			|||||||
 | 
					# Qt plugin package | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Qt plugin package - является обычным плагином типа "[Plugin package](#todo)", но использующего Qt сигналы и слоты. Проект "[Demo Dart Packages](https://gitlab.com/omprussia/flutter/demo-dart-packages)" содержит в себе пакет реализующий платформо-зависимый плагин для ОС Аврора типа "Plugin package", на его примере покажем как подключить сигналы и слоты к плагину. | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Плагин уже имеет в зависимостях Qt, но в нем не будут работать сигналы и слоты. Для их подключения следует добавить зависимости в класс реализующий `PluginInterface`: | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Файл `packages/aurora/plugin_device/aurora/include/plugin_device/plugin_device_plugin.h` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```cpp | 
				
			||||||
 | 
					#include <flutter/plugin-interface.h> | 
				
			||||||
 | 
					#include <plugin_device/globals.h> | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <QtCore> | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class PLUGIN_EXPORT PluginDevicePlugin final | 
				
			||||||
 | 
					    : public QObject | 
				
			||||||
 | 
					    , public PluginInterface | 
				
			||||||
 | 
					{ | 
				
			||||||
 | 
					    Q_OBJECT | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public: | 
				
			||||||
 | 
					    void RegisterWithRegistrar(PluginRegistrar ®istrar) override; | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					private: | 
				
			||||||
 | 
					    void onMethodCall(const MethodCall &call); | 
				
			||||||
 | 
					    void onGetDeviceName(const MethodCall &call); | 
				
			||||||
 | 
					    void unimplemented(const MethodCall &call); | 
				
			||||||
 | 
					}; | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					А в файл реализации добавить в низ файла `#include "moc_sensors_plus_aurora_plugin.cpp"`: | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Файл `packages/aurora/plugin_device/aurora/plugin_device_plugin.cpp` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```cpp | 
				
			||||||
 | 
					#include <plugin_device/plugin_device_plugin.h> | 
				
			||||||
 | 
					#include <flutter/method-channel.h> | 
				
			||||||
 | 
					#include <QtDBus/QtDBus> | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** | 
				
			||||||
 | 
					 * Регистрация [MethodChannel]. | 
				
			||||||
 | 
					 */ | 
				
			||||||
 | 
					void PluginDevicePlugin::RegisterWithRegistrar(PluginRegistrar ®istrar) | 
				
			||||||
 | 
					{ | 
				
			||||||
 | 
					    registrar.RegisterMethodChannel("plugin_device", | 
				
			||||||
 | 
					                                    MethodCodecType::Standard, | 
				
			||||||
 | 
					                                    [this](const MethodCall &call) { this->onMethodCall(call); }); | 
				
			||||||
 | 
					} | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** | 
				
			||||||
 | 
					 * Метод onMethodCall будет выполняться при вызове MethodChannel из Dart-плагина. | 
				
			||||||
 | 
					 * По названию, передаваемому из плагина, можно вызвать нужный платформо-зависимый метод. | 
				
			||||||
 | 
					 */ | 
				
			||||||
 | 
					void PluginDevicePlugin::onMethodCall(const MethodCall &call) | 
				
			||||||
 | 
					{ | 
				
			||||||
 | 
					    const auto &method = call.GetMethod(); | 
				
			||||||
 | 
					    if (method == "getDeviceName") { | 
				
			||||||
 | 
					        onGetDeviceName(call); | 
				
			||||||
 | 
					        return; | 
				
			||||||
 | 
					    } | 
				
			||||||
 | 
					    unimplemented(call); | 
				
			||||||
 | 
					} | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** | 
				
			||||||
 | 
					 * Платформо-зависимый метод, получающий название устройства | 
				
			||||||
 | 
					 */ | 
				
			||||||
 | 
					void PluginDevicePlugin::onGetDeviceName(const MethodCall &call) | 
				
			||||||
 | 
					{ | 
				
			||||||
 | 
					    if (!QDBusConnection::sessionBus().isConnected()) { | 
				
			||||||
 | 
					        call.SendSuccessResponse(nullptr); | 
				
			||||||
 | 
					        return; | 
				
			||||||
 | 
					    } | 
				
			||||||
 | 
					    QDBusInterface iface("ru.omp.deviceinfo", | 
				
			||||||
 | 
					        "/ru/omp/deviceinfo/Features", | 
				
			||||||
 | 
					        "", | 
				
			||||||
 | 
					        QDBusConnection::sessionBus() | 
				
			||||||
 | 
					    ); | 
				
			||||||
 | 
					    if (iface.isValid()) { | 
				
			||||||
 | 
					        QDBusReply<QString> reply = iface.call("getDeviceModel"); | 
				
			||||||
 | 
					        if (reply.isValid()) { | 
				
			||||||
 | 
					            call.SendSuccessResponse(reply.value().toStdString()); | 
				
			||||||
 | 
					            return; | 
				
			||||||
 | 
					        } | 
				
			||||||
 | 
					    } | 
				
			||||||
 | 
					    call.SendSuccessResponse(nullptr); | 
				
			||||||
 | 
					} | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/** | 
				
			||||||
 | 
					 * Метод возвращающий [nullptr], если запрашиваемый метод не найден | 
				
			||||||
 | 
					 */ | 
				
			||||||
 | 
					void PluginDevicePlugin::unimplemented(const MethodCall &call) | 
				
			||||||
 | 
					{ | 
				
			||||||
 | 
					    call.SendSuccessResponse(nullptr); | 
				
			||||||
 | 
					} | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "moc_sensors_plus_aurora_plugin.cpp" | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					И для того что бы мок файл сгенерировался добавим в [set_target_properties](https://cmake.org/cmake/help/latest/command/set_target_properties.html) `AUTOMOC ON`: | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Файл `packages/aurora/plugin_device/aurora/CMakeLists.txt` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					set_target_properties(${PLUGIN_NAME} PROPERTIES CXX_VISIBILITY_PRESET hidden AUTOMOC ON) | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Для подключения Qt в плагин нужно добавить в `CMakeLists.txt` как минимум [QtCore](https://doc.qt.io/qt-5/qtcore-index.html): | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					find_package(Qt5 COMPONENTS Core REQUIRED) | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					target_link_libraries(${PLUGIN_NAME} PUBLIC Qt5::Core) | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Для работы плагина в приложении Qt нужно включить отдельно. Сделать это можно добавив в `main` функцию приложения вызов метода `EnableQtCompatibility()`. Выглядеть это может следующим образом: | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```cpp | 
				
			||||||
 | 
					#include <flutter/application.h> | 
				
			||||||
 | 
					#include <flutter/compatibility.h> | 
				
			||||||
 | 
					#include "generated_plugin_registrant.h" | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int main(int argc, char *argv[]) { | 
				
			||||||
 | 
					    Application::Initialize(argc, argv); | 
				
			||||||
 | 
					    EnableQtCompatibility(); // Включение "Qt plugin package" плагинов | 
				
			||||||
 | 
					    RegisterPlugins(); | 
				
			||||||
 | 
					    Application::Launch(); | 
				
			||||||
 | 
					    return 0; | 
				
			||||||
 | 
					} | 
				
			||||||
 | 
					``` | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Добавив зависимости в плагин начнут работать сигналы и слоты Qt. ОС Аврора очень зависит от Qt, во Flutter мы стараемся минимизировать эту зависимость. Если есть возможность выбора типа для реализации платформо-зависимого плагина использование Qt нежелательно.  | 
				
			||||||
					Loading…
					
					
				
		Reference in new issue