Skip to content

afonsopacifer/da-vinci-css

Repository files navigation

aurea

Da Vinci CSS

Build Status Release v0.4.0

Creating shapes and drawings with CSS.

Pixel Art demo

Plankton

Sheldon J. Plankton - View demo

Summary

Why?

Because it's fun.

How to install?

Note: To use the framework, you'll need to compile your style with the Stylus preprocessor using NodeJS, for more information see NodeJS and Stylus.

Import the library.

@import "da-vinci"

Done ;)

Usage

Basic shapes

rectangle

.element
  rect(100px, 50px, #eb02dd) /* width, height, color (default #eb02dd) */

rectangle

circle

.element
  circ(50px, #eb02dd) /* radius, color (default = #eb02dd) */

circle

oval

.element
  oval(100px, 50px, #eb02dd) /* width, height, color (default = #eb02dd) */

oval

triangle

.element
  tri(100px, 50px, 50px, #eb02dd) /* top, right, left (default = #eb02dd) */

triangle

Pixel art

markup

<div class="canvas">
  <div class="art"></div>
</div>

grid

.canvas {
  grid(30px, 4, #000) /* cell size, grid size (default = 4), stroke color (default = #000) */
}

grid

origin

.art {
  origin(1, 1, 30px, #000) /* row, col, displacement, color (default = #000) */
}

origin

pixels

.art {
  origin(1, 1, 30px, #000)
  box-shadow: pixel(2, 2, 30px, #000); /* row, col, displacement, color (default = #000) */
}

Tip: Create variables and use p( ) > pixel( ).

.art {
  a = 30px
  origin(1, 1, a)
  box-shadow: p(2, 2, a);
}

pixels

line

.art {
  a = 30px
  origin(1, 1, a)
  box-shadow: line(2..6, a, #eb02dd); /* start..end, displacement, color (default = #000) */
}

line

lineX

.art {
  a = 30px
  origin(1, 1, a)
  box-shadow: lineX(2..6, a, #eb02dd); /* start..end, displacement, color (default = #000) */
}

lineX

lineY

.art {
  a = 30px
  origin(1, 1, a)
  box-shadow: lineY(2..6, a, #eb02dd); /* start..end, displacement, color (default = #000) */
}

lineY

Working all together

.canvas {
  grid(30px, 6, #ccc)
}

.art {
  a = 30px
  origin(1, 1, a, #eb02dd)
  box-shadow:
    pixel(3, 4, a, #eb02dd),
    line(2..6, a, purple),
    lineY(2..6, a, pink),
    lineX(2..6, a, pink);
}

lineY

Images

img

.picture
  img("magic.gif", 200px, 200px) /* url, width, height */

magic

Edit

position

.element
  rect(100px, 50px, #eb02dd)
  pos(10px, 10px, 1) /* x, y, layer(default = 1) */

position

flip vertical

.picture
  img("magic.gif", 200px, 200px)
  flip(vertical) /* vertical or horizontal (default = horizontal) */

vertical

flip horizontal

.picture
  img("magic.gif", 200px, 200px)
  flip(horizontal) /* vertical or horizontal (default = horizontal) */

horizontal

clone

.element
  rect(100px, 100px, #eb02dd)
  clone(110px, 0, #ccc) /* x, y, color (default = #eb02dd) */

clone

shadow

.picture
  img("unicorn.png", 200px, 200px)
  shadow(10px, 10px, 5px, #000) /*X, Y, dissipation, color (default = #000) */

shadow

Versioning

To keep better organization of releases we follow the Semantic Versioning 2.0.0 guidelines.

Contributing

Find on our roadmap the next steps of the project ;)
Want to contribute? Follow these recommendations.

History

See Releases for detailed changelog.

License

MIT License © Afonso Pacifer