• Stars
    star
    273
  • Rank 150,780 (Top 3 %)
  • Language
    Python
  • License
    MIT License
  • Created over 10 years ago
  • Updated about 5 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

虚拟蓝牙键盘(BlueTooth Keyboard)

btk

蓝牙虚拟键盘

缘起

我本人是键盘党,喜欢快捷键。我又是程序员,需要疯狂地敲代码。我还是iPad的粉丝,一边敲代码,一边用iPad看文档。问题来了,看文档的时候手因为要操作iPad而不得不离开键盘,这让我感到绝望。所以我就一直在想,能不能使用PC的键盘控制iPad呢?答案是肯定的,因为我已经实现了。并非所有能达到目的的方案都可以,我认为合理的方案应该满足以下需求:

  1. iPad无需越狱
  2. iPad无需安装程序
  3. 支持Arch Linux

我没有苹果开发者帐号,也不会开发iOS程序,所以规定了第二条。另一方面,第二条也提高了系统易用性。

我是Arch Linux的粉丝。Arch滚动发布,升级比较快,系统的各个软件版本都很新。所以合理的方案应该兼容最新的系统。

想来想去,也就只有蓝牙键盘能够满足以上要求了。也就是说,我们使用蓝牙协议将电脑虚拟成一个蓝牙HID输入设备。这样iPad就会自动识别我们的电脑了。

要想实现一个蓝牙键盘,需要做以下工作:

  • 学习蓝牙HIDP协议栈
  • 学习Linux系统下的蓝牙编程技术

HIDP协议栈全文可以从蓝牙官网下载到,但是是英文的,啃吧。而Linux下的蓝牙协议栈是BlueZ,最新的版本则是5.x。BlueZ对外提供DBus接口,所以还得研究以下DBus编程规范。

另一方面,我们从来都不是一个人在战斗。前人在相关领域已经有了丰富的研究成果。本项目主要参考了两个项目,一个是btkbdd,另一个则是PiTooth。我借鉴了PiTooth读取系统键盘事件的实现(evdev),直接借用了PiTooth的sdp定义文件和键盘映射文件。而btkbdd项目则提供关于iPad相关的珍贵细节问题,为我节省了不少时间。当然了,这两个项目都比较古老,无法适应Arch Linux系统,其中的根本原因是BlueZ进入5.x版本后放弃了前向兼容。我使用Python,充分利用BlueZ的新接口,提供了蓝牙键盘的一种简单实现。

到目前为止,btk可以与iPad和安卓手机正常配合工作,但仍然有一些问题:

  • 无法支持多设备连接
  • 无法很优雅地处理设备断掉连接的情况
  • 主程序不支持配置选项
  • 不支持systemd集成

我希望通过开源,可以将对此项目感兴趣的朋友聚集到一起,让此方案的功能不断完善。

体验方法

系统要求如下:

首先,运行脚本:

sudo python agent.py

然后使用手机搜索蓝牙,找到你的主机点击配对。这时agent.py脚本会提示你输入配对码。直接输入并回车即可开启体验之旅。

键鼠HID报告描述符

以下是一个具有键盘和鼠标功能的HID描述符,具体参见USB HID协议。

0x05, 0x01, // UsagePage GenericDesktop
0x09, 0x02, // Usage Mouse
0xA1, 0x01, // Collection Application
0x85, 0x01, // REPORT ID: 1
0x09, 0x01, // Usage Pointer
0xA1, 0x00, // Collection Physical
0x05, 0x09, // UsagePage Buttons
0x19, 0x01, // UsageMinimum 1
0x29, 0x03, // UsageMaximum 3
0x15, 0x00, // LogicalMinimum 0
0x25, 0x01, // LogicalMaximum 1
0x75, 0x01, // ReportSize 1
0x95, 0x03, // ReportCount 3
0x81, 0x02, // Input data variable absolute
0x75, 0x05, // ReportSize 5
0x95, 0x01, // ReportCount 1
0x81, 0x01, // InputConstant (padding)
0x05, 0x01, // UsagePage GenericDesktop
0x09, 0x30, // Usage X
0x09, 0x31, // Usage Y
0x09, 0x38, // Usage ScrollWheel
0x15, 0x81, // LogicalMinimum -127
0x25, 0x7F, // LogicalMaximum +127
0x75, 0x08, // ReportSize 8
0x95, 0x02, // ReportCount 3
0x81, 0x06, // Input data variable relative
0xC0, 0xC0, // EndCollection EndCollection
0x05, 0x01, // UsagePage GenericDesktop
0x09, 0x06, // Usage Keyboard
0xA1, 0x01, // Collection Application
0x85, 0x02, // REPORT ID: 2
0xA1, 0x00, // Collection Physical
0x05, 0x07, // UsagePage Keyboard
0x19, 0xE0, // UsageMinimum 224
0x29, 0xE7, // UsageMaximum 231
0x15, 0x00, // LogicalMinimum 0
0x25, 0x01, // LogicalMaximum 1
0x75, 0x01, // ReportSize 1
0x95, 0x08, // ReportCount 8
0x81, 0x02, // **Input data variable absolute
0x95, 0x08, // ReportCount 8
0x75, 0x08, // ReportSize 8
0x15, 0x00, // LogicalMinimum 0
0x25, 0x65, // LogicalMaximum 101
0x05, 0x07, // UsagePage Keycodes
0x19, 0x00, // UsageMinimum 0
0x29, 0x65, // UsageMaximum 101
0x81, 0x00, // **Input DataArray
0xC0, 0xC0, // EndCollection

