rgba -> image
This commit is contained in:
parent
676278920f
commit
1a3a2cf6c7
@ -6,6 +6,7 @@ import 'dart:ffi';
|
|||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'package:flutter_easyloading/flutter_easyloading.dart';
|
import 'package:flutter_easyloading/flutter_easyloading.dart';
|
||||||
|
import 'dart:typed_data';
|
||||||
|
|
||||||
class RgbaFrame extends Struct {
|
class RgbaFrame extends Struct {
|
||||||
@Uint32()
|
@Uint32()
|
||||||
@ -55,14 +56,15 @@ class FFI {
|
|||||||
static F3 _setByName;
|
static F3 _setByName;
|
||||||
static F4 _freeRgba;
|
static F4 _freeRgba;
|
||||||
static F5 _getRgba;
|
static F5 _getRgba;
|
||||||
|
static Pointer<RgbaFrame> _lastRgbaFrame;
|
||||||
|
|
||||||
static String getId() {
|
static String getId() {
|
||||||
return getByName("remote_id");
|
return getByName('remote_id');
|
||||||
}
|
}
|
||||||
|
|
||||||
static List<Peer> peers() {
|
static List<Peer> peers() {
|
||||||
try {
|
try {
|
||||||
List<dynamic> peers = json.decode(getByName("peers"));
|
List<dynamic> peers = json.decode(getByName('peers'));
|
||||||
return peers
|
return peers
|
||||||
.map((s) => s as List<dynamic>)
|
.map((s) => s as List<dynamic>)
|
||||||
.map((s) =>
|
.map((s) =>
|
||||||
@ -75,12 +77,25 @@ class FFI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void connect(String id) {
|
static void connect(String id) {
|
||||||
setByName("connect", id);
|
setByName('connect', id);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void _clearRgbaFrame() {
|
||||||
|
if (_lastRgbaFrame != null && _lastRgbaFrame != nullptr)
|
||||||
|
_freeRgba(_lastRgbaFrame);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Uint8List getRgba() {
|
||||||
|
_clearRgbaFrame();
|
||||||
|
_lastRgbaFrame = _getRgba();
|
||||||
|
if (_lastRgbaFrame == null || _lastRgbaFrame == nullptr) return null;
|
||||||
|
final ref = _lastRgbaFrame.ref;
|
||||||
|
return Uint8List.sublistView(ref.data.asTypedList(ref.len));
|
||||||
}
|
}
|
||||||
|
|
||||||
static Map<String, String> popEvent() {
|
static Map<String, String> popEvent() {
|
||||||
var s = getByName("event");
|
var s = getByName('event');
|
||||||
if (s == "") return null;
|
if (s == '') return null;
|
||||||
try {
|
try {
|
||||||
Map<String, String> event = json.decode(s);
|
Map<String, String> event = json.decode(s);
|
||||||
return event;
|
return event;
|
||||||
@ -92,24 +107,25 @@ class FFI {
|
|||||||
|
|
||||||
static void login(String password, bool remember) {
|
static void login(String password, bool remember) {
|
||||||
setByName(
|
setByName(
|
||||||
"login",
|
'login',
|
||||||
json.encode({
|
json.encode({
|
||||||
"password": password,
|
'password': password,
|
||||||
"remember": remember ? "true" : "false",
|
'remember': remember ? 'true' : 'false',
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void close() {
|
static void close() {
|
||||||
setByName("close", "");
|
_clearRgbaFrame();
|
||||||
|
setByName('close', '');
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setByName(String name, String value) {
|
static void setByName(String name, String value) {
|
||||||
_setByName(Utf8.toUtf8(name), Utf8.toUtf8(value));
|
_setByName(Utf8.toUtf8(name), Utf8.toUtf8(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
static String getByName(String name, {String arg = ""}) {
|
static String getByName(String name, {String arg = ''}) {
|
||||||
var p = _getByName(Utf8.toUtf8(name), Utf8.toUtf8(arg));
|
var p = _getByName(Utf8.toUtf8(name), Utf8.toUtf8(arg));
|
||||||
assert(p != null);
|
assert(p != nullptr && p != null);
|
||||||
var res = Utf8.fromUtf8(p);
|
var res = Utf8.fromUtf8(p);
|
||||||
// https://github.com/brickpop/flutter-rust-ffi
|
// https://github.com/brickpop/flutter-rust-ffi
|
||||||
_freeCString(p);
|
_freeCString(p);
|
||||||
@ -130,7 +146,7 @@ class FFI {
|
|||||||
.lookupFunction<Void Function(Pointer<RgbaFrame>), F4>('free_rgba');
|
.lookupFunction<Void Function(Pointer<RgbaFrame>), F4>('free_rgba');
|
||||||
_getRgba = dylib.lookupFunction<F5, F5>('get_rgba');
|
_getRgba = dylib.lookupFunction<F5, F5>('get_rgba');
|
||||||
final dir = (await getApplicationDocumentsDirectory()).path;
|
final dir = (await getApplicationDocumentsDirectory()).path;
|
||||||
setByName("init", dir);
|
setByName('init', dir);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -162,7 +178,7 @@ void showSuccess(String text) {
|
|||||||
|
|
||||||
// https://material.io/develop/flutter/components/dialogs
|
// https://material.io/develop/flutter/components/dialogs
|
||||||
void enterPasswordDialog(String id, BuildContext context) {
|
void enterPasswordDialog(String id, BuildContext context) {
|
||||||
var remember = FFI.getByName("remember", arg: id) == "true";
|
var remember = FFI.getByName('remember', arg: id) == 'true';
|
||||||
var dialog = AlertDialog(
|
var dialog = AlertDialog(
|
||||||
title: Text('Please enter your password'),
|
title: Text('Please enter your password'),
|
||||||
contentPadding: EdgeInsets.zero,
|
contentPadding: EdgeInsets.zero,
|
||||||
|
@ -45,7 +45,7 @@ class _HomePageState extends State<HomePage> {
|
|||||||
|
|
||||||
void onConnect() {
|
void onConnect() {
|
||||||
var id = _idController.text.trim();
|
var id = _idController.text.trim();
|
||||||
if (id == "") return;
|
if (id == '') return;
|
||||||
Navigator.push<dynamic>(
|
Navigator.push<dynamic>(
|
||||||
context,
|
context,
|
||||||
MaterialPageRoute<dynamic>(
|
MaterialPageRoute<dynamic>(
|
||||||
|
@ -17,13 +17,18 @@ class RemotePage extends StatefulWidget {
|
|||||||
// https://github.com/hanxu317317/flutter_plan_demo/blob/master/lib/src/enter.dart
|
// https://github.com/hanxu317317/flutter_plan_demo/blob/master/lib/src/enter.dart
|
||||||
class _RemotePageState extends State<RemotePage> {
|
class _RemotePageState extends State<RemotePage> {
|
||||||
Timer _interval;
|
Timer _interval;
|
||||||
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
int width = 0;
|
||||||
|
int height = 0;
|
||||||
|
ui.Image image;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
super.initState();
|
super.initState();
|
||||||
FFI.connect(widget.id);
|
FFI.connect(widget.id);
|
||||||
WidgetsBinding.instance.addPostFrameCallback((_) {
|
WidgetsBinding.instance.addPostFrameCallback((_) {
|
||||||
showLoading("Connecting...");
|
showLoading('Connecting...');
|
||||||
_interval =
|
_interval =
|
||||||
Timer.periodic(Duration(milliseconds: 30), (timer) => interval());
|
Timer.periodic(Duration(milliseconds: 30), (timer) => interval());
|
||||||
});
|
});
|
||||||
@ -38,22 +43,33 @@ class _RemotePageState extends State<RemotePage> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void interval() {
|
void interval() {
|
||||||
print(DateTime.now());
|
|
||||||
var evt = FFI.popEvent();
|
var evt = FFI.popEvent();
|
||||||
if (evt == null) return;
|
if (evt == null) return;
|
||||||
var name = evt["name"];
|
var name = evt['name'];
|
||||||
if (name == "msgbox") {
|
if (name == 'msgbox') {
|
||||||
handleMsgbox(evt);
|
handleMsgbox(evt);
|
||||||
}
|
}
|
||||||
|
var rgba = FFI.getRgba();
|
||||||
|
if (rgba != null) {
|
||||||
|
ui.decodeImageFromPixels(rgba, width, height, ui.PixelFormat.rgba8888,
|
||||||
|
(_image) {
|
||||||
|
setState(() {
|
||||||
|
image = _image;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleMsgbox(evt) {
|
void handleMsgbox(evt) {
|
||||||
var type = evt["type"];
|
var type = evt['type'];
|
||||||
var title = evt["title"];
|
var title = evt['title'];
|
||||||
var text = evt["text"];
|
var text = evt['text'];
|
||||||
if (type == "error") {
|
if (type == 'error') {
|
||||||
} else if (type == "re-input-password") {
|
} else if (type == 're-input-password') {
|
||||||
} else if (type == "input-password") {}
|
wrongPasswordDialog(widget.id, context);
|
||||||
|
} else if (type == 'input-password') {
|
||||||
|
enterPasswordDialog(widget.id, context);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
@ -65,14 +81,14 @@ class _RemotePageState extends State<RemotePage> {
|
|||||||
return FlutterEasyLoading(
|
return FlutterEasyLoading(
|
||||||
child: GestureDetector(
|
child: GestureDetector(
|
||||||
child: CustomPaint(
|
child: CustomPaint(
|
||||||
painter: new ImageEditor(image: null),
|
painter: new ImageEditor(image: image),
|
||||||
),
|
),
|
||||||
onPanStart: (DragDownDetails) {
|
onPanStart: (DragDownDetails) {
|
||||||
print("onPanStart $DragDownDetails");
|
print('onPanStart $DragDownDetails');
|
||||||
// hero.moveTo(DragDownDetails.globalPosition.dx, DragDownDetails.globalPosition.dy);
|
// hero.moveTo(DragDownDetails.globalPosition.dx, DragDownDetails.globalPosition.dy);
|
||||||
},
|
},
|
||||||
onPanUpdate: (DragDownDetails) {
|
onPanUpdate: (DragDownDetails) {
|
||||||
print("onPanUpdate $DragDownDetails");
|
print('onPanUpdate $DragDownDetails');
|
||||||
// hero.moveTo(DragDownDetails.globalPosition.dx, DragDownDetails.globalPosition.dy);
|
// hero.moveTo(DragDownDetails.globalPosition.dx, DragDownDetails.globalPosition.dy);
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user