These are optional plugins that can be included in an embedder to access OS functionality.
In the long term plugins would be managed via pub, as they are with mobile Flutter plugins. For now, however, they are designed to be included directly from this repository.
Add local package references for the plugins you want to use to your pubspec.yaml. For example:
dependencies:
...
color_panel:
path: relative/path/to/plugins/color_panel
Then import it in your dart code as you would any other package:
import 'package:color_panel/color_panel.dart';
Build the Xcode project under the macos diretory for each plugin you want to use, then link the resulting framework in your project.
When you set up your FLEViewController, before calling launchEngine...
,
call -addPlugin:
with an instance of each plugin you want to use. For
instance:
[myFlutterViewController addPlugin:[[FLEColorPanelPlugin alloc] init]];
Run make
in the linux
directory for each plugin you want to use, then
link the resulting library in your application.
After creating your Flutter window, call AddPlugin with an instance of each plugin you want to use. For instance:
AddPlugin(window,
std::make_unique<plugins_color_panel::ColorPanelPlugin>());
See the example application under each platform's directory in the example
directory to see an example of including optional plugins on that platform.
The Flutter application under example/flutter_app
shows examples of using
optional plugins on the Dart side.
You can easily create local packages following the model of plugins here to use in your own projects.
If you think they would be generally useful, feel free to submit a pull request and they could potentially be folded into this repository. In the future, as noted above, desktop plugins would be managed using a model like mobile plugins where that wouldn't be necessary.
Currently only JSONMethodCodec is supported for desktop plugins. See google#67