rgba -> image

This commit is contained in:
open-trade 2020-11-18 00:28:55 +08:00
parent 676278920f
commit 1a3a2cf6c7
3 changed files with 59 additions and 27 deletions

View File

@ -6,6 +6,7 @@ import 'dart:ffi';
import 'dart:async';
import 'dart:convert';
import 'package:flutter_easyloading/flutter_easyloading.dart';
import 'dart:typed_data';
class RgbaFrame extends Struct {
@Uint32()
@ -55,14 +56,15 @@ class FFI {
static F3 _setByName;
static F4 _freeRgba;
static F5 _getRgba;
static Pointer<RgbaFrame> _lastRgbaFrame;
static String getId() {
return getByName("remote_id");
return getByName('remote_id');
}
static List<Peer> peers() {
try {
List<dynamic> peers = json.decode(getByName("peers"));
List<dynamic> peers = json.decode(getByName('peers'));
return peers
.map((s) => s as List<dynamic>)
.map((s) =>
@ -75,12 +77,25 @@ class FFI {
}
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() {
var s = getByName("event");
if (s == "") return null;
var s = getByName('event');
if (s == '') return null;
try {
Map<String, String> event = json.decode(s);
return event;
@ -92,24 +107,25 @@ class FFI {
static void login(String password, bool remember) {
setByName(
"login",
'login',
json.encode({
"password": password,
"remember": remember ? "true" : "false",
'password': password,
'remember': remember ? 'true' : 'false',
}));
}
static void close() {
setByName("close", "");
_clearRgbaFrame();
setByName('close', '');
}
static void setByName(String name, String 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));
assert(p != null);
assert(p != nullptr && p != null);
var res = Utf8.fromUtf8(p);
// https://github.com/brickpop/flutter-rust-ffi
_freeCString(p);
@ -130,7 +146,7 @@ class FFI {
.lookupFunction<Void Function(Pointer<RgbaFrame>), F4>('free_rgba');
_getRgba = dylib.lookupFunction<F5, F5>('get_rgba');
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
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(
title: Text('Please enter your password'),
contentPadding: EdgeInsets.zero,

View File

@ -45,7 +45,7 @@ class _HomePageState extends State<HomePage> {
void onConnect() {
var id = _idController.text.trim();
if (id == "") return;
if (id == '') return;
Navigator.push<dynamic>(
context,
MaterialPageRoute<dynamic>(

View File

@ -17,13 +17,18 @@ class RemotePage extends StatefulWidget {
// https://github.com/hanxu317317/flutter_plan_demo/blob/master/lib/src/enter.dart
class _RemotePageState extends State<RemotePage> {
Timer _interval;
int x = 0;
int y = 0;
int width = 0;
int height = 0;
ui.Image image;
@override
void initState() {
super.initState();
FFI.connect(widget.id);
WidgetsBinding.instance.addPostFrameCallback((_) {
showLoading("Connecting...");
showLoading('Connecting...');
_interval =
Timer.periodic(Duration(milliseconds: 30), (timer) => interval());
});
@ -38,22 +43,33 @@ class _RemotePageState extends State<RemotePage> {
}
void interval() {
print(DateTime.now());
var evt = FFI.popEvent();
if (evt == null) return;
var name = evt["name"];
if (name == "msgbox") {
var name = evt['name'];
if (name == 'msgbox') {
handleMsgbox(evt);
}
var rgba = FFI.getRgba();
if (rgba != null) {
ui.decodeImageFromPixels(rgba, width, height, ui.PixelFormat.rgba8888,
(_image) {
setState(() {
image = _image;
});
});
}
}
void handleMsgbox(evt) {
var type = evt["type"];
var title = evt["title"];
var text = evt["text"];
if (type == "error") {
} else if (type == "re-input-password") {
} else if (type == "input-password") {}
var type = evt['type'];
var title = evt['title'];
var text = evt['text'];
if (type == 'error') {
} else if (type == 're-input-password') {
wrongPasswordDialog(widget.id, context);
} else if (type == 'input-password') {
enterPasswordDialog(widget.id, context);
}
}
@override
@ -65,14 +81,14 @@ class _RemotePageState extends State<RemotePage> {
return FlutterEasyLoading(
child: GestureDetector(
child: CustomPaint(
painter: new ImageEditor(image: null),
painter: new ImageEditor(image: image),
),
onPanStart: (DragDownDetails) {
print("onPanStart $DragDownDetails");
print('onPanStart $DragDownDetails');
// hero.moveTo(DragDownDetails.globalPosition.dx, DragDownDetails.globalPosition.dy);
},
onPanUpdate: (DragDownDetails) {
print("onPanUpdate $DragDownDetails");
print('onPanUpdate $DragDownDetails');
// hero.moveTo(DragDownDetails.globalPosition.dx, DragDownDetails.globalPosition.dy);
}));
}