Finished for publish

This commit is contained in:
whowechina 2024-09-17 20:21:13 +08:00
parent 1e00dc8b55
commit 2a95af15e8
37 changed files with 7454 additions and 0 deletions

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
3DPrint/geki_pico_top.3mf Normal file

Binary file not shown.

BIN
3DPrint/geki_pico_top.stl Normal file

Binary file not shown.

File diff suppressed because it is too large Load Diff

Binary file not shown.

189
README.md Normal file
View File

@ -0,0 +1,189 @@
# Geki Pico - ONGEKI Style Mini Controller
[点这里可以切换到中文版](README_CN.md)
<img src="doc/main.jpg" width="80%">
Features:
* It's small but closely replicates the feel of the arcade controller.
* Smooth lever action with adjustable resistance.
* Air WAD with sound feedback.
* IO4 emulation.
* Built-in AIME card reader.
* Command line for configurations.
* All source files open.
Thanks to many respectful guys/companies who made their tools or materials free or open source (KiCad, OnShape, InkScape, Raspberry things).
Special thanks to community projects and developers.
* Robin Grosset (https://github.com/rgrosset/pico-pwm-audio)
* GEEKiDoS (https://github.com/GEEKiDoS/ongeeki-firmware)
* RP_Silicon_KiCad: https://github.com/HeadBoffin/RP_Silicon_KiCad
* Type-C: https://github.com/ai03-2725/Type-C.pretty
## Notes
You can check out my other cool projects.
<img src="https://github.com/whowechina/popn_pico/raw/main/doc/main.jpg" height="100px">
<img src="https://github.com/whowechina/iidx_pico/raw/main/doc/main.jpg" height="100px">
<img src="https://github.com/whowechina/iidx_teeny/raw/main/doc/main.jpg" height="100px">
<img src="https://github.com/whowechina/chu_pico/raw/main/doc/main.jpg" height="100px">
<img src="https://github.com/whowechina/mai_pico/raw/main/doc/main.jpg" height="100px">
<img src="https://github.com/whowechina/diva_pico/raw/main/doc/main.jpg" height="100px">
<img src="https://github.com/whowechina/aic_pico/raw/main/doc/main.gif" height="100px">
<img src="https://github.com/whowechina/groove_pico/raw/main/doc/main.gif" height="100px">
<img src="https://github.com/whowechina/geki_pico/raw/main/doc/main.jpg" height="100px">
* Popn Pico: https://github.com/whowechina/popn_pico
* IIDX Pico: https://github.com/whowechina/iidx_pico
* IIDX Teeny: https://github.com/whowechina/iidx_teeny
* Chu Pico: https://github.com/whowechina/chu_pico
* Mai Pico: https://github.com/whowechina/mai_pico
* Diva Pico: https://github.com/whowechina/diva_pico
* AIC Pico: https://github.com/whowechina/aic_pico
* Groove Pico: https://github.com/whowechina/groove_pico
* Geki Pico: https://github.com/whowechina/geki_pico
This Geki Pico project:
* Heavily depends on 3D printing, you need a 3D printer.
* Requires skills to solder tiny components.
## **Disclaimer** ##
I made this project in my personal time with no financial benefit or sponsorship. I will continue to improve the project. I have done my best to ensure that everything is accurate and functional, there's always a chance that mistakes may occur. I cannot be held responsible for any loss of your time or money that may result from using this open source project. Thank you for your understanding.
## About the License
It's CC-NC. So DIY for yourself and for your friend, don't make money from it.
## HOW TO BUILD
### PCB and Components
* Go JLCPCB and make order with the gerber zip file (latest `Production\PCB\geki_main_xxx.zip`), regular FR-4 board, black or white color, **1.6mm** thickness.
<img src="doc/pcb.jpg" width="60%">
* 1x Rasberry Pico Pi Pico or pin-to-pin compatible clones (U1).
https://www.raspberrypi.com/products/raspberry-pi-pico
* 1x USB Type-C socket (918-418K2023S40001 or KH-TYPE-C-16P)
* 24x WS2812B-4020 side-facing RGB LEDs for the circular gimbal daughter PCBs (D2-D36).
https://www.lcsc.com/product-detail/Light-Emitting-Diodes-LED_Worldsemi-WS2812B-4020_C965557.html
* 19x WS2812B-3528 RGB LEDs for the main PCB (D1, D37).
* 2x 8002A audio mini amplifier board (AMP1, AMP2), or you can use discrete components following the schematics (R4, R5, R8, R9, C9 ~ 12).
<img src="doc/8002a.jpg" width="20%">
https://www.nz-electronics.co.nz/products/4pcs-one-sell-3v-5v-supply-voltage-3w-8002-audio-player-power-amplifier-module-board-pcb-mono
https://www.ebay.com.au/itm/225481264605
* 2x VL53L0x ToF sensors with optical cover.
https://kuriosity.sg/products/time-of-flight-tof-distance-sensor-vl53l0x-200cm-with-optical-cover
https://www.smart-prototyping.com/VL53L0X-ToF-Distance-Sensor
* 2x Small speakers no larger than 20mm\*20mm\*5mm, 8ohm or close, (SPK1, SPK2), you can even harvest similar sized ones from old broken toys.
Try search on Google with keywords: "smd speaker 1540"
* 1x SS49E linear Hall sensor (U5).
https://mou.sr/4gDuQKu
https://www.digikey.com/short/fmm54dzq
* 1x Small 3V to 5V DC-DC step up or up-down converter (U6). Make sure its output is 5V and input range covers 3.3V. If the one you get has different pinout, you need to hand wire it.
https://www.dfrobot.com/product-1766.html
* 8x 0603 0.1uF (0.1~1uF all fine) capacitors (C1 to C8), OPTIONAL but strongly recommended.
* 2x 0603 5.1kohm resistors (R1, R2) for the USB.
* 1x 0603 10ohm resistor, (1-20ohm all work fine) (R3).
* 1x 0603 10kohm resistor (R6).
* 1x 0603 20kohm resistor (R7).
* 8x Kailh Choc v1 or v2 switches (2 of them must be Choc v1). Choose linear ones, such as "Red Pro" or the latest Lofree branded Ghost.
<img src="doc/choc_v1_red_pro.jpg" width="30%">
* 1x PN532 Module (the Red Square board version, cheap clones work too). It's optional, if you want a built-in card reader, then you need it.
https://www.elechouse.com/product/pn532-nfc-rfid-module-v4/
* If you're using 8002A boards, leave R4, R5, R8, R9, C9 ~ 12, U3, U4 empty.
* Leave U2 empty, it only provides placebo effect for better ADC reference voltage.
* This is how it looks after soldering. Please note that the two circular daughter PCBs are fully wired, so you can test them before cutting them off.
<img src="doc/pcb_solder_1.png" width="90%">
<img src="doc/pcb_solder_2.png" width="90%">
* Becareful of 2 pin holes. It's a common oversight to either forget to solder them or to leave air bubbles during the process. To avoid this, solder slowly from one side of the hole, using minimal solder wire and a generous amount of flux.
<img src="doc/usb_txrx_holes.png" width="40%">
### 3D Printing
* Printing parameters
* PLA or PETG.
* Layer height: 0.2mm
* Support: Yes, always.
#### Lever Parts
* Lever Base: `Production\3DPrint\geki_pico_lever_base.stl`, white.
* Lever Shaft: `Production\3DPrint\geki_pico_lever_shaft.stl`, white.
* 2x Lever Fixer: `Production\3DPrint\geki_pico_lever_fixer.stl`, white.
* Lever Handle: `Production\3DPrint\geki_pico_lever_handle.stl`, red.
#### Housing Parts
You need to rotate 135 degrees on Z axis to fit the bed.
* Housing Bottom: `Production\3DPrint\geki_pico_bottom.stl`, I chose sakura pink, what's your choice?
* Housing Support: `Production\3DPrint\geki_pico_support.stl`, semi-transparent.
* Housing Top: `Production\3DPrint\geki_pico_top.*`, white. If you have multi-color printing equipment and skill, use the 3mf one (button outlines and logo are black).
#### Button Caps
* 6x Main Button Cap: `Production\3DPrint\geki_pico_button_main_choc_*.stl`, white, print up-side down so you get nice button surface and stem. Choc v1 and v2 are different, choose the right one.
* 2x Aux Button Cap: `Production\3DPrint\geki_pico_button_aux.stl`, semi-transparent, print up-side down.
### Lever
* Required components
* PTFE or UHMW Film Tape, >=10mm wide, >=0.3mm (0.5mm is best) thick, one-side adhesive.
https://www.3m.com/3M/en_US/p/d/b40072069/
* 2x 6700zz bearings (10mm inner diameter, 15mm outer diameter, 4mm thickness).
https://www.amazon.com/Bearing-10x15x4-6700ZZ-MOCHU-Bearings/dp/B081Z6419H
* 1x Double-ended stud screws, M4 thread, 80mm length.
https://www.amazon.com/METALLIXITY-Double-Screws-Stainless-Threaded/dp/B0B7BX3CYH
* 1x **5mm\*2mm** or **5mm\*3mm** magnet, MUST be radially/diametrically magnetized (N-S poles on the curved side).
https://wargameportal.com/products/special-diametrically-magnetized-50pcs-5mm-x-2mm-3-16-x-1-16-disc-magnets?variant=49014932209942
* 6x **M2*5mm regular screws** for resistance adjustment.
* 4x **M2*16mm regular screws** for fixing the bearings.
* Optional: Some keyboard switch lubricant.
* Assemble Steps
1. Print out the parts.
<img src="doc/lever_print_1.jpg" width="40%"> <img src="doc/lever_print_2.jpg" width="40%">
2. Stick PTFE/UHMW tape to the sliding surfaces of the fixer and the shaft. Then trim the tape to match the surface shape. Turn the M2*5mm screws into the bearing fixers halfway, dont tighten it.
<img src="doc/sliding_surface_1.jpg" width="30%"> <img src="doc/sliding_surface_2.jpg" width="30%"> <img src="doc/sliding_surface_3.jpg" width="15%">
3. Install the 2 bearings on both sides of the shaft and put it in the base, then use M2*16mm screws to fix the two bearing fixers on the base.
<img src="doc/install_shaft_1.jpg" width="25%"> <img src="doc/install_shaft_2.jpg" width="25%">
4. Use some instant glue to stick the magnet to the bottom of the shaft. Make sure the poles are placed horizontally. A little trick is you connect several magnets together and draw a line to cross all the magnets, and then you know the poles.
<img src="doc/magnet_1.jpg" width="43%"> <img src="doc/magnet_2.jpg" width="30%">
5. Install the lever handle onto the double-ended stud screw, put aside. Later when the housing is ready we need to screw it into the lever shaft.
### Assembly
* Other components needed
* 4x **M3\*8mm regular screws** for fixing the lever to the bottom.
* 8x **M3\*20mm regular screws** for the housing.
* Some VHB double-sided tape to fix the speakers and the ToF sensors.
* Some thin soft wires for the speakers and the ToF sensors.
* Steps
1. Install the lever to the bottom part, using M3\*8mm screws.
2. Wire (solder) the ToF sensors to the main PCB, each needs 4 wires.
3. Use VHB tape to fix the ToF sensors on the ToF seats on the bottom part.
4. Wire (solder) the speakers to the main PCB, each needs 2 wires.
5. Use VHB tape to fix the speakers on the floor of the bottom part.
6. Install the main PCB to the bottom part, no screws needed.
7. Bend the hall-effect sensor (SS49E) so it stays on top of the lever magnets. Remember to leave a tiny gap so the shaft can move freely.
<img src="doc/lever_hall_1.jpg" width="40%"> <img src="doc/lever_hall_2.jpg" width="48%">
8. Solder the PN532 module, 8002A modules to the main PCB if you haven't done it yet.
9. Install the main button caps and the aux button caps onto the switches.
10. Now it looks like this. Please note that in the picture it is the PCB v1. I've done some optimizations in the later version.
<img src="doc/almost_done.jpg" width="80%">
11. Put the support part on the bottom part, then put the top part on the support part.
12. Align these parts and use M3\*20mm screws to fix them together. You may need to carefully adjust the position of the ToF sensors so the IR covers fit into the windows on the support part.
13. Finally screw the lever handle into the lever shaft.
<img src="doc/finally_done.jpg" width="80%">
### Firmware
* UF2 file is in `Production\Firmware` folder.
* For the new build, hold the BOOTSEL button while connect the USB to a PC, there will be a disk named "RPI-RP2" showed up. Drag the UF2 firmware binary file into it. That's it. There's a small hole at the bottom side of the Geki Pico, it is facing right to the BOOTSEL button.
* If it's already running Geki Pico firmware, you can either use "update" in command line or hold down at least 4 buttons while connecting to USB to enter update mode.
* To access the command line, you can use this Web Serial Terminal to connect to the USB serial port of the Geki Pico. (Note: "?" is for help)
https://googlechromelabs.github.io/serial-terminal/
* **NOTE:** You need to calibrate the lever by "lever calibrate" command after you flash the firmware.
## CAD Source File
I'm using OnShape free subscription. It's powerful but it can't archive original designs to local, so I can only share the link here. STL/DXF/DWG files are exported from this online document.
https://cad.onshape.com/documents/eb38f3add988969c42b50060/w/86bcbeae8562f01c1a81c53e/e/feecb6f371a076c968584d3c

6
README_CN.md Normal file
View File

@ -0,0 +1,6 @@
# Groove Pico - 节奏过山车风格的迷你控制器
[Click here for the English version of this guide.](README.md)
<img src="doc/main.jpg" width="80%">
别急,还在吭哧吭哧写呢。

BIN
doc/8002a.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

BIN
doc/almost_done.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 655 KiB

BIN
doc/anti_slip_pads.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 363 KiB

BIN
doc/choc_v1_red_pro.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 396 KiB

BIN
doc/damper_grease_1.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 580 KiB

BIN
doc/finally_done.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 655 KiB

BIN
doc/install_shaft_1.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 138 KiB

BIN
doc/install_shaft_2.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 425 KiB

BIN
doc/lever_hall_1.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 311 KiB

BIN
doc/lever_hall_2.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 191 KiB

BIN
doc/lever_print_1.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 570 KiB

BIN
doc/lever_print_2.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 538 KiB

BIN
doc/magnet_1.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

BIN
doc/magnet_2.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

BIN
doc/main.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 832 KiB

BIN
doc/pcb.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 719 KiB

BIN
doc/pcb_solder_1.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 719 KiB

BIN
doc/pcb_solder_2.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 728 KiB

BIN
doc/sliding_surface_1.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 696 KiB

BIN
doc/sliding_surface_2.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 426 KiB

BIN
doc/sliding_surface_3.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 245 KiB

BIN
doc/usb_txrx_holes.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 196 KiB