Go to file
LeapwardKoex db5e3c5903 Merge branch 'master' of https://github.com/Leapward-Koex/MaiTouchSensorEmulator 2024-02-13 22:40:19 +13:00
.github/workflows Update dotnet-desktop.yml 2024-02-10 11:09:43 +13:00
Assets/Images Properly include image assets 2024-02-09 16:36:17 +13:00
Properties Handle installing/uninstalling COM ports when not running as admin. 2024-02-10 12:47:46 +13:00
assets Properly include image assets 2024-02-09 16:36:17 +13:00
thirdparty programs/com0com Add delay when dragging finger across multiple buttons 2024-02-09 17:10:08 +13:00
.gitattributes Add .gitattributes, .gitignore, and README.md. 2024-02-08 17:41:20 +13:00
.gitignore Add .gitattributes, .gitignore, and README.md. 2024-02-08 17:41:20 +13:00
App.config Handle installing/uninstalling COM ports when not running as admin. 2024-02-10 12:47:46 +13:00
App.xaml Add project files. 2024-02-08 17:41:21 +13:00
App.xaml.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
AssemblyInfo.cs Add project files. 2024-02-08 17:41:21 +13:00
DumpCreator.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
LICENSE Create LICENSE 2024-02-10 13:27:15 +13:00
Logger.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
MaiTouchComConnector.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
MaiTouchSensorButtonStateManager.cs Properly include image assets 2024-02-09 16:36:17 +13:00
MainWindow.xaml UX improvements 2024-02-10 12:58:13 +13:00
MainWindow.xaml.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
MainWindowViewModel.cs Implement automatic connecting loop 2024-02-08 22:55:04 +13:00
README.md Update README.md 2024-02-11 23:37:05 +13:00
TouchPanel.xaml Add delay when dragging finger across multiple buttons 2024-02-09 17:10:08 +13:00
TouchPanel.xaml.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
TouchPanelPositionManager.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
VirtualComPortManager.cs Add minidump generation, more error handling and logging 2024-02-13 22:40:12 +13:00
VisualTreeHelperExtensions.cs Code tidy up 2024-02-08 23:02:54 +13:00
WpfMaiTouchEmulator.csproj Add delay when dragging finger across multiple buttons 2024-02-09 17:10:08 +13:00
WpfMaiTouchEmulator.sln Add project files. 2024-02-08 17:41:21 +13:00

README.md

WpfMaiTouchEmulator

A WPF C# app meant to emulate the touch sensor hardware for SDEZ MaiMai using software on a touchscreen.

How it works

The app uses com0com to install a virtual COM port pairing of COM3 - COM23. The app then connects to COM23 and emulates how the hardware touch sensor works, sending data over this port.

Demo

https://github.com/Leapward-Koex/MaiTouchSensorEmulator/assets/30615050/eea21285-fec5-4393-a75d-74274b39789f

https://github.com/Leapward-Koex/MaiTouchSensorEmulator/assets/30615050/e45ca02f-8d82-4ad4-a610-ef08abcb5087

Setup

Disable Three- and four-finger touch gestures in windows (on W11 Settings -> Bluetooth & devices -> Touch)

COM3 needs to be free for this app to work as that is the port used by SDEZ. By default most people will find that COM3 is already in use by a USB Serial device. This will need to be uninstalled via Device Manager,

  1. Open Device Manager
  2. Show hidden devices. "View" -> "Show Hidden Devices" -> "Ports (COM & LPT)" -> Right click the COM3 device and uninstall.

Set DummyTouchPanel=0 in the [AM] section of your maimai .ini file.

Open the WpfMaiTouchEmulator.exe app, Install the virtual port via the "Install COM port" button, either tick the "Automatic port connecting" for the app to connect to the COM23 port on start up or press the "Connect to port" button.

If you have issues where the app can't bind to COM23 after installing the virtual port I find that restarting my PC normally fixes it.

Start SDEZ and use your touchscreen as normal.

Installing the virtual COM ports without using the included com0com program

If you don't want to use the included install/remove virtual com actions in the app because you don't want to give admin access to this unknown app then you can achieve the same outcome by manually downloading Null-modem com0com online (version 2.2.2.0 required!) and then running this command. cd "C:\Program Files (x86)\com0com" && setupc.exe install Portname=COM3 Portname=COM23 to install the virtual port and cd "C:\Program Files (x86)\com0com" && setupc.exe uninstall to uninstall the virtual ports.

Why?

Most SDEZ don't work very will with the built in touchscreen and require either someone else to modify the SDEZ source code to get the inbuilt touch controls to work or for you to edit and recompile the .dll files. This app should work with all SDEZ versions (afaik) out of the box.

Another reason is sourcing a ITO etched panel for use as a touch sensor can be difficult and reasonable expensive.

Performance

Its ok, the app polls the touch sensor window at up to 1Khz but its running in C# so it may or may not actually be running at this speed, depending on the performance of the host machine.

As for accuracy. I'm not that good so I can't say how well it works at high levels of play but in my experience it works pretty well.

Thanks

Thanks to whowechina - mai_pico and Sucareto - Mai2Touch for the basic serial data format and touch implementation research.