Skip to content

Latest commit

 

History

History
86 lines (59 loc) · 5.36 KB

README.md

File metadata and controls

86 lines (59 loc) · 5.36 KB

Potions

Design

The first mock-up was a very rough sketch on a post-it note. I'm no artist, but I liked it enough to keep going. So I collected a few inspirations into a mood board, in a folder on my desktop, and got started with some basic designs...

Not sure where to get started? Luckily, there's creativity all over the internet. If you know where to look, you can follow some amazing artists. (e.g. Dribbble, Reddit, Artstation, ...)

Inkscape

On the topic of illustration software, there are a few options to choose from. I've used a trial of Adobe Illustrator before, which was excellent, but not remotely worth it's cost or contract lock-in. So I gave Inkscape a try. It turned out to be a great piece of software, and open-source which is always amazing. Albeit, it could use a bit more documentation and a few official tutorials.

One excellent feature of Vector Graphic tools is the clipping mask. It unlocks a huge number of possibilities for animations, as you can create a complex shapes in a background layer and send objects across the gap. This allows certain objects to leave the apparent field of view; by matching the colour of the mask to the webpage background. (E.g. The blue multi-hexagon shape of potions.svg was cut-out, and has a periodic, sweeping line rotating across the gap).

In Inkscape, the steps are as follows:

  • Draw your background layer
  • Draw your cut-out shape
  • Set the colour of your cut out shape to Black (#000000). Or lighten the colour if you wish your cut-out to be partially opaque.
  • Select both
  • Navigate to Object --> Mask --> Set Inverse (LPE)

Warning

[Bug]: The clipping mask is sometimes not visible in other software. There is a temporary workaround listed here.

Also, since Inkscape saves vector graphics in their own personalised format, here are some steps I use to prepare it for handling code:

  • Using Inkscape, add labels to all the relevant shapes/groups in the Objects Pane (only required once)
  • Using a text editor, replace all: inkscape:label= with class=
  • Upload it to SVGOMG. An excellent tool, utilizing SVGO to optimise and prettify SVGs.
  • Add the CSS (detailed below)

Animation

CSS can be easily included in SVGs using the <foreignObject> tag. Simply insert this block of code under the initial <svg> line and you're set.

<foreignObject>
  <div xmlns="http://www.w3.org/1999/xhtml">
    <style>
      /// CSS HERE
    </style>
  </div>
</foreignObject>

Dark Mode Detection

Since GitHub has a dark mode and we want the clipping mask to match the colours, we need to account for that in the design. The obvious solution is the CSS property prefers-color-scheme, launched in 2019. It can be handled using some fairly simple media queries in our CSS. For example:

@media (prefers-color-scheme: light) {
  .Background  { fill: #fff }
}
@media (prefers-color-scheme: dark) {
  .Background  { fill: #0d1117 } 
}

However, it no longer works on GitHub, and is most likely deliberately not supported. Fortunately, an alternative method of dark-mode detection does exist; specific to GitHub flavoured markdown.

![Potions](./potions-light.svg#gh-light-mode-only)
![Potions](./potions-dark.svg#gh-dark-mode-only)

There are a few caveats worth being aware of. It does require two files, and both may render in the document when the readme is viewed from an external source (e.g. NPM, crates.io, ...). But neither is a significant problem in this instance.

Additional Notes

SVGs are obviously scalable by design, but that statement is not entirely true. Icons are a great example. If you design something at 16x16 pixels, then scale it to 24x24, it could appear to have blurred edges. This is known as anti-aliasing, and it's likely you've heard the term before. It's the process of blending outer-edge pixels to reduce contrast and create a smoother picture.

It's not always helpful. Luckily, there is a CSS property known as shape-rendering, which can provide a solution in specific situations. However, in the case of icons, you may require several additional icon sets for each common size (16x16, 20x20, 24x24, 32x32, etc.) to circumvent the issue.

Acknowledgements