queer-loop is a simple ReasonML app that generates and reads QR codes based on URL parameters.
Tested on:
- Chrome (desktop and Android mobile)
NOTE: this only works in iOS version 11 and higher.
The prototypical use is to hold queer-loop
up to a mirror so that it can read itself.
Each capture in this mode represents one instance where the QR code was safely read back
by the software, accompanied by an image that accumulates frames from the camera.
Here are a few ways I've found so far to play with it:
- open two copies of qqq.lu on different devices and point their screens/cameras at each other
- hook up a capture card (I use the ClonerAlliance Flint LXT) to a Chromecast,
and cast...:
- a phone camera to it
- the tab to itself
Below are the query parameters which may be supplied.
a
controls SVG animation, which may be slow on some devices. Default is 0 (off).
Examples:
https://qqq.lu/?a=0
https://qqq.lu/?a=1
b
sets the "background" CSS property of the document's body. Default is none.
Examples:
https://qqq.lu/?b=url("queer-loop.svg")
https://qqq.lu/?b=lightpink
https://qqq.lu/?b=%23faa
(must use "%23" since #
is reserved for the timestamp)
If you have more than one camera, you can set the camera(s) using e.g. ?c=1
or ?c=0&c=1
.
Examples:
https://qqq.lu/?c=0&c=1
https://qqq.lu/?c=1
d
sets whether to include the domain in the Q(uee)r code.
Examples:
i
renders the code as white on a dark background.
Examples:
Set the opacity of the camera image (default: 0.1). Smaller values result in a longer exposure (more time is captured).
Examples:
Get the poem by poets.org slug.
Examples:
https://qqq.lu/?p=im-nobody-who-are-you-260
Set the page title.
Examples:
https://qqq.lu/?t=Hello%20there
Set the URL to point to.
https://qqq.lu/?u=hyper://bbf20e48b5281a5b0921bf2b9677e61dfb48cf2c626f83a016e7d9a8527dfb0e/
Get the video by YouTube ID.
Examples:
Get the English Wikipedia page.
Examples:
License is GPL v3.
Development has only tested on Ubuntu 18.10, but should work anywhere Node does.
In different terminals (or tmux splits), run:
yarn start
rollup -c -w
yarn build:production