Skip to content

Commit

Permalink
Readme in Chinese
Browse files Browse the repository at this point in the history
  • Loading branch information
whowechina committed Feb 25, 2024
1 parent 5d32790 commit 8ee584a
Show file tree
Hide file tree
Showing 2 changed files with 145 additions and 4 deletions.
10 changes: 6 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,16 +3,18 @@
<img src="doc/main.jpg" width="80%">
<img src="doc/assembled.jpg" width="80%">

Features:
[看不懂英文的,这里是中文版指南](README_CN.md)

**Features:**
* Made with a 15.6 inch portable screen.
* Arcade-like experience.
* Dual-player is possible.
* 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).
Thanks to many respectful guys/companies who made their tools or materials free or open source (KiCad, OnShape, InkScape, Raspberry things, JLCPCB).

## Notes
This project is the most complex one.
This project is the most complex one among all my projects.
* It needs a custom etched ITO glass and a portable display.
* Heavily depends on 3D printing.
* Requires skills to solder tiny components.
Expand Down Expand Up @@ -48,12 +50,12 @@ It's CC-NC. So DIY for yourself and for your friend, don't make money from it.
Becareful of 3 pins that are at the other side, they're difficult to solder and may leave air bubbles.
<img src="doc/solder_usb_txrx.jpg" width="60%">
* 1x USB Type-C socket (918-418K2023S40001 or KH-TYPE-C-16P)
* 2x 0603 5.1kohm resistors (R20, R21) for USB. If you plan to use the native USB socket on the Pi Pico directly, then the Type-C socket and resistors can be omitted, making the soldering much simpler.
* 3x MPR121 modules, there're many types in the market, choose ones like this.
https://www.sparkfun.com/products/retired/9695
Before solder MP121 module to the main PCB board, remember to **cut (unshort) the ADDR pin** which is short by default.
<img src="doc/mpr121_cut.png" width="40%">
* Leave U5, U6, U7 area discrete components empty as we're using MPR121 module, not the chip.
* 2x 0603 5.1kohm resistors (R20, R21) for USB.
* 1x SN74LV1T34DBVR (SOT-23-5) level shifter (U8), if you can't find one, use a 0603 10ohm resistor (R4) as an alternative.
https://www.lcsc.com/product-detail/Buffer-Driver-Transceiver_Texas-Instruments-SN74LV1T34DBVR_C100024.html
* 4x 0603 1uF (0.1~1uF all fine) capacitors (C1, C2, C3, C7), OPTIONAL, recommended.
Expand Down
139 changes: 139 additions & 0 deletions README_CN.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,139 @@
# Mai Pico - Maimai 风格的迷你控制器

<img src="doc/main.jpg" width="80%">
<img src="doc/assembled.jpg" width="80%">

