You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
183 lines
5.5 KiB
183 lines
5.5 KiB
import 'dart:convert';
|
|
import 'dart:typed_data';
|
|
import 'package:csv/csv.dart';
|
|
import 'package:fit_tool/fit_tool.dart';
|
|
|
|
class ManagerFile {
|
|
// -- Field
|
|
final String _fieldTimestamp = "timestamp";
|
|
final String _fieldPositionLatitue = "position_lat";
|
|
final String _fieldPositionLongitude = "position_long";
|
|
final String _fieldDistance = "distance";
|
|
final String _fieldBPM = "heart_rate";
|
|
final String _fieldSpeed = "speed";
|
|
final String _fieldAltitude = "altitude";
|
|
final String _fieldTotalStep = "total_strides";
|
|
final String _fieldTotalCalorie = "total_calories";
|
|
// -- Getter field
|
|
String get fieldTimeStamp => _fieldTimestamp;
|
|
String get fieldPositionLatitude => _fieldPositionLatitue;
|
|
String get fieldPositionLongitude => _fieldPositionLongitude;
|
|
String get fieldDistance => _fieldDistance;
|
|
String get fielBPM => _fieldBPM;
|
|
String get fieldSpeed => _fieldSpeed;
|
|
String get fieldAltitude => _fieldAltitude;
|
|
String get fieldTotalStep => _fieldTotalStep;
|
|
String get fieldTotalCalories => _fieldTotalCalorie;
|
|
|
|
List<String> allowedFieldWalking = List.empty(growable: true);
|
|
|
|
ManagerFile() {
|
|
allowedFieldWalking = [
|
|
_fieldTimestamp,
|
|
_fieldPositionLatitue,
|
|
_fieldPositionLongitude,
|
|
_fieldDistance,
|
|
_fieldBPM,
|
|
_fieldSpeed,
|
|
_fieldAltitude,
|
|
_fieldTotalStep,
|
|
_fieldTotalCalorie
|
|
];
|
|
}
|
|
|
|
List<List<String>> convertBytesFitFileIntoCSVList(Uint8List bytes) {
|
|
FitFile fitFile = FitFile.fromBytes(bytes);
|
|
|
|
// ----------- Lire le fit et extarire les données qu'on choisi ----------- //
|
|
List<Map<String, Map<String, String>>> dataResult =
|
|
List.empty(growable: true);
|
|
|
|
for (Record element in fitFile.records) {
|
|
List listeField = element.toRow();
|
|
Map<String, Map<String, String>> ligneDataResult = {};
|
|
bool skip = true;
|
|
|
|
if (listeField[0] != "Data") {
|
|
continue;
|
|
}
|
|
|
|
for (int i = 0; i < listeField.length;) {
|
|
if (allowedFieldWalking.contains(listeField[i])) {
|
|
Map<String, String> tmp = {};
|
|
tmp["Value"] = listeField[i + 1].toString();
|
|
tmp["Unite"] = listeField[i + 2].toString();
|
|
ligneDataResult[listeField[i]] = tmp;
|
|
i += 2;
|
|
skip = false;
|
|
}
|
|
i += 1;
|
|
}
|
|
if (!skip) {
|
|
dataResult.add(ligneDataResult);
|
|
}
|
|
}
|
|
// -------- FIN ---------- //
|
|
|
|
// ------- Création du csv ----- //
|
|
// --- Création de l'entête -- //
|
|
List<String> enteteCSV = [];
|
|
for (String field in allowedFieldWalking) {
|
|
enteteCSV.add("Value_$field");
|
|
enteteCSV.add("Unite_$field");
|
|
}
|
|
|
|
List<List<String>> csvData = List.empty(growable: true);
|
|
//
|
|
for (Map<String, Map<String, String>> ligne in dataResult) {
|
|
List<String> tmpLigne = List.empty(growable: true);
|
|
for (String field in allowedFieldWalking) {
|
|
if (!ligne.containsKey(field)) {
|
|
tmpLigne.add("null");
|
|
tmpLigne.add("null");
|
|
} else {
|
|
tmpLigne.add(ligne[field]!["Value"]!);
|
|
tmpLigne.add(ligne[field]!["Unite"]!);
|
|
}
|
|
}
|
|
csvData.add(tmpLigne);
|
|
}
|
|
csvData.insert(0, enteteCSV);
|
|
// ------- FIN --------------- //
|
|
return csvData;
|
|
}
|
|
|
|
// -- Read the byte of file CSV -- //
|
|
List<List<dynamic>> convertByteIntoCSV(Uint8List bytes) {
|
|
return const CsvToListConverter().convert(utf8.decode(bytes));
|
|
}
|
|
|
|
/*
|
|
// ------------- Get The path of application --- //
|
|
Future<String> get localPath async {
|
|
final directory = await getApplicationDocumentsDirectory();
|
|
return directory.path;
|
|
}*/
|
|
|
|
/*
|
|
// ----- Read csv File ------- //
|
|
Future<List<dynamic>> readCSVFile(String path) async {
|
|
if (File(path).exists() == false) return List.empty();
|
|
final input = File(path).openRead();
|
|
final fields = await input
|
|
.transform(utf8.decoder)
|
|
.transform(const CsvToListConverter())
|
|
.toList();
|
|
return fields;
|
|
}
|
|
|
|
// ----- Read a file FIT --- //
|
|
Future<List<dynamic>> readFitFile(String path) async {
|
|
if (File(path).existsSync() == false) return List.empty();
|
|
|
|
final file = File(path);
|
|
final bytes = await file.readAsBytes();
|
|
final fitFile = FitFile.fromBytes(bytes);
|
|
|
|
return fitFile.toRows();
|
|
}
|
|
|
|
Future<List<dynamic>> readFitFileWhithFile(File file) async {
|
|
final bytes = await file.readAsBytes();
|
|
final fitFile = FitFile.fromBytes(bytes);
|
|
return fitFile.toRows();
|
|
}
|
|
|
|
List<dynamic> readFitFileWeb(Uint8List bytes) {
|
|
final fitFile = FitFile.fromBytes(bytes);
|
|
return fitFile.toRows();
|
|
}*/
|
|
|
|
/*
|
|
// --- A modifier si utilisé --- //
|
|
Future<bool> saveFileLocal(String nameFileWithExtension, String path) async {
|
|
/*
|
|
final outFile = File("${await localPath}\\Files\\$nameFileWithExtension");
|
|
if (outFile.existsSync() == false) {
|
|
outFile.createSync(recursive: true);
|
|
}
|
|
await outFile.writeAsString(await file.readAsString());
|
|
return true;*/
|
|
}*/
|
|
/*
|
|
// -- Check si le fichier existe localement -- //
|
|
Future<bool> fileExist(String filname) async {
|
|
Directory directory = Directory("${await localPath}\\Files\\");
|
|
if (!directory.existsSync()) {
|
|
print("Le dossier n'existe pas !");
|
|
return false;
|
|
}
|
|
List<FileSystemEntity> files = directory.listSync();
|
|
for (FileSystemEntity file in files) {
|
|
if (file.path.split("\\").last == filname) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}*/
|
|
|
|
// --- Ligne utile --- //
|
|
//final csv = const ListToCsvConverter().convert(fitFile.toRows());
|
|
//await outFile.writeAsString(csv);*/
|
|
}
|