/Otagle

O T A G L E (otagle) is advanced, configurable on screen keyboard, based on AutoHotkey. The name is anagram of "elgato".

Primary LanguageHTMLGNU General Public License v3.0GPL-3.0

Otagle, introduction

Otagle is inspaired by commercial product Elgato stream deck. Once upon a time I decided to make something similar with fraction of a cost. The name of my software framework, Otagle is actually anagram to word Elgato; the word otagle is formed by reading the word elgato backwards.

Watch the video

The idea behind is simple: configurable tool, where you can easily connect any icon to any button and to any script.

flowchart LR
    icon    --> button
    button  --> script
Loading

At the moment it works only with Microsoft Windows operating systems (10 and 11) and is based on AutoHotkey scripting language.

Example

For example you would like to have some shortcuts, visually appealing, to call your favorite function in video editor. So instead of clicking over menu and submenu and drop-down-list, you would like to directly specify 5 s, as your scene outro by default takes 5 s. So you select icon T [5 s], connect it with top-right button and connect it to an AutoHotkey script, which calls API (Application Programming Interface) of your video editor. This principle can be translates into the following matrix:

block-beta
	block:matrix
    columns 5
    	R1C1["T 5 s"]	R1C2[" "] R1C3[" "] R1C4[" "] R1C5[" "]
    	R2C1[" "] 		R2C2[" "] R2C3[" "] R2C4[" "] R2C5[" "]
    	R3C1[" "]		R3C2[" "] R3C3[" "] R3C4[" "] R3C5[" "]
    	R4C1[" "]		R4C2[" "] R4C3[" "] R4C4[" "] R4C5[" "]
    	R5C1[" "]		R5C2[" "] R5C3[" "] R5C4[" "] R5C5[" "]
	end
	space
	R1C1["T 5 s"] --> VS["AutoHotkey script, call video editor"]
Loading

The matrix of icons / buttons can have pure software form, e.g. as a separate Otagle application window, but it makes much more sense to make it over more touchable, tactile piece of hardware, a Physical Device aka touch screen. To follow this challenge I found cheap, small touch screens, which can be interfaced to a computer over:

  • recommended: one HDMI wire (to connect video signal) and one USB-A wire (to connect touch screen feedback)
  • optional: two USB-A wires (the 1st to connect video signal, the 2nd to connect touch screen feedback)

flowchart LR
	subgraph rm["`**Regular Screen**`"]
		display[["display"]]
		dp1["`display **port** e.g. HDMI`"]
		ps1["`power supply **port**`"]
	end

	subgraph ts["`Personal Computer`"]
		ps2["`power supply **port**`"]
		dp2["`display **port**  e.g. HDMI`"]
	end

	ps[["power supply / mains"]]

	dp1 	--- dp2
	ps1		--- ps
	ps2		--- ps
Loading
flowchart LR
	subgraph rm["`Generic **Touch Screen**`"]
		display[["display"]]
		ps1["`power supply **port**`"]
		dp1["`display **port** e.g. HDMI`"]
		tp["` touch **port** USB`"]
	end

	subgraph ts["`Personal Computer`"]
		ps2["`power supply **port**`"]
		dp2["`display **port**  e.g. HDMI`"]
		usbp["`**port** USB`"]
	end

	ps[["power supply / mains"]]

	dp1 	--- dp2
	ps1		--- ps
	ps2		--- ps
	tp		--- usbp
Loading
flowchart LR
	subgraph rm["`Specific **Touch Screen**`"]
		display[["display"]]
		dp1["`display **port** e.g. HDMI`"]
		tp["` touch **port** microUSB`"]
	end

	subgraph ts["`Personal Computer`"]
		ps2["`power supply **port**`"]
		dp2["`display **port**  e.g. HDMI`"]
		usbp["`**port** USB`"]
	end

	ps[["power supply / mains"]]

	dp1 	--- dp2
	ps2		--- ps
	tp		--- usbp
Loading
Picture 1. Comparison between classical screen (display) and specific touch screen.

flowchart LR
	subgraph pd["`Specific **Touch Screen**`"]
		display[["HDMI display"]]
		TS[["touch screen"]]
		hport["HDMI port"]
		tsport["micro USB port"]

		display === hport
		TS 		=== tsport
	end
	
	subgraph pc["Personal Computer"]
		vp["USB-A, video"]
		tp["USB-A, touch"]
	end
	
	hvc["HDMI to USB-A adapter"]

	hport 	=== hvc
	hvc 	=== vp
	tsport 	=== tp
Loading
flowchart LR
	subgraph pd["`Specific **Touch Screen**`"]
		display[["HDMI display"]]
		TS[["touch screen"]]
		hport["HDMI port"]
		tsport["micro USB port"]

		display === hport
		TS 		=== tsport
	end

	subgraph pc["Personal Computer"]
		hdmip["HDMI, video"]
		tp["USB-A, touch"]
	end
	
	hport 	======= hdmip
	tsport 	======= tp
Loading
Picture 2. Comparison of recommended and optional connection between a Physical Device and Personal Computer (PC).

Existing versions of Otagle scripts

  • Otagle1, non-scallable window, 1024 x 600 px, replaces numeric keypad (numpad)
  • Otagle2, non-scalleble window of any size, with rectangular buttons,
  • Otagle3, scallable window of any size, with rectangular buttons.

For details please see dedicated folders and README.md files.

Hardware example

Physical Device Physical Device ports HDMI to USB-A adapter

Some parameters:

  • display size: 7''
  • display size [pixels]: 1024 x 600
  • display active size [cm]: 15.5 x 8.6
  • display passive size [cm]: 16.5 x 9.9
  • display type: TFT (Thin Film Transistor)
  • screen size [cm]: 18 x 12.5

Hardware configuration.

In order to run this touch screen both cables must be connected (HDMI and USB). Power is delivered from computer to the touch screen over USB cable, which is also used to

The HDMI cable could be connected directly to HDMI port or at first to the HDMI to USB adapter. Such adapter is fully plug-and-play, doesn't require any configuration. The one presented at picture above actually stopped working out of sudden, so I don't recommend it.

Configuration of additional display in Microsoft Windows is available in System settings:

  • menu Start → Configuration Configuration

  • or press keyboard shortcut # + I (keyboard chord: Windows key and I) in System settings → Display. Display Configuration

Information regarding actual touch screen activity are transfered over USB port. From operating system point of view this is just another input device. The issue is it must be logically connected to the correct screen.

Run system application Calibrate the screen for pen or touch input aka Tablet PC Settings (you can search for it) and configure relation between correct screen and touch. Tablet Configuration Screen choice

You're done.

By the way, there are available touch overlays to regular screens of specific size. Such overlays are usually glued (by adhesive tape) or clamped to regular size monitors (e.g. 24''). Thanks to that one can get access to huge button matrix if switching between layers is somehow cumbersome or unwanted.

Additional links

AutoHotkey forum topic dedicated to Otagle. You can find there discussion about pros and cons as well as syntetic comparison with Elgato Stream Deck.