[Here's the English version of this guide.](README.md)

为了省事,本文档是我从原先英文版翻译回中文的,高度依赖了 GitHub Copilot (GPT),所以语气可能怪怪的,见谅。

**特性:**
* 使用 15.6 英寸的便携式屏幕制作。
* 类似街机的体验。
* 可以双人游戏。
* 所有源文件开放。

感谢许多尊敬的爱好者和公司将他们的工具或材料免费或开源(KiCad,OnShape,InkScape,Raspberry 相关工具, 嘉立创)。

## 注意事项
这个项目是我众多项目里最复杂的一个。
* 它需要定制蚀刻的 ITO 玻璃和便携式显示器。
* 严重依赖 3D 打印。
* 需要焊接微小组件的技能。
* 需要许多其他 DIY 动手技能。
* IO PCB 仍处于原型状态,它可以工作,但布局和连接器并不完美。您可能需要直接从 Pi Pico 的引脚焊接。我太懒了,原型之后就没有做新版本。
* 我没有设计外壳,需要你自己来设计,让它看起来漂亮且结构稳定,发挥你的想象力,跟随你的品味。

## 查看我的其他项目
你也可以查看我其他的酷炫项目。

<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.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

## **声明** ##
我在个人时间内制作了这个项目,没有任何经济利益或赞助。我将继续改进这个项目。我已尽我所能确保所有内容的准确性和功能性,但总有可能出现错误。如果你因使用这个开源项目而造成时间或金钱的损失,我不能负责。感谢你的理解。

查看我 GitHub 主页,上面有很多其他项目。

https://github.com/whowechina/

## 关于许可证
它是 CC-NC 授权。所以你只能给自己和你的朋友 DIY,不能利用这个项目赚钱。

## 如何构建
### PCB
* 去 JLCPCB 并使用 gerber zip 文件(最新的 `Production\PCB\mai_io_v*.zip``Production\PCB\mai_button_v*.zip`)下单,常规 FR-4 板,厚度 1.6mm。你需要 1x io PCB 和 8x 按钮 PCBs 来构建一个 Mai Pico con。
<img src="doc/pcbs.jpg" width="50%">
* 1x Raspberry Pico Pi Pico 或 Pico W。
https://www.raspberrypi.com/products/raspberry-pi-pico

注意另一侧的 3 个引脚,它们很难焊接,可能会留下气泡。
<img src="doc/solder_usb_txrx.jpg" width="60%">
* 1x USB Type-C 插座(918-418K2023S40001 或 KH-TYPE-C-16P)
* 2x 0603 5.1kohm 电阻(R20,R21)用于 USB,如果你打算直接使用 Pi Pico 上面原生的 USB 插座,那么 Type-C 插座和电阻都可以省去,焊接也会简单不少。

* 3x MPR121 模块,市场上有许多类型,选择像这样的。
https://www.sparkfun.com/products/retired/9695

在将 MP121 模块焊接到主 PCB 板之前,记住**切断(断开)默认短接的 ADDR 引脚**,也要注意不要切过红线之外的区域。
<img src="doc/mpr121_cut.png" width="40%">
* 因为我们使用的是 MPR121 模块,而不是芯片,所以 U5、U6、U7 区域的离散组件留空。
* 1x SN74LV1T34DBVR(SOT-23-5)电平转换器(U8),如果你找不到,可以用 0603 10ohm 电阻(R4)替代。
https://www.lcsc.com/product-detail/Buffer-Driver-Transceiver_Texas-Instruments-SN74LV1T34DBVR_C100024.html
* 4x 0603 1uF(0.1~1uF 都可以)电容器(C1,C2,C3,C7),可选,推荐。
* 16x WS2812B-3528 RGB LED(每个按钮需要两个)。
* 8x Kailh Choc v1 键盘开关,线性的,30gf 到 45gf 的。
https://www.kailhswitch.com/mechanical-keyboard-switches/low-profile-key-switches/burnt-orange-switch.html

### ITO 玻璃
* 找一个服务定制蚀刻 ITO 镀膜玻璃。AutoCAD 文件是 `Production\CAD\mai_pico_ito_v*.dwg`。使用 2mm 厚,10-20ohm 平方电阻的 ITO 镀膜玻璃。
<img src="doc/ito_glass.jpg" width="70%">
* ITO 镀膜玻璃通过 "斑马线"(1.6mm 间距:0.8mm 黑色部分和 0.8mm 透明部分)连接到 IO PCB。使用 200°C 的硅加热头将斑马线粘贴到 PCB 的金手指部分和 ITO 镀膜玻璃上。这种线的正式名称是 "热压密封连接器"。
<img src="doc/zebra_cable.jpg" width="70%">
* 定制 ITO 镀膜玻璃相对较贵,但我们的尺寸小,所以并不像街机那么贵。这是我订购 ITO 玻璃的店铺,我订购的时候的最小批量是 5 件。据我所知,他们只在中国提供服务。我和他们店铺没有关联,此处提供链接并不表示我为他们的产品和服务负责。
https://shop378788148.taobao.com/?spm=2013.1.1000126.2.305e16c4LFf1GW

### 按键环
*`Production\3DPrint\mai_*.stl` 打印出 8 套 `底座``连接板``按钮``盖子`
* 购买 8 根 2mm(直径)* 40mm(长度)的钢轴,它们用作按钮铰链。
* 这是如何组装它们的方法,这个渲染图像中没有显示铰链轴和 PCB 上的组件。
<img src="doc/assemble.jpg" width="80%">
* 这是我如何组装环的方法。请注意,这些图片中缺少按钮开关的线路。
* 所有离散组件已准备好。
<img src="doc/assemble_1.jpg" width="60%">
* 首先焊接按钮 PCB。
<img src="doc/assemble_2.jpg" width="60%">
* PCB 使用短且柔软的 4 线电缆串联,它们是 LED_GND、LED、LED_5V 和 BUTTON_GND。BUTTON 信号引脚还没有焊接,你可以后面再焊接。请不用担心按钮 GPIOs 的顺序,因为它们可以通过命令行界面重新映射。
<img src="doc/assemble_3.jpg" width="60%">
* 你需要 3M5423 UHMW 胶带(或类似的硬且超滑的 PTFE 胶带,厚度 0.2-0.3)。它用来润滑触摸键开关的按钮表面。
<img src="doc/button_lub.jpg" width="60%">
* 将 3D 打印的部件和 PCBs 组装在一起。
<img src="doc/assemble_4.jpg" width="60%">
* 使用轴稍微扩大支撑孔,然后涂上一些键盘开关润滑剂,如 Krytox 205G0,使轴超级光滑。
<img src="doc/assemble_5.jpg" width="60%">
* 每个 `连接板` 需要 8x M2*4mm 螺丝将两个 `底座` 连接在一起。
<img src="doc/assemble_6.jpg" width="60%">
* 安装 `盖子`,每个需要 2x M2*5mm 螺丝。
<img src="doc/assemble_7.jpg" width="60%">

### 便携显示器
* 分辨率:1920*1080,尺寸:15.6 英寸,刷新率:120Hz(推荐)或 60Hz,内置扬声器。
* 它们很容易找到。选择闲鱼上有小瑕疵的会便宜得多,也一样很好用。
* 有两种类型的驱动板,一种只有 micro-HDMI,另一种支持 type-C 显示(方便连接 Nintendo Switch)。两种都可以。
https://www.amazon.com/s?k=portable+display+15.6+120hz&s=price-asc-rank&crid=1CCA2EAYLZDBE&qid=1697276847&sprefix=portable+display+15.6+120hz%2Caps%2C387&ref=sr_st_price-asc-rank&ds=v1%3AqoS0mks05q225yuL8reh50fEEBkTZ583nMPEZJwjXAk

### 粘合到一起
* 我使用 3M VHB 胶带(0.5mm 或 1mm 厚)将按钮环、ITO 玻璃和显示器粘在一起。
* 只使用一点胶带,我使用 4 小块胶带将 ITO 玻璃粘到显示器上,另外 4 小块胶带将按钮环粘到 ITO 玻璃上。
* 不要在 ITO 玻璃的走线上贴胶带,你可以在某个角度光线下看到 ITO 的走线。

### 外壳
* 设计并使其看起来漂亮是你的工作。

### 固件
* UF2 文件在 `Production\Firmware` 文件夹中。
* 对于新的构建,连接 USB 到 PC 时按住 BOOTSEL 按钮,会出现一个名为 "RPI-RP2" 的磁盘。将 UF2 固件二进制文件拖入其中。就这样。
* LED 和 Touch 协议的实现遵循 Sucareto 在 https://github.com/Sucareto/Mai2Touch 上的研究。
* 它有一个命令行进行配置。你可以使用这个 Web Serial Terminal 连接到 Mai Pico 的 USB 串口。(注意:"?" 是帮助)
https://googlechromelabs.github.io/serial-terminal/
<img src="doc/cmd.png" width="80%">
* 可以使用 `gpio` 命令重新映射按钮 GPIOs。
* 可以使用 `rgb` 命令为每个按钮分配串联的 RGB LED 数量。
* 可以通过 `level` 命令调整 LED 的亮度。
* 有 MPR121 参数调整和灵敏度设置,自己探索。
* 它实现了 3 个 COM 端口,一个用于命令行,另外两个用于 LED 和 Touch。通过向命令行发出 `whoami`,每个 COM 端口都会打印它们的身份。
* 按钮信号通过 HID Joystick 或 HID NKRO(键盘)发送到主机。有两套 NKRO 键映射,使用 `hid <joy|key1|key2>` 在它们之间切换。在 NKRO 模式下,键映射是:
* key1:`WEDCXZAQ`-按键环,`3`-Select
* key2(小键盘):`89632147`-按键环,`*`-Select
* 上述两套都有:`F1`-Test `F2`-Service `F3`-投币

## CAD 源文件
我正在使用 OnShape 的免费订阅。它很强大,但不能将原始设计存档到本地,所以我只能在这里分享链接。STL/DXF/DWG 文件是从这个在线文档导出的。
https://cad.onshape.com/documents/d8b39d27c9cb7990d9ce4d46/w/2c1baa71e391bfd1246f122b/e/f87f0f1c373fe2186ddc5c9c?renderMode=0&uiState=652a665608b4e07137e3861a

0 comments on commit 8ee584a

Please sign in to comment.