Skip to content

Commit

Permalink
Improving the interpretation widgets
Browse files Browse the repository at this point in the history
We display the prediction on top of a map displaying the gestures along
with their statistics.
  • Loading branch information
DariusIMP committed Feb 4, 2022
1 parent 079f4fd commit 6ba559d
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 20 deletions.
2 changes: 1 addition & 1 deletion lib/pages/ble_devices_connection_page.dart
Original file line number Diff line number Diff line change
Expand Up @@ -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),
),
],
Expand Down
63 changes: 44 additions & 19 deletions lib/pages/interpretation_page.dart
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down Expand Up @@ -137,21 +136,6 @@ class _InterpretationWidgetState extends State<InterpretationWidget> {
color: Theme.of(context).backgroundColor,
child: Text("Mac addr: ${device.id.id}")),
displayStats(),
StreamBuilder<List<int>>(
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));
})
],
));
}
Expand All @@ -165,17 +149,58 @@ class _InterpretationWidgetState extends State<InterpretationWidget> {
initialData: [],
builder: (c, rawDeviceInterpretations) {
String msg = "";
String prediction = "";
Map<String, String> 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<String, String> _parseStatistics(String msg) {
Map<String, String> 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 {
Expand Down

0 comments on commit 6ba559d

Please sign in to comment.