From 6ba559d24d6801a17d3c3f46e3b627ff7b46c542 Mon Sep 17 00:00:00 2001 From: Darius Maitia Date: Fri, 4 Feb 2022 16:43:58 -0300 Subject: [PATCH] Improving the interpretation widgets We display the prediction on top of a map displaying the gestures along with their statistics. --- lib/pages/ble_devices_connection_page.dart | 2 +- lib/pages/interpretation_page.dart | 63 +++++++++++++++------- 2 files changed, 45 insertions(+), 20 deletions(-) diff --git a/lib/pages/ble_devices_connection_page.dart b/lib/pages/ble_devices_connection_page.dart index 2e94800..9411343 100644 --- a/lib/pages/ble_devices_connection_page.dart +++ b/lib/pages/ble_devices_connection_page.dart @@ -50,7 +50,7 @@ class BluetoothOffScreen extends StatelessWidget { 'Bluetooth Adapter is ${state != null ? state.toString().substring(15) : 'not available'}.', style: Theme.of(context) .primaryTextTheme - .subhead + .subtitle1 ?.copyWith(color: Colors.white), ), ], diff --git a/lib/pages/interpretation_page.dart b/lib/pages/interpretation_page.dart index 8ab7d92..c3144a1 100644 --- a/lib/pages/interpretation_page.dart +++ b/lib/pages/interpretation_page.dart @@ -2,7 +2,6 @@ import 'package:flutter/material.dart'; import 'package:flutter/widgets.dart'; import 'package:flutter_blue/flutter_blue.dart'; import 'package:lsa_gloves/connection/ble/bluetooth_backend.dart'; -import 'package:lsa_gloves/connection/ble/bluetooth_specification.dart'; import 'package:lsa_gloves/navigation/navigation_drawer.dart'; import 'dart:developer' as developer; @@ -137,21 +136,6 @@ class _InterpretationWidgetState extends State { color: Theme.of(context).backgroundColor, child: Text("Mac addr: ${device.id.id}")), displayStats(), - StreamBuilder>( - stream: dcCharacteristic.value, - initialData: [], - builder: (c, measurements) { - String msg = ""; - if (measurements.hasData) { - msg = new String.fromCharCodes(measurements.data!); - } - return Container( - width: double.infinity, - height: 80, - alignment: Alignment.center, - color: Theme.of(c).backgroundColor, - child: Text(msg)); - }) ], )); } @@ -165,17 +149,58 @@ class _InterpretationWidgetState extends State { initialData: [], builder: (c, rawDeviceInterpretations) { String msg = ""; + String prediction = ""; + Map stats = Map(); if (rawDeviceInterpretations.hasData) { msg = new String.fromCharCodes(rawDeviceInterpretations.data!); } + prediction = _parsePrediction(msg); + stats = _parseStatistics(msg); + return Container( width: double.infinity, - height: 80, - alignment: Alignment.center, + height: 200, + padding: EdgeInsets.all(8), + alignment: Alignment.topCenter, color: Theme.of(c).backgroundColor, - child: Text(msg)); + child: Column( + children: [ + Text(prediction, + textScaleFactor: 1.5, + style: TextStyle(fontWeight: FontWeight.bold)), + SizedBox(height: 16), + Text(stats.toString()) + ], + )); }); } + + String _parsePrediction(String msg) { + int bracketIndex = msg.indexOf("["); + if (bracketIndex != -1) { + return msg.substring(bracketIndex + 1, msg.indexOf("]")); + } + return ""; + } + + /// Parses the statistics and returns a map with each gesture as a key and its + /// corresponding probability as its value. + /// + /// The message must have a format like the following: + /// "[prediction]{gesture1:1}{gesture2:2}{gesture3:1}...{gestureN:2} + Map _parseStatistics(String msg) { + Map stats = new Map(); + int bracketIndex = msg.indexOf("{"); + while (!bracketIndex.isNegative) { + int semicolonIndex = msg.indexOf(":", bracketIndex); + String category = msg.substring(bracketIndex + 1, semicolonIndex); + String probability = + msg.substring(semicolonIndex + 1, msg.indexOf("}", semicolonIndex)); + bracketIndex = msg.indexOf("{", bracketIndex + 1); + stats[category] = probability; + } + return stats; + } } class InterpretationButton extends StatefulWidget {