Reorganize and Add UserManager
This commit is contained in:
@@ -88,16 +88,22 @@
|
|||||||
<Reference Include="WaveshareUARTFingerprintSensor, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="WaveshareUARTFingerprintSensor, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>packages\WaveshareUARTFingerprintSensor.1.0.0\lib\net472\WaveshareUARTFingerprintSensor.dll</HintPath>
|
<HintPath>packages\WaveshareUARTFingerprintSensor.1.0.0\lib\net472\WaveshareUARTFingerprintSensor.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
<Reference Include="YamlDotNet, Version=9.0.0.0, Culture=neutral, PublicKeyToken=ec19458f3c15af5e, processorArchitecture=MSIL">
|
||||||
|
<HintPath>packages\YamlDotNet.9.1.4\lib\net45\YamlDotNet.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Compile Include="DataDisplay.cs" />
|
<Compile Include="Views\DataDisplay.cs" />
|
||||||
<Compile Include="EntryDialog.cs" />
|
<Compile Include="Views\EntryDialog.cs" />
|
||||||
<Compile Include="FingerprintDialog.cs" />
|
<Compile Include="Views\FingerprintDialog.cs" />
|
||||||
<Compile Include="Program.cs" />
|
<Compile Include="Program.cs" />
|
||||||
<Compile Include="Properties\AssemblyInfo.cs" />
|
<Compile Include="Properties\AssemblyInfo.cs" />
|
||||||
<Compile Include="SettingsDisplay.cs" />
|
<Compile Include="Views\SettingsDisplay.cs" />
|
||||||
<Compile Include="SleepDisplay.cs" />
|
<Compile Include="Views\SleepDisplay.cs" />
|
||||||
<Compile Include="TUIManager.cs" />
|
<Compile Include="Views\TUIManager.cs" />
|
||||||
|
<Compile Include="Users\User.cs" />
|
||||||
|
<Compile Include="Users\UsersManager.cs" />
|
||||||
|
<Compile Include="WaveshareUARTProvider.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="App.config" />
|
<None Include="App.config" />
|
||||||
|
|||||||
18
Program.cs
18
Program.cs
@@ -1,4 +1,7 @@
|
|||||||
using System;
|
using Akari.Provider.WaveshareUART;
|
||||||
|
using Akari.Provider.WaveshareUART.Users;
|
||||||
|
using Akari.Provider.WaveshareUART.Views;
|
||||||
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO.Ports;
|
using System.IO.Ports;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@@ -10,12 +13,15 @@ using Unosquare.RaspberryIO;
|
|||||||
using Unosquare.RaspberryIO.Abstractions;
|
using Unosquare.RaspberryIO.Abstractions;
|
||||||
using Unosquare.WiringPi;
|
using Unosquare.WiringPi;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART
|
||||||
{
|
{
|
||||||
class Program
|
class Program
|
||||||
{
|
{
|
||||||
static void Main(string[] args)
|
static void Main(string[] args)
|
||||||
{
|
{
|
||||||
|
// TODO
|
||||||
|
args = new[] { "-c" };
|
||||||
|
|
||||||
if (args.Length > 0)
|
if (args.Length > 0)
|
||||||
{
|
{
|
||||||
switch (args[0])
|
switch (args[0])
|
||||||
@@ -29,13 +35,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WaveshareUARTProvider.Instance.FingerprintLoop();
|
||||||
StartLoop();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void StartLoop()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void StartConfig()
|
private static void StartConfig()
|
||||||
|
|||||||
27
Users/User.cs
Normal file
27
Users/User.cs
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace Akari.Provider.WaveshareUART.Users
|
||||||
|
{
|
||||||
|
public class User
|
||||||
|
{
|
||||||
|
public string Name { get; private set; }
|
||||||
|
public string Token { get; private set; }
|
||||||
|
public ushort RangeStart { get; private set; }
|
||||||
|
|
||||||
|
public User()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public User(string name, string token, ushort rangeStart)
|
||||||
|
{
|
||||||
|
Name = name;
|
||||||
|
Token = token;
|
||||||
|
RangeStart = rangeStart;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
88
Users/UsersManager.cs
Normal file
88
Users/UsersManager.cs
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Terminal.Gui;
|
||||||
|
using YamlDotNet.Serialization;
|
||||||
|
|
||||||
|
namespace Akari.Provider.WaveshareUART.Users
|
||||||
|
{
|
||||||
|
public class UsersManager
|
||||||
|
{
|
||||||
|
public const string UsersFilePath = "users.yaml";
|
||||||
|
|
||||||
|
private readonly List<User> _users;
|
||||||
|
private IDeserializer _deserializer;
|
||||||
|
private ISerializer _serializer;
|
||||||
|
|
||||||
|
public int Count => _users.Count;
|
||||||
|
|
||||||
|
public UsersManager()
|
||||||
|
{
|
||||||
|
_serializer = new SerializerBuilder().Build();
|
||||||
|
_deserializer = new DeserializerBuilder().Build();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (!File.Exists(UsersFilePath))
|
||||||
|
{
|
||||||
|
_users = new List<User>();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_users = _deserializer.Deserialize<List<User>>(File.ReadAllText(UsersFilePath));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Console.WriteLine($"Can't load users: {e.Message}");
|
||||||
|
Console.WriteLine(e.StackTrace);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public User this[string name] => _users.FirstOrDefault(u => u.Name.Equals(name, StringComparison.OrdinalIgnoreCase));
|
||||||
|
|
||||||
|
public void Add(User user)
|
||||||
|
{
|
||||||
|
_users.Add(user);
|
||||||
|
|
||||||
|
Save();
|
||||||
|
}
|
||||||
|
|
||||||
|
public IReadOnlyCollection<User> GetAll()
|
||||||
|
{
|
||||||
|
return _users.AsReadOnly();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Remove(User user)
|
||||||
|
{
|
||||||
|
_users.Remove(user);
|
||||||
|
|
||||||
|
Save();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Clear()
|
||||||
|
{
|
||||||
|
_users.Clear();
|
||||||
|
|
||||||
|
Save();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Save()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
File.WriteAllText(UsersFilePath, _serializer.Serialize(_users));
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Console.WriteLine($"Can't save users: {e.Message}");
|
||||||
|
Console.WriteLine(e.StackTrace);
|
||||||
|
|
||||||
|
MessageBox.ErrorQuery("Users", $"Can't save users: {e.Message}");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -6,7 +6,7 @@ using System.Text;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Terminal.Gui;
|
using Terminal.Gui;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART.Views
|
||||||
{
|
{
|
||||||
public class DataDisplay : Toplevel
|
public class DataDisplay : Toplevel
|
||||||
{
|
{
|
||||||
@@ -6,7 +6,7 @@ using System.Text;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Terminal.Gui;
|
using Terminal.Gui;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART.Views
|
||||||
{
|
{
|
||||||
public class EntryDialog : Dialog
|
public class EntryDialog : Dialog
|
||||||
{
|
{
|
||||||
@@ -6,7 +6,7 @@ using System.Text;
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Terminal.Gui;
|
using Terminal.Gui;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART.Views
|
||||||
{
|
{
|
||||||
public class FingerprintDialog : Dialog
|
public class FingerprintDialog : Dialog
|
||||||
{
|
{
|
||||||
@@ -6,8 +6,9 @@ using System.Text;
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Terminal.Gui;
|
using Terminal.Gui;
|
||||||
|
using WaveshareUARTFingerprintSensor;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART.Views
|
||||||
{
|
{
|
||||||
public class SettingsDisplay : Toplevel
|
public class SettingsDisplay : Toplevel
|
||||||
{
|
{
|
||||||
@@ -6,8 +6,9 @@ using System.Text;
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Terminal.Gui;
|
using Terminal.Gui;
|
||||||
|
using WaveshareUARTFingerprintSensor;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART.Views
|
||||||
{
|
{
|
||||||
public class SleepDisplay : Toplevel
|
public class SleepDisplay : Toplevel
|
||||||
{
|
{
|
||||||
@@ -1,4 +1,6 @@
|
|||||||
using NStack;
|
using Akari.Provider.WaveshareUART;
|
||||||
|
using Akari.Provider.WaveshareUART.Users;
|
||||||
|
using NStack;
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
@@ -6,21 +8,22 @@ using System.Linq;
|
|||||||
using System.Text;
|
using System.Text;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Terminal.Gui;
|
using Terminal.Gui;
|
||||||
|
using WaveshareUARTFingerprintSensor;
|
||||||
|
|
||||||
namespace WaveshareUARTFingerprintSensor.Sample
|
namespace Akari.Provider.WaveshareUART.Views
|
||||||
{
|
{
|
||||||
public class TUIManager : Toplevel
|
public class TUIManager : Toplevel
|
||||||
{
|
{
|
||||||
public const string OutputFilePath = "out.txt";
|
|
||||||
public const string SettingsFilePath = "settings.txt";
|
public const string SettingsFilePath = "settings.txt";
|
||||||
|
|
||||||
private FingerprintSensor _fingerprintSensor;
|
public WaveshareUARTProvider Provider => WaveshareUARTProvider.Instance;
|
||||||
|
public FingerprintSensor FingerprintSensor => Provider.FingerprintSensor;
|
||||||
|
public UsersManager UsersManager => Provider.UsersManager;
|
||||||
|
|
||||||
private Label _serialPortLabel;
|
private Label _serialPortLabel;
|
||||||
private Label _comparisonLevelLabel;
|
private Label _comparisonLevelLabel;
|
||||||
private Label _userCountLabel;
|
private Label _userCountLabel;
|
||||||
|
|
||||||
private object _outputFileLock = new object();
|
|
||||||
|
|
||||||
public TUIManager()
|
public TUIManager()
|
||||||
{
|
{
|
||||||
Init();
|
Init();
|
||||||
@@ -68,76 +71,34 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
Y = Pos.Bottom(_serialPortLabel),
|
Y = Pos.Bottom(_serialPortLabel),
|
||||||
Width = Dim.Fill()
|
Width = Dim.Fill()
|
||||||
};
|
};
|
||||||
_userCountLabel = new Label("Users: 0")
|
_userCountLabel = new Label($"Users: {UsersManager.Count}")
|
||||||
{
|
{
|
||||||
X = Pos.Left(_comparisonLevelLabel),
|
X = Pos.Left(_comparisonLevelLabel),
|
||||||
Y = Pos.Bottom(_comparisonLevelLabel),
|
Y = Pos.Bottom(_comparisonLevelLabel),
|
||||||
Width = Dim.Fill()
|
Width = Dim.Fill()
|
||||||
};
|
};
|
||||||
|
|
||||||
var userCountButton = new Button("Query _User Count")
|
var manageUsersButton = new Button("_Manage Users")
|
||||||
{
|
{
|
||||||
X = Pos.Center(),
|
X = Pos.Center(),
|
||||||
Y = 7
|
Y = 7
|
||||||
};
|
};
|
||||||
userCountButton.Clicked += UserCountButton_Clicked;
|
manageUsersButton.Clicked += ManageUsersButton_Clicked;
|
||||||
|
|
||||||
var readFingerprintButton = new Button("_Read Fingerprint")
|
var addUserButton = new Button("_Add User")
|
||||||
{
|
{
|
||||||
X = Pos.Center(),
|
X = Pos.Center(),
|
||||||
Y = Pos.Bottom(userCountButton) + 1
|
Y = Pos.Bottom(manageUsersButton) + 1
|
||||||
};
|
};
|
||||||
readFingerprintButton.Clicked += ReadFingerprintButton_Clicked;
|
addUserButton.Clicked += AddUserButton_Clicked;
|
||||||
|
|
||||||
var readEigenvaluesButton = new Button("Read _Eigenvalues")
|
|
||||||
{
|
|
||||||
X = Pos.Center(),
|
|
||||||
Y = Pos.Bottom(readFingerprintButton)
|
|
||||||
};
|
|
||||||
readEigenvaluesButton.Clicked += ReadEigenvaluesButton_Clicked;
|
|
||||||
|
|
||||||
var readImageButton = new Button("Read _Image")
|
|
||||||
{
|
|
||||||
X = Pos.Center(),
|
|
||||||
Y = Pos.Bottom(readEigenvaluesButton)
|
|
||||||
};
|
|
||||||
readImageButton.Clicked += ReadImageButton_Clicked;
|
|
||||||
|
|
||||||
var addFingerprintButton = new Button("_Add Fingerprint")
|
|
||||||
{
|
|
||||||
X = Pos.Center(),
|
|
||||||
Y = Pos.Bottom(readImageButton) + 1
|
|
||||||
};
|
|
||||||
addFingerprintButton.Clicked += AddFingerprintButton_Clicked;
|
|
||||||
|
|
||||||
var deleteAFingerprint = new Button("_Delete a Fingerprint")
|
|
||||||
{
|
|
||||||
X = Pos.Center(),
|
|
||||||
Y = Pos.Bottom(addFingerprintButton)
|
|
||||||
};
|
|
||||||
deleteAFingerprint.Clicked += DeleteAFingerprint_Clicked;
|
|
||||||
|
|
||||||
var clearFingerprintsButton = new Button("_Clear Fingerprints")
|
|
||||||
{
|
|
||||||
X = Pos.Center(),
|
|
||||||
Y = Pos.Bottom(deleteAFingerprint)
|
|
||||||
};
|
|
||||||
clearFingerprintsButton.Clicked += ClearFingerprintsButton_Clicked;
|
|
||||||
|
|
||||||
var setComparisonLevelButton = new Button("Set Comparison _Level")
|
var setComparisonLevelButton = new Button("Set Comparison _Level")
|
||||||
{
|
{
|
||||||
X = Pos.Center(),
|
X = Pos.Center(),
|
||||||
Y = Pos.Bottom(clearFingerprintsButton) + 1
|
Y = Pos.Bottom(addUserButton) + 1
|
||||||
};
|
};
|
||||||
setComparisonLevelButton.Clicked += SetComparisonLevelButton_Clicked;
|
setComparisonLevelButton.Clicked += SetComparisonLevelButton_Clicked;
|
||||||
|
|
||||||
var sleepButton = new Button("_Sleep Mode")
|
|
||||||
{
|
|
||||||
X = Pos.Center(),
|
|
||||||
Y = Pos.Bottom(setComparisonLevelButton) + 1
|
|
||||||
};
|
|
||||||
sleepButton.Clicked += SleepButton_Clicked;
|
|
||||||
|
|
||||||
var quitButton = new Button("_Quit")
|
var quitButton = new Button("_Quit")
|
||||||
{
|
{
|
||||||
X = Pos.Center(),
|
X = Pos.Center(),
|
||||||
@@ -149,15 +110,9 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
_serialPortLabel,
|
_serialPortLabel,
|
||||||
_comparisonLevelLabel,
|
_comparisonLevelLabel,
|
||||||
_userCountLabel,
|
_userCountLabel,
|
||||||
userCountButton,
|
manageUsersButton,
|
||||||
readFingerprintButton,
|
addUserButton,
|
||||||
readEigenvaluesButton,
|
|
||||||
readImageButton,
|
|
||||||
addFingerprintButton,
|
|
||||||
deleteAFingerprint,
|
|
||||||
clearFingerprintsButton,
|
|
||||||
setComparisonLevelButton,
|
setComparisonLevelButton,
|
||||||
sleepButton,
|
|
||||||
quitButton
|
quitButton
|
||||||
);
|
);
|
||||||
|
|
||||||
@@ -167,7 +122,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
Application.Run(new SettingsDisplay());
|
Application.Run(new SettingsDisplay());
|
||||||
}
|
}
|
||||||
|
|
||||||
InitSensor();
|
Provider.InitSensor();
|
||||||
|
|
||||||
// Update gui
|
// Update gui
|
||||||
UpdateSerialPort();
|
UpdateSerialPort();
|
||||||
@@ -177,97 +132,27 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
|
|
||||||
private void UpdateSerialPort()
|
private void UpdateSerialPort()
|
||||||
{
|
{
|
||||||
_serialPortLabel.Text = $"Serial Port: {_fingerprintSensor.PortName}";
|
_serialPortLabel.Text = $"Serial Port: {FingerprintSensor.PortName}";
|
||||||
}
|
|
||||||
|
|
||||||
private void InitSensor()
|
|
||||||
{
|
|
||||||
_fingerprintSensor = new FingerprintSensor(File.ReadAllText(SettingsFilePath));
|
|
||||||
|
|
||||||
_fingerprintSensor.Start();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void UpdateUserCount()
|
private void UpdateUserCount()
|
||||||
{
|
{
|
||||||
if (_fingerprintSensor.TryGetUserCount(out ushort count))
|
_userCountLabel.Text = $"Users: {UsersManager.Count}";
|
||||||
{
|
|
||||||
_userCountLabel.Text = $"Users: {count}";
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void UpdateComparisonLevel()
|
private void UpdateComparisonLevel()
|
||||||
{
|
{
|
||||||
if (_fingerprintSensor.TryGetComparisonLevel(out byte comparisonLevel))
|
if (FingerprintSensor.TryGetComparisonLevel(out byte comparisonLevel))
|
||||||
{
|
{
|
||||||
_comparisonLevelLabel.Text = $"Comparison Level: {comparisonLevel}";
|
_comparisonLevelLabel.Text = $"Comparison Level: {comparisonLevel}";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ReadImageButton_Clicked()
|
|
||||||
{
|
|
||||||
var dialog = new FingerprintDialog("Acquire Image", "Can't acquire image, try to place your finger flat on the sensor");
|
|
||||||
byte[] image = null;
|
|
||||||
|
|
||||||
Task.Run(() =>
|
|
||||||
{
|
|
||||||
if (_fingerprintSensor.TryAcquireImage(out image))
|
|
||||||
{
|
|
||||||
dialog.Cancel();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
dialog.CancelAndShowError();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
dialog.Show();
|
|
||||||
|
|
||||||
if (image != null)
|
|
||||||
{
|
|
||||||
WriteOut($"Image:\n{Utils.ArrayDisplay(image)}\n\n\n");
|
|
||||||
|
|
||||||
var window = new DataDisplay("Image", image.ToArray());
|
|
||||||
|
|
||||||
Application.Run(window);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ReadEigenvaluesButton_Clicked()
|
|
||||||
{
|
|
||||||
var dialog = new FingerprintDialog("Acquire Eigenvalues", "Can't acquire eigenvalues, try to place your finger flat on the sensor");
|
|
||||||
byte[] eigenvalues = null;
|
|
||||||
|
|
||||||
Task.Run(() =>
|
|
||||||
{
|
|
||||||
if (_fingerprintSensor.TryAcquireEigenvalues(out var values))
|
|
||||||
{
|
|
||||||
eigenvalues = values.ToArray();
|
|
||||||
|
|
||||||
dialog.Cancel();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
dialog.CancelAndShowError();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
dialog.Show();
|
|
||||||
|
|
||||||
if (eigenvalues != null)
|
|
||||||
{
|
|
||||||
var window = new DataDisplay("Eigenvalues", eigenvalues);
|
|
||||||
|
|
||||||
WriteOut($"Eigenvalues:\n{Utils.ArrayDisplay(eigenvalues)}\n\n\n");
|
|
||||||
|
|
||||||
Application.Run(window);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SetComparisonLevelButton_Clicked()
|
private void SetComparisonLevelButton_Clicked()
|
||||||
{
|
{
|
||||||
if (new EntryDialog("Comparison Level", i => int.TryParse(i.ToString(), out var n) && n > 0 && n < 10, "Need to be a valid number in 0-9 range").TryShow(out var input))
|
if (new EntryDialog("Comparison Level", i => int.TryParse(i.ToString(), out var n) && n > 0 && n < 10, "Need to be a valid number in 0-9 range").TryShow(out var input))
|
||||||
{
|
{
|
||||||
if (!_fingerprintSensor.TrySetComparisonLevel(byte.Parse(input.ToString())))
|
if (!FingerprintSensor.TrySetComparisonLevel(byte.Parse(input.ToString())))
|
||||||
{
|
{
|
||||||
MessageBox.ErrorQuery("Comparison Level", "Can't set comparison level", "Ok");
|
MessageBox.ErrorQuery("Comparison Level", "Can't set comparison level", "Ok");
|
||||||
}
|
}
|
||||||
@@ -276,35 +161,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
UpdateComparisonLevel();
|
UpdateComparisonLevel();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void DeleteAFingerprint_Clicked()
|
private void AddUserButton_Clicked()
|
||||||
{
|
|
||||||
if (new EntryDialog("User id", i => int.TryParse(i.ToString(), out var n), "Need to be a valid user id").TryShow(out var input))
|
|
||||||
{
|
|
||||||
if (!_fingerprintSensor.DeleteUser(ushort.Parse(input.ToString())))
|
|
||||||
{
|
|
||||||
MessageBox.ErrorQuery("Delete User", "Can't delete user, check user id", "Ok");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
UpdateUserCount();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void SleepButton_Clicked()
|
|
||||||
{
|
|
||||||
var window = new SleepDisplay(_fingerprintSensor);
|
|
||||||
|
|
||||||
Application.Run(window);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ClearFingerprintsButton_Clicked()
|
|
||||||
{
|
|
||||||
if (!_fingerprintSensor.DeleteAllUsers())
|
|
||||||
{
|
|
||||||
MessageBox.ErrorQuery("Delete All Users", "Can't delete all user", "Ok");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void AddFingerprintButton_Clicked()
|
|
||||||
{
|
{
|
||||||
if (new EntryDialog("User id", i => ushort.TryParse(i.ToString(), out var n), "Need to be a valid user id").TryShow(out var input))
|
if (new EntryDialog("User id", i => ushort.TryParse(i.ToString(), out var n), "Need to be a valid user id").TryShow(out var input))
|
||||||
{
|
{
|
||||||
@@ -312,7 +169,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
|
|
||||||
Task.Run(() =>
|
Task.Run(() =>
|
||||||
{
|
{
|
||||||
switch (_fingerprintSensor.AddFingerprint(ushort.Parse(input.ToString()), UserPermission.Level1))
|
switch (FingerprintSensor.AddFingerprint(ushort.Parse(input.ToString()), UserPermission.Level1))
|
||||||
{
|
{
|
||||||
case ResponseType.Success:
|
case ResponseType.Success:
|
||||||
dialog.Cancel();
|
dialog.Cancel();
|
||||||
@@ -356,7 +213,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void ReadFingerprintButton_Clicked()
|
private void ManageUsersButton_Clicked()
|
||||||
{
|
{
|
||||||
var dialog = new FingerprintDialog("Read Fingerprint", "Can't read fingerprint, try to place your finger flat on the sensor");
|
var dialog = new FingerprintDialog("Read Fingerprint", "Can't read fingerprint, try to place your finger flat on the sensor");
|
||||||
|
|
||||||
@@ -364,7 +221,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
|
|
||||||
Task.Run(() =>
|
Task.Run(() =>
|
||||||
{
|
{
|
||||||
if (_fingerprintSensor.TryComparison1N(out userInfo))
|
if (FingerprintSensor.TryComparison1N(out userInfo))
|
||||||
{
|
{
|
||||||
dialog.Cancel();
|
dialog.Cancel();
|
||||||
}
|
}
|
||||||
@@ -382,28 +239,13 @@ namespace WaveshareUARTFingerprintSensor.Sample
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void UserCountButton_Clicked()
|
|
||||||
{
|
|
||||||
UpdateUserCount();
|
|
||||||
}
|
|
||||||
private void WriteOut(string text)
|
|
||||||
{
|
|
||||||
Task.Run(() =>
|
|
||||||
{
|
|
||||||
lock (_outputFileLock)
|
|
||||||
{
|
|
||||||
File.AppendAllText(OutputFilePath, text);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private void ChangeConfig()
|
private void ChangeConfig()
|
||||||
{
|
{
|
||||||
File.Delete(SettingsFilePath);
|
File.Delete(SettingsFilePath);
|
||||||
|
|
||||||
Application.Run(new SettingsDisplay());
|
Application.Run(new SettingsDisplay());
|
||||||
|
|
||||||
InitSensor();
|
Provider.InitSensor();
|
||||||
|
|
||||||
UpdateSerialPort();
|
UpdateSerialPort();
|
||||||
}
|
}
|
||||||
43
WaveshareUARTProvider.cs
Normal file
43
WaveshareUARTProvider.cs
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
using Akari.Provider.WaveshareUART.Users;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using WaveshareUARTFingerprintSensor;
|
||||||
|
|
||||||
|
namespace Akari.Provider.WaveshareUART
|
||||||
|
{
|
||||||
|
public class WaveshareUARTProvider
|
||||||
|
{
|
||||||
|
public const string SettingsFilePath = "settings.txt";
|
||||||
|
|
||||||
|
public static WaveshareUARTProvider Instance { get; }
|
||||||
|
|
||||||
|
static WaveshareUARTProvider()
|
||||||
|
{
|
||||||
|
Instance = new WaveshareUARTProvider();
|
||||||
|
}
|
||||||
|
|
||||||
|
public UsersManager UsersManager { get; }
|
||||||
|
public FingerprintSensor FingerprintSensor { get; private set; }
|
||||||
|
|
||||||
|
private WaveshareUARTProvider()
|
||||||
|
{
|
||||||
|
UsersManager = new UsersManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void InitSensor()
|
||||||
|
{
|
||||||
|
FingerprintSensor = new FingerprintSensor(File.ReadAllText(SettingsFilePath));
|
||||||
|
|
||||||
|
FingerprintSensor.Start();
|
||||||
|
}
|
||||||
|
|
||||||
|
internal void FingerprintLoop()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -15,4 +15,5 @@
|
|||||||
<package id="Unosquare.Swan.Lite" version="3.0.0" targetFramework="net472" />
|
<package id="Unosquare.Swan.Lite" version="3.0.0" targetFramework="net472" />
|
||||||
<package id="Unosquare.WiringPi" version="0.5.1" targetFramework="net472" />
|
<package id="Unosquare.WiringPi" version="0.5.1" targetFramework="net472" />
|
||||||
<package id="WaveshareUARTFingerprintSensor" version="1.0.0" targetFramework="net472" />
|
<package id="WaveshareUARTFingerprintSensor" version="1.0.0" targetFramework="net472" />
|
||||||
|
<package id="YamlDotNet" version="9.1.4" targetFramework="net472" />
|
||||||
</packages>
|
</packages>
|
||||||
Reference in New Issue
Block a user