Skip to content

Renders Keyboard Layout Editor JSON by manipulating photos of keys

Notifications You must be signed in to change notification settings

Maximillian/kle_render

 
 

Repository files navigation

KLE-Render

Get prettier images of Keyboard Layout Editor designs

This project uses Pillow (Python Image Library), Flask, and Flask-RESTPlus to serve up 'renders' of keyboards from their keyboard layout editor JSON, by stretching, tinting, and tiling base images of a 1u keycap.

Check it out at kle-render.herokuapp.com.

You can also see a sample render of Nantucket Selectric here.

Frequently Asked Questions

I've also answered many common questions on the reddit post. If you have a simple question not answered here, try messaging me on reddit.

What keycap profiles are supported?

KLE-Render technically only supports SA and GMK keycap profiles, but most layouts for DSA, DCS, OEM, or even beamspring profiles should still look pretty close. Keycap row profiles (like SA R1) are not supported - everything is assumed to be in row 3.

Why aren't my custom legend icons showing up?

KLE-render does all legend rendering server side with pillow, so rendering arbitrary html and css, or external image links, is quite difficult as well as possibly dangerous. If possible, try replacing custom icons with unicode text, or something from keyboard layout editor's glyph picker. If not, you may have to add the legends via photoshop yourself.

Why am I getting an internal server error when I try to render a layout?

It's quite possible the server is overloaded, but also possible that something in your layout is causing the server to crash. If you're uploading JSON, make sure it is downloaded via the button. If as far as you can tell everything is inputted correctly, please contact me with the gist link or JSON that is causing the error and I will try to fix the problem.

Why are the edges cut off on my image?

To save time, the program guesses a reasonable initial image size given the number of keys in the layout, then crops it to size after rendering all of the keys. For certain narrow layouts, the initial guess may be too small in one dimension, causing the final image to be cut off. I will try to fix this issue when possible, but for now try adding extra keys to make the layout more square, then cropping the render afterwards.

Why are my legends not aligned correctly?

Sometimes keyboard layout editor and kle-render end up with different default legend alignments for some keys. Try explicitly settings alignment with the arrows under the "Tools" tab of keyboard layout editor. Also, SA profile (which is kle-render's default profile) caps with only the first one or two legends set are automatically given all caps, centered legends if another alignment is not explicitly specified.

Can I render from a different angle? What if I need to render with a case, or rare profiles, or translucent keycaps?

This tool can generate relatively realistic renders of arbitrary keyboard layout editor layouts, but because it works by stretching and tinting grayscale images there are many limitations on what can be shown, compared to 3D renders. For certain work you may still have to do post-processing in photoshop, or, for the greatest photorealism, commission someone like thesiscamper to create real 3D renders of your set design.

I've made a great looking set design that I think could be a popular group buy. How do I turn it into a reality?

If you're looking for help with creating a keycap set for a group buy livingspeedbump has a nice guide on keychatter.

Sample Image

Sample Render

About

Renders Keyboard Layout Editor JSON by manipulating photos of keys

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 86.3%
  • HTML 13.7%