• Stars
    star
    284
  • Rank 144,669 (Top 3 %)
  • Language
    C
  • License
    Apache License 2.0
  • Created over 3 years ago
  • Updated 4 months ago

Reviews

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

Repository Details

Show keys you typed on screen.

Show Me The Key

Show keys you typed on screen.

Project Website

A SUSE Hack Week 20 Project: Show Me The Key: A screenkey alternative that works under Wayland via libinput.

Install

Distribution Package (Recommanded)

AOSC OS

Just run following command to install from offcial repository:

# apt install showmethekey

Arch Linux

Install From AUR

$ yay showmethekey

Or use other AUR helpers.

Install From archlinuxcn

First add archlinuxcn repo to your system.

# pacman -S showmethekey

openSUSE

Install from OBS

Packages can be found in my OBS project.

# zypper ar https://download.opensuse.org/repositories/home:/AZhou/openSUSE_Tumbleweed/home:AZhou.repo
# zypper in showmethekey showmethekey-lang

Leap users please replace URL for Tumbleweed with URL for your Leap version.

Other Distributions

Please help package showmethekey to your distribution!

Build From Source

Dependencies

  • libevdev
  • udev (or systemd)
  • libinput
  • glib2
  • gtk4
  • libadwaita
  • json-glib
  • cairo
  • pango
  • libxkbcommon
  • polkit
  • meson
  • ninja
  • gcc

Build

$ git clone https://github.com/AlynxZhou/showmethekey.git
$ cd showmethekey
$ mkdir build && cd build && meson setup --prefix=/usr . .. && meson compile && meson install
$ showmethekey-gtk

Usage

For detailed usage please run usage dialog from app menu!

You need to toggle the switch to start it manually and need to input admin password to polkit authentication agent's dialog, because we need superuser permission to read keyboard events (this program does not handle your password so it is safe). Wayland does not allow a client to set its position, so this program does not set its position in preference, and you can click the "Clickable Area" in titlebar and drag the floating window to anywhere you want.

Users in wheel group can skip password authentication.

Special Notice for Wayland Session Users

There is no official Wayland protocol allowing toplevel clients to set their own position and layer, only users can change those things. But don't worry, users are always allowed to do those things by themselves if their compositors support it.

For example if you are using GNOME Shell (Wayland), you can right click the "Clickable Area" on title bar to show a window manager menu and check "Always on Top" and "Always on Visible Workspace" in it.

If you are using KDE Plasma (Wayland), you can right click "Floating Window - Show Me The Key" on task bar, check "Move to Desktop" -> "All Desktops" and "More Actions" -> "Keep Above Others".