摘自Python编程.Bluetooth HID Mouse and Keyboard(一)

将以上描述符去掉0x,和注释,拼成一行放入HID描述xml文件的HID Descriptor属性即可。

More Repositories

1

geohash

simple php geohash class
PHP
76
star
2

vim

Taoso's vimrc
Lua
61
star
3

tagbar-markdown

vim-tagbar extension for markdown
PHP
47
star
4

led

led - lehu daemon
Go
38
star
5

nvim

Lv's vim conf
Vim Script
35
star
6

webfeed

WebFeed Extension
JavaScript
27
star
7

protoc-gen-grpc-php

protoc grpc plugin for PHP
PHP
27
star
8

dtun

simple ip tunnel based on dtls
Go
25
star
9

zns

ZNS - Simple DoH server in Go
JavaScript
22
star
10

nginx-websocket-module

make nginx as websocket server
C
22
star
11

utun

UDP Tunnel
Go
14
star
12

lehu

Shell
13
star
13

jaeger-php

jaeger php client for OpenTracing API
PHP
12
star
14

mru.vim

Most Recently Used File List for Vim/NeoVim
Vim Script
12
star
15

txtimg

convert text to image
Go
11
star
16

phpfold.vim

vim fold plugin according php ast
PHP
10
star
17

php-alipay

alipay wireless sdk php backend
PHP
9
star
18

tlstunnel

tls tunnel
Go
9
star
19

fzf.vim

Vim Script
8
star
20

fzf-mru.vim

FZF MRU(Most Recently Used) File List Vim/NeoVim Plugin
Vim Script
8
star
21

sfile

simple http file server
Go
7
star
22

jw-hls

hsl plugin for jw player
ActionScript
6
star
23

msgpack-rpc

PHP
4
star
24

php-coroutine

Extension for php coroutine.
C
4
star
25

kbmice

基于键盘的鼠标模拟程序
Python
4
star
26

makedown

Makefile for Markdown Blogging
Smarty
3
star
27

poj

PKU Judge Online
C
2
star
28

nginx-stream-echo

nginx stream echo module
C
2
star
29

webp2p

WebP2P
JavaScript
2
star
30

protobuf-php

protobuf php sdk mirror
PHP
2
star
31

hello-dbus

Python
2
star
32

phpstan

PHP
2
star
33

hello-envoy

1
star
34

lbs.js

lbs powered by node.js
JavaScript
1
star
35

tinycrud

tiny tool for CRUD operations
PHP
1
star
36

php-ev

libev extension for php
C
1
star
37

tini_autovirtualenv

bash helper to auto active python virtualenv, works well under tmux
1
star
38

vim-mpc

vim mpc plugin
Vim Script
1
star
39

tinypy

tiny pinyin input tool
C++
1
star
40

l.js

JavaScript
1
star
41

moveit.vim

Vim Script
1
star
42

jaeger-idl

1
star
43

ag.vim

simple plugin for ag/rg
Vim Script
1
star
44

dngwp

Designing Next Generation Web Projects with CSS3
1
star
45

iH5

Tiny Demos for HTML5
1
star
46

php-misc

Miscellaneous for PHP
PHP
1
star
47

hello-blade

PHP
1
star
48

php-ns-quirk

PHP 名称空间的奇怪行为
PHP
1
star
49

spa

Single Page Application
JavaScript
1
star
50

php-aho

A php extension for the multifast's Aho–Corasick algorithm. Only Support PHP 7.
C
1
star
51

lbs

PHP
1
star
52

gitconf

git configuration
1
star
53

php-kv

php kev-value store
PHP
1
star
54

mithril-redux-demo

A minimal demo for redux using redux, es6, webpack.
JavaScript
1
star
55

tmux

Lv's tmux configuration
1
star
56

eth-finder

JavaScript
1
star
57

udplog

syslog udp client for php
PHP
1
star
58

un

UNotice
Java
1
star
59

tinypage

tiny template engine for php
PHP
1
star
60

tinyconfig

tiny config tool for php
PHP
1
star
61

apns

Go APNS Client using the http2 API
Go
1
star