-
Notifications
You must be signed in to change notification settings - Fork 35
Platform Communication
Use the PlatformComm
class in the platform_comm
directory when you need to access platform-specific code quickly without writing a plugin.
More info on how platform communication is executed in Flutter can be found at the official documentation.
Also, if you need a specific feature that needs to communicate with platform-specific native code consider writing a flutter plugin. Here's a blog post on writing a good flutter plugin.
The PlatformComm
class is a helper for executing platform-specific methods which adds typed parameters and typed response. It's a wrapper around MethodChannel
and provides invokeMethod
and listenMethod
helper functions.
The PlatformComm
class is already configured on the flutter, Android, and iOS side, and is ready to be used. See platform_comm/AppPlatformMethods
for preset platform methods used for testing.
Alternatively, you can use Pigeon for this, but we opted to write our own helper.
The following code sends a String
message to the native side and receives the same echo message back.
serviceLocator
.get<PlatformComm>()
.echoMessage('echo')
.catchError((error) => 'Test platform method error: $error')
.then((backEcho) => Log.d("Test message 'echo' - '$backEcho'"));
For more complicated parameter types see echoObject
which takes a typed Object as a parameter and echoes it back.
In the process the object is:
- on the flutter side, serialized to JSON and sent to the native side
- on the native side, deserialized to Object and being read
- on the native side, serialized to JSON and sent back as a result to the calling flutter side
- on the flutter side, deserialized to Object and returned as a result to the caller