For Sway users, you can add following configurations into ~/.config/sway/config to enable floating and sticky (thanks to haxibami's blog post:

for_window [app_id="one.alynx.showmethekey" title="Floating Window - Show Me The Key"] {
  floating enable
  sticky enable
}

Feature

screenkey is a popular project for streamers or tutorial recorders because it can make your typing visual on screen, but it only works under X11, not Wayland because it uses X11 functions to get keyboard event.

This program, instead, reads key events via libinput directly, and then put it on screen, so it will not depend on X11 or special Wayland Compositors and will work across them.

Project Structure

CLI

This part exists because of Wayland's security policy, which means you cannot run a GUI program with sudo (see https://wiki.archlinux.org/index.php/Running_GUI_applications_as_root#Wayland). It's suggested to split your program into a GUI frontend and a CLI backend that do privileged operations, and this is the backend, a custom re-write of https://gitlab.freedesktop.org/libinput/libinput/-/blob/master/tools/libinput-debug-events.c, based on libinput, libudev and libevdev.

It generates JSON in lines like {"event_name": "KEYBOARD_KEY", "event_type": 300, "time_stamp": 39869802, "key_name": "KEY_C", "key_code": 46, "state_name": "PRESSED", "state_code": 1}.

GTK

A GUI frontend based on GTK, will run CLI backend as root via pkexec, and show a transparent floating window to display events.

FAQ

Why your program needs root permission? screenkey never asks for it!

If you debug with libinput, you'll find it needs root permission, too. Because this program support both Wayland and X11, it does not get input events via display protocol, actually it's reading directly from evdev interface under /dev. And if you want to interact with files under /dev, you need root permission. screenkey does not needs root permission because it's heavily X11-based, it gets input events from X server instead of /dev, which already done it. And because of this it will never support Wayland.

I am using Sway/Wayfire/[not DEs], and I always get AUTHENTICATION FAILED in terminal!

This is a pkexec bug that it's tty authentication does not work, see https://gitlab.freedesktop.org/polkit/polkit/-/issues/17. Most DEs have their own authentication agents, but if you are not using them, pkexec will try to make itself an agent, and you get this bug.

A possible workaround is #2 (comment), actually you can use any agents, not only the gnome one.

Translate

If you changed translatable strings, don't forget to run meson compile showmethekey-update-po in build directory and then edit po files, and please check if there are fuzzy tag in comment, you should remove them and make translation exact, otherwise it will not work.

If you added new source files with translatable strings, don't forget to add it to showmethekey-gtk/po/POTFILES.in before running meson compile showmethekey-update-po. File paths in POTFILES.in should be relative to project directory.

If you want to add languages, first add a country code in showmethekey-gtk/po/LINGUAS, then run meson compile showmethekey-update-po, you will get a new .po file with your added country code. If this language needs UTF-8 encoding, don't use words like zh_CN.UTF-8 in showmethekey-gtk/po/LINGUAS or file name, because RPM's find_lang script may ignore them sometimes, and you should change to charset=UTF-8 manually in the header.

Name

As I want some clear name that hints its usage, but screenkey is already taken and I think visualkey sounds like Visual Studio and it's horrible. My friend @LGiki suggests Show Me The Key which sounds like "Show me the code" from Linus Torvalds. At first I think it's a little bit long, but now it is acceptable so it's called showmethekey or Show Me The Key.

The Chinese translate of this program name should be 让我看键, and it's only used for window title, debug output, package name and desktop entry name should not be translated.

Icon

Program icon made by Freepik from www.flaticon.com.

More Repositories

1

gnome-shell-extension-inotch

Add a useless notch to your screen.
JavaScript
942
star
2

hexo-theme-aria

A Hexo theme inspired by Kalafina's song ARIA.
HTML
153
star
3

flipclock

A flip clock screensaver supported by SDL2.
C
128
star
4

alynx-live-wallpaper

An android app that allows you choose a video as wallpaper.
Java
91
star
5

flipclock-android

The Android wrapper of FlipClock.
C
89
star
6

Harmonica

Sheets of Harmonica Music
CoffeeScript
40
star
7

gnome-shell-extension-net-speed

Show current net speed on panel.
JavaScript
34
star
8

hikaru-theme-aria

A Hikaru theme inspired by Kalafina's song ARIA.
Nunjucks
21
star
9

hikaru

A static site generator that generates routes based on directories naturally.
JavaScript
18
star
10

hikaru-coffee

A static site generator that generates routes based on directories naturally.
CoffeeScript
14
star
11

alynx-rime-config

12
star
12

azpiano-react

JavaScript
10
star
13

gnome-shell-extension-sb-counter

A counter to count how many times you are interrupted by SBs.
JavaScript
10
star
14

gnome-shell-extension-always-show-workspace-thumbnails

Always show workspace thumbnails even there is only one workspace.
JavaScript
9
star
15

AlynxZhou.github.io

喵's Homepage
HTML
7
star
16

atom-code-music

Play music notes like a piano while coding in Atom.
CoffeeScript
7
star
17

gnome-shell-extension-fixed-ime-list

Make the IME list in fixed sequence instead of MRU.
JavaScript
7
star
18

alynx-zsh-config

Alynx's zsh configuration files.
Shell
6
star
19

alynx-emacs-config

Alynx's Emacs configurations.
Emacs Lisp
5
star
20

rpi-lcd

JavaScript
5
star
21

hexo-renderer-nunjucks

Yet another Nunjucks renderer for Hexo.
JavaScript
5
star
22

azsh

A TOY shell for operating system homework.
C
4
star
23

azgallery

A static gallery website.
JavaScript
4
star
24

coffee-danmaku-server

Danmaku server based on Fastify. Written in CoffeeScript.
CSS
4
star
25

wakana

A Wayland compositer implemention.
C
3
star
26

azbot-telegram

Alynx Zhou's zero-dependency Telegram Bot API implemention.
JavaScript
3
star
27

coffee-telegram-bot

A Telegram Bot framework, written in CoffeeScript.
CoffeeScript
3
star
28

azpiano

AZPiano in vanilla JavaScript.
JavaScript
3
star
29

stackharbor

喵's StackHarbor
C
3
star
30

kouichi100

JavaScript
3
star
31

telebot

Telegram Bot Starter Kit.
Python
3
star
32

vala-danmaku-client

A danmaku client on desktop, written in Vala and using GTK+, Cairo.
Vala
2
star
33

railgun.ismyonly.one

某科学的标志生成器
HTML
2
star
34

azrotate

A quick panel button to rotate screen manually.
Java
2
star
35

image-collector-bot

An image collector Telegram bot.
JavaScript
2
star
36

Lab7-elevator

A very silly elevator, using SDL2.
C
1
star
37

mvmath

A simple C implemention of some GLM Matrix and Vector Math functions.
C
1
star
38

gles-loaders

C
1
star
39

atom-counter

A counter for the joke created by AlynxZhou.
CoffeeScript
1
star
40

music.ismyonly.one

JavaScript
1
star
41

namefight

Python
1
star
42

azbutton-pico

A pico-based, single-button USB HID keyboard firmware.
C
1
star
43

GNOMEWallpaperChanger

GNOME Wallpaper Auto Changer
Vala
1
star
44

snakejs

A snake game written in CoffeeScript.
CoffeeScript
1
star
45

hexo-theme-mirror

A hexo theme for creating a mirror's website, used by http://mirror.bjtu.edu.cn/.
CSS
1
star
46

AlynxZhou

A boring GitHub feature because I already have my own website.
1
star