CSS Art - Creating an Isometric Cube using CSS Transform
Making 3D objects can be difficult and time-consuming. Learn how to combine CSS and isometric projection techniques in this step-by-step article.
Introduction
Creating fully-featured three-dimensional (3D) objects for the web can be a daunting task. In this article, you’ll learn how to merge isometric projection methods with the CSS transform
property to create visually appealing, “3D-ish” objects and illustrations ready for the web.
This article introduces these CSS properties and functions:
transform
repeating-linear-gradient()
rotate()
skewX()
scaleY()
translate()
Preview
A preview of the isometric cube you’ll be learning to create using CSS properties and functions.
data:image/s3,"s3://crabby-images/8bf40/8bf409fa34864ed0687e33026f0ad41443245e09" alt="Isometric Cube - Preview Isometric Cube - Preview"
Prerequisites
Essential CSS and HTML knowledge will help you understand the concepts and techniques introduced in this article. Jump over to this article if you require an HTML and CSS primer.
We assume you have configured tools to modify CSS. If not, this article will guide you through the setup process.
HTML Structure
<div class="container">
<div class="isometric-cube-1">
<div class="isometric-cube-top"></div>
<div class="isometric-cube-right"></div>
<div class="isometric-cube-left"></div>
</div>
</div>
container
is the outermost enclosure. It enables the content to be centered and draws a light gray border. The rest of the divs represent each image component.
Keep the HTML structure as is for the image to display correctly.
Body and Container Div CSS
CSS code for the body
and container
div.
/* Body and Container Settings */
/* Center shapes */
body {
margin: 0;
padding: 0;
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
flex-wrap: wrap;
}
/* Set background and border color */
.container {
min-width: 500px;
height: 500px;
border: 5px solid lightgray;
background: #0a0a0a;
position: relative;
margin: 5px;
display: flex;
justify-content: center;
align-items: center;
}
What is Isometric Projection
The term “isometric” comes from a Greek phrase meaning “equal measure,” signifying that the scale remains uniform on each axis of the projection.
Isometric projection, first defined by Professor William Farish (1759–1837), effectively represents three-dimensional (3D) objects on a two-dimensional (2D) plane, making it particularly valuable for technical and engineering illustrations.
data:image/s3,"s3://crabby-images/8f188/8f18810fb9a0e8187dce75a9f92feff164a43017" alt=""
Source: Wikipedia
Isometric projection is a special way to draw objects that remain the same size no matter how far they are from the viewer. This makes designs clearer and avoids the confusion that can occur with other types of 3D projections.
data:image/s3,"s3://crabby-images/313e7/313e788a0f8d3d3b98ae730adba2009afb409c0c" alt=""
Source: Wikipedia
By using isometric projection, you can present your ideas more reliably and effectively. It’s a straightforward way to make your visuals precise and easy to understand.
data:image/s3,"s3://crabby-images/75198/75198fd6fdecdea596261c40f6c07eba36235716" alt=""
Source: Wikipedia
In the next section, you’ll learn how to implement an isometric grid guide to prepare for creating the isometric cube.
Making an Isometric Grid Guide
Employing a grid guide allows for more precise sizing and placement of isometric cube components than merely estimating or “eyeballing” them. It’s also simpler to position multiple isometric elements when using a grid guide.
data:image/s3,"s3://crabby-images/dc1e6/dc1e6645955bb67ff35ccdb821b00e1504b6c042" alt="Isometric Grid Guide - Preview Isometric Grid Guide - Preview"
Let’s make an isometric grid guide using the CSS repeating-linear-gradient()
function.
The isometric grid guide is made using three color stops:
#ccc
a silver hue#bbb
a gray shadetransparent
a transparent area
You’ll be making three repeating linear gradient sets using the above color stop pattern.
data:image/s3,"s3://crabby-images/ef618/ef61860a9c728b715d5820bf985e63d75dee369c" alt="First Repeating Linear Gradient - 0 degree First Repeating Linear Gradient - 0 degree"
/* First repeating linear gradient */
repeating-linear-gradient(
150deg,
#ccc,
#bbb 0.5px,
transparent 1px,
transparent 40px
)
- The gradient angle is set to
150deg
or 150 degrees. - The first color stop is
#ccc
, a silver hue. #bbb
, a gray shade, is the second color stop and set to0.5px
or 0.5 pixels.- The third color stop is
transparent
and set to1px
. - The final color stop is another
transparent
area, set to40
pixels.
data:image/s3,"s3://crabby-images/ae165/ae1655e53b3b168ac38544087561d11b884ef7c5" alt="First Repeating Linear Gradient - 150 degrees First Repeating Linear Gradient - 150 degrees"
Next, you’ll add the second repeating gradient, creating a crisscross pattern.
data:image/s3,"s3://crabby-images/a8a0b/a8a0bd75e8e2f1e300087dec37d7b8b38796d85e" alt="Second Repeating Linear Gradient - 30 degrees Second Repeating Linear Gradient - 30 degrees"
/* Second repeating linear gradient */
repeating-linear-gradient(
30deg,
#ccc,
#bbb 0.5px,
transparent 1px,
transparent 40px
)
The angle is to 30deg
or 30 degrees. The color stops are the same as the previous set.
data:image/s3,"s3://crabby-images/04074/04074023b7af00d11e2c9206ba3f24e1bb438961" alt="Third Repeating Linear Gradient - 90 degrees Third Repeating Linear Gradient - 90 degrees"
To complete the isometric grid guide, add the final repeating gradient that creates the vertical line pattern.
/* Third repeating linear gradient */
repeating-linear-gradient(
90deg,
#ccc,
#bbb 0.5px,
transparent 1px,
transparent 41px
)
Other than the 90deg
angle and the final transparent
color stop adjusted to 41 pixels, 41px
, the remaining values resemble those in the earlier examples.
Here’s the full isometric grid guide CSS code
/* Isometric Grid Guide */
background: repeating-linear-gradient(
150deg,
#ccc,
#bbb 0.5px,
transparent 1px,
transparent 40px
),
repeating-linear-gradient(
30deg,
#ccc,
#bbb 0.5px,
transparent 1px,
transparent 40px
),
repeating-linear-gradient(
90deg,
#ccc,
#bbb 1px,
transparent 1px,
transparent 41px
);
background-size: 81px 46px;
The background-size
property value is set to 81px
(width) and 46px
(height), which controls the repeating gradient’s dimensions.
Check this article to learn more about the repeating-linear-gradient()
function.
Let’s start making the isometric cube using CSS in the next section.
Creating an Isometric Cube
In this final section, you will learn how to create an isometric cube using CSS. You will utilize various CSS transform
functions, including rotate()
, skewX()
, scaleY()
, and translate()
.
data:image/s3,"s3://crabby-images/ecdb9/ecdb9e2befc7f9502b392a1c04c54159e13693df" alt="Isometric Cube - With Grid Guide Preview Isometric Cube - With Grid Guide Preview"
The isometric cube consists of three square faces, each with a width and height of 130 pixels, 130px
.
- Top face:
Background color is set to#085bb5
, a sapphire blue color. - Right face:
Background color is set to a dark midnight blue color,#043468
- Left face:
A blue jeans,#4fa0f8
, color is set as the background color.
The Top face always has a neutral color tone, and you can alternate between the highlighted and shaded areas based on the direction of the light. Here, the light source is from the left, making the Left face a lighter blue color.
Let’s start working on the Top face in the next section.
Top Face
data:image/s3,"s3://crabby-images/e34bd/e34bdab9401dac1d71e7c7db858b271505f575d8" alt="Top Face - Initial state Top Face - Initial state"
/* Top Face */
.isometric-cube-top {
width: 130px;
height: 130px;
background: #085bb5;
transform-origin: 0 0;
transform: rotate(210deg) skewX(-30deg) scaleY(0.864);
}
The transform-origin
property value is set to 0 0
for all three faces. Let’s break down the transform
property values below.
data:image/s3,"s3://crabby-images/2ea60/2ea60649e54995b443ef7f09e5a47cddae063683" alt="Top Face - Rotate 210 degrees Top Face - Rotate 210 degrees"
.isometric-cube-top {
transform: rotate(210deg);
}
To position the Top face, we use the CSS rotate()
function to rotate it by 210 degrees (210deg
). It will temporarily extend beyond the light gray border, but that will be fixed in the next step.
data:image/s3,"s3://crabby-images/bab1c/bab1c7f5282d4b231ec17415e8f9396e9c0d56af" alt="Top Face - Horizontal Skew -30 degrees Top Face - Horizontal Skew -30 degrees"
.isometric-cube-top {
transform: rotate(210deg) skewX(-30deg);
}
Immediately following the rotate()
function, include skewX(-30deg)
. This CSS code will horizontally skew the Top face by -30 degrees, positioning it inside the light gray border.
data:image/s3,"s3://crabby-images/4b752/4b75288902638f7a9f0963451a76765a009dea49" alt="Top Face - Vertical Scale 0.864% Top Face - Vertical Scale 0.864%"
.isometric-cube-top {
transform: rotate(210deg) skewX(-30deg) scaleY(0.864);
}
Finish the Top face by adding scaleY(0.864)
, which reduces it to roughly 86% of its original size. It’s crucial to vertically scale the face by exactly 0.864
so it adheres to isometric drawing standards.
Let’s work on the Right face in the next section.
Right Face
The Right face illustrates the shadowed region of the isometric cube, with a light source originating from the left. To create a sense of depth, this face employs a darker hue than both the Top and Left faces.
data:image/s3,"s3://crabby-images/1b889/1b8897b1d103c7708ca8f1ee360d492b3864af15" alt="Right Face - Initial state Right Face - Initial state"
/* Right Face */
.isometric-cube-right {
position: absolute;
height: 130px;
width: 130px;
background: #043468;
transform-origin: 0 0;
transform: rotate(-30deg) skewX(-30deg) translate(0, -113px) scaleY(0.864);
}
The position property value is configured to absolute
for both the Right and following Left face.
data:image/s3,"s3://crabby-images/55921/55921b03d48b9b305108587c383b18e428708f83" alt="Right Face - Rotate -30 degrees Right Face - Rotate -30 degrees"
.isometric-cube-right {
transform: rotate(-30deg);
}
Using the CSS rotate(-30deg)
function, the Right face is rotated by negative 30 degrees.
data:image/s3,"s3://crabby-images/0ed63/0ed634160d71d0db35458dbb49cc31187798c5ae" alt="Right Face - Horizontal Skew -30 degrees Right Face - Horizontal Skew -30 degrees"
.isometric-cube-right {
transform: rotate(-30deg) skewX(-30deg);
}
Skew the Right face horizontally by -30 degrees with skewX(-30deg)
.
data:image/s3,"s3://crabby-images/0c7da/0c7da33103bb1c75bbb63606eb5769933acc2a4a" alt="Right Face - Vertically Translate -113 pixels Right Face - Vertically Translate -113 pixels"
.isometric-cube-right {
transform: rotate(-30deg) skewX(-30deg) translate(0, -113px);
}
The Right face needs to be connected to the Top face. By using translate(0, -113px)
, you shift or translate the Right face upward by -113 pixels, connecting it with the Top face.
data:image/s3,"s3://crabby-images/212fe/212febbe819aec417101cfe59bd1a6587877cf76" alt="Right Face - Vertical Scale 0.864% Right Face - Vertical Scale 0.864%"
.isometric-cube-right {
transform: rotate(-30deg) skewX(-30deg) translate(0, -113px) scaleY(0.864);
}
Finally, scale the Right face horizontally using scaleY(0.864)
.
Let’s work on the Left face in the next section.
Left Face
The Left face serves as the highlight area of the isometric cube, which is why it features a lighter blue compared to the Top and Right faces.
data:image/s3,"s3://crabby-images/03a6d/03a6d4780e7e8c6768a7113e9541b27dc17fdef6" alt="Left Face - Initial state Left Face - Initial state"
/* Left Face */
.isometric-cube-left {
position: absolute;
width: 130px;
height: 130px;
transform-origin: 0 0;
background: #4fa0f8;
transform: rotate(90deg) skewX(-30deg) scaleY(0.864) translate(-130.5px, 0);
}
data:image/s3,"s3://crabby-images/9056b/9056bb832dcfa97676a6ac5534653bcc9eb16bc1" alt="Left Face - Rotate 90 degrees Left Face - Rotate 90 degrees"
.isometric-cube-left {
transform: rotate(90deg);
}
The rotate(90deg)
CSS property rotates the Left face 90 degrees, placing it underneath the Right face.
data:image/s3,"s3://crabby-images/94f37/94f37c160bf559c0c572a27dd8b4a922f985a055" alt="Left Face - Horizontal Skew -30 degrees Left Face - Horizontal Skew -30 degrees"
.isometric-cube-left {
transform: rotate(90deg) skewX(-30deg);
}
Like the Right face, the Left face is horizontally skewed using skewX(-30deg)
.
data:image/s3,"s3://crabby-images/83de2/83de29a11772fd347163a2847b36bdcd69cb3168" alt="Left Face - Vertical Scale 0.864% Left Face - Vertical Scale 0.864%"
.isometric-cube-left {
transform: rotate(90deg) skewX(-30deg) scaleY(0.864);
}
Next, scale the Left face vertically using scaleY(0.864)
.
data:image/s3,"s3://crabby-images/25677/2567773352ba8c2a163d928abf3ce1bfe09fb1b0" alt="Left Face - Horizontally Translate -130.5 pixels Left Face - Horizontally Translate -130.5 pixels"
.isometric-cube-left {
transform: rotate(90deg) skewX(-30deg) scaleY(0.864) translate(-130.5px, 0);
}
To connect the Left face with the other faces, apply translate(-130.5px, 0)
to shift it upwards by -130.5 pixels.
You can see and play with the complete code on Pyxofy’s CodePen page.
See the Pen CSS Art – Creating an Isometric Cube using CSS Transform by Pyxofy (@pyxofy) on CodePen.
Conclusion
Isometric projection allows for the simulation of three-dimensional objects on a two-dimensional surface. It’s essential in the fields of technical and engineering illustrations. By utilizing the CSS transform
property along with its functions like rotate()
, skew()
, scale()
, and translate()
, you can effortlessly incorporate isometric projections into your web designs and illustrations.
You discovered how to create an isometric grid guide using the CSS repeating-linear-gradient()
function, and then you constructed an isometric cube based on this guide. Be sure to choose a light direction, as it will affect the lighting on your cube’s faces. It’s essential to include both a highlight and a shadow color tone to add depth to your CSS images.
Feel free to experiment with the code and showcase your creation with us on LinkedIn, Threads, Bluesky, Mastodon, X (Twitter) @pyxofy, or Facebook.
We hope you liked this article. Kindly share it with your network. We appreciate it.