재미있는 CSS 픽셀 아트
원본 주소: https://css-tricks.com/fun-times-css-pixel-art/#article-header-id-4
알림: 국내 네트워크 문제로 인해 CodePen이 열리지 않거나 매우 느릴 수 있으니 조금만 기다려주세요!
픽셀 아트는 매우 선명한 고해상도 사진에 비하면 아무것도 아닌 잃어버린 예술 형식입니다. CodePen을 검색하는 동안 우연히 픽셀 아트를 발견했는데 이 아트가 얼마나 멋진지 상기시켜 주었습니다!
CodePen에서 Devi Krisdiansyah(@agilBAKA)의 Pen Pikachu 픽셀 CSS를 확인하세요.
멋지지 않나요? 고화질 그래픽과 일러스트레이션에는 없는 픽셀화된 그래픽에는 단순하고 친근한 뭔가가 있습니다.
이는 HTML과 CSS를 사용하여 픽셀 아트를 만드는 방법을 보여주는 좋은 예이기도 합니다. 이 개념을 분석하여 다른 상황에서도 사용할 수 있는 패턴을 만들어 보겠습니다.
그리드 생성
먼저 픽셀화된 작품을 그릴 캔버스가 필요합니다. 그리드를 만드는 방법에는 여러 가지가 있습니다. 한 가지 방법은 각 행의 고정 너비 셀을 포함하는 표준 HTML <table>
요소를 사용하는 것입니다. 예를 들어, 8개의 행과 8개의 열로 구성된 완전 정사각형을 그립니다. 각 셀의 너비를 10px로 설정하면 80X80 테이블이 생성됩니다.
CodePen에서 Geoff Graham(@geoffgraham)이 작성한 Pen CSS Pixels - Table Grid 예제를 참조하세요.
더 큰 캔버스를 원할 경우 셀 크기를 더 크게 설정하세요. 8비트 해상도에서 16비트 해상도로 변경하려면 테이블의 각 행에 있는 셀 수를 두 배로 늘리기만 하면 됩니다.
그리드를 만드는 또 다른 방법은 테이블 대신 두 개의 div를 사용하는 것입니다. 그 중 하나는 캔버스의 컨테이너 역할을 하고, 다른 하나는 캔버스의 요소를 나타내며 필요한 만큼 반복할 수 있습니다.
<span style="color: #0000ff;"><</span><span style="color: #800000;">div </span><span style="color: #ff0000;">class</span><span style="color: #0000ff;">="canvas"</span><span style="color: #0000ff;">></span> <span style="color: #0000ff;"><</span><span style="color: #800000;">div </span><span style="color: #ff0000;">class</span><span style="color: #0000ff;">="pixel"</span><span style="color: #0000ff;">></</span><span style="color: #800000;">div</span><span style="color: #0000ff;">></span> <span style="color: #008000;"><!--</span><span style="color: #008000;"> Repeat as many times as needed </span><span style="color: #008000;">--></span> <span style="color: #0000ff;"></</span><span style="color: #800000;">div</span><span style="color: #0000ff;">></span><span style="color: #008000;"><!--</span><span style="color: #008000;"> end .canvas </span><span style="color: #008000;">--></span>
제가 이것을 좋아하는 이유는 우리가 정의한 캔버스 크기에 더 현실적이기 때문입니다. 그리고 table 요소에서 추가 HTML 태그를 작성하지 않고도 이 방법이 더 간단하다고 생각합니다.
보다 명확한 패턴을 만들기 위해 더 많은 픽셀을 원한다면 HTML 태그의 픽셀 수를 두 배로 늘리고 각 픽셀의 크기를 절반으로 줄일 수 있습니다. 마치 웹 페이지에 사용하려는 이미지를 Photoshop에서 만들고 더 높은 해상도를 얻기 위해 크기를 두 배로 늘린 것과 같습니다.
<span style="color: #800000;">.canvas </span>{ <span style="color: #008000;">/*</span><span style="color: #008000;"> Perfectly square </span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 80px</span>;<span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 80px</span>; }<span style="color: #800000;"> .pixel </span>{ <span style="color: #008000;">/*</span><span style="color: #008000;"> We'll need 256 total pixels in our HTML </span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 5px</span>;<span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 5px</span>;<span style="color: #ff0000;"> float</span>:<span style="color: #0000ff;"> left</span>; }
그림 그리기 시작
우리는 고무가 도로를 만나는 것처럼 픽셀에 색상을 추가합니다. nth-child 속성을 사용하여 그리드에서 요소를 선택할 수 있습니다.
<span style="color: #008000;">/*</span><span style="color: #008000;"> The third cell in our grid </span><span style="color: #008000;">*/</span><span style="color: #800000;"> .pixel:nth-child(3) </span>{<span style="color: #ff0000;"> background</span>:<span style="color: #0000ff;"> orange</span>; }
正如你想象的那样,这个列表会很长,它取决于网格中的单元格的数量和设计的细节。文章开头的例子中使用了1920个像素并且超过300个子类选择器。天哪!
一个简单的例子
我决定做一张像素化的自画像。这个例子很简单,因为它的像素很少并且总共只有四种颜色。
See the Pen CSS Pixels - Self Portrait by Geoff Graham (@geoffgraham) on CodePen.
作为Icon的CSS像素艺术
既然我们已经有了素材,我们可以 使用 transform 属性缩小图片把它作为icon使用。
See the Pen CSS Pixels - Self Portrait - Icon by Geoff Graham (@geoffgraham) on CodePen.
其他的像素绘制技术
1.box-shadow
你可以用一个元素通过复杂的 box-shadow 属性绘制像素艺术。如果你声明一个 box-shadow 的垂直和水平偏移,而没有模糊值及阴影半径,你将得到一个可以随意移动的元素形状的彩色复制体。
以下是概念实例。黑色元素是初始形状,我已经在左下角创建了一个橙色像素以及在右下角创建了一个红色像素。
See the Pen Basics of Pixel Art by Chris Coyier (@chriscoyier) on CodePen.
你可以疯狂的使用这种方式绘制整个图案。
See the Pen Pixel Hellboy by servin (@servinlp) on CodePen.
2.预处理
变量可以更容易地调整颜色和大小等。
以下是less编写的例子。
See the Pen Pixel-art hipster pacwoman by Mario Sanz (@msanz) on CodePen.
这是Una Kravets编写的例子, 他更进一步地使用Sass map 创建box-shadow,很聪明的方法。
<span style="color: #800000;">// Setting the colors we're syncing up with $pixel-color-map: ( 'r' : #f00, 'w': #fff, 'k': #000, 'o': transparent, 't': #83401f, 'p': #ffbc77, 'b': #06f, 'y': #ff0, 'n': #ff8000, 'g': #5ac528 ); // Mario pixel art matrices! $pixel-art:( mushroom: ( (o o o o o k k k k k k o o o o o) (o o o k k r r r r w w k k o o o) (o o k w w r r r r w w w w k o o) (o k w w r r r r r r w w w w k o) (o k w r r w w w w r r w w w k o) (k r r r w w w w w w r r r r r k) (k r r r w w w w w w r r w w r k) (k w r r w w w w w w r w w w w k) (k w w r r w w w w r r w w w w k) (k w w r r r r r r r r r w w r k) (k w r r k k k k k k k k r r r k) (o k k k w w k w w k w w k k k o) (o o k w w w k w w k w w w k o o) (o o k w w w w w w w w w w k o o) (o o o k w w w w w w w w k o o o) (o o o o k k k k k k k k o o o o) ) );</span>
有很多函数可以把它转换成box-shadow并且应用它。下面是最终结果。
See the Pen Sass-Generated Box Shadow Pixel Art! by Una Kravets (@una) on CodePen.
记住box-shadow也可以做动画。
See the Pen Ash and Pikachu box-shadow Pixel Art by Andrew (@AstroDroid) on CodePen.
3.canvas
<canvas> 肯定可以绘制矩形。
<span style="color: #0000ff;">var</span> canvas = document.getElementById("canvas"<span style="color: #000000;">); </span><span style="color: #0000ff;">var</span> ctx = canvas.getContext("2d"<span style="color: #000000;">); ctx.fillStyle </span>= "rgb(53, 41, 15)"<span style="color: #000000;">; ctx.fillRect(</span>48, 0, 8, 8<span style="color: #000000;">); ctx.fillStyle </span>= "rgb(238, 187, 68)"<span style="color: #000000;">; ctx.fillRect(</span>56, 0, 8, 8);
CodePen에서 Max(@MyXoToD)가 제작한 Tranigma의 Pen Canvas Ark를 살펴보세요.
4.svg
<svg><직선이 있지만 > 그러나 기회주의적으로 다음을 포함하는 <polygon>을 사용할 수 있습니다. 더 많은 픽셀
.CodePen에서 Aloïs De Schepper(@Alo62)의 Pen Pixel me를 확인하세요.
5.3D!
글쎄요, 할 만큼 했다고 생각합니다.
CodePen에서 cx20(@cx20)의 Pen 3D 픽셀 아트를 확인하세요.
당신 차례입니다
- 우리는 항상 여러분이 자신만의 방식으로 작업하기를 원하지만 픽셀 아트를 그리는 데 사용할 수 있는 도구가 많이 있다는 것을 알아두세요.
- Ludvig Lindblom의 캔버스 상자 그림자 픽셀 아트 생성기
- Jenn Schiffer가 만든 8비트 아트!
XOXCO의 Make Pixel Art

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

이 기사는 모바일 장치의 반응 형 웹 디자인에 필수적인 Viewport Meta Tag에 대해 설명합니다. 적절한 사용이 최적의 컨텐츠 스케일링 및 사용자 상호 작용을 보장하는 방법을 설명하는 반면, 오용은 설계 및 접근성 문제로 이어질 수 있습니다.

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

이 기사는 html5 & lt; time & gt; 시맨틱 날짜/시간 표현 요소. 인간이 읽을 수있는 텍스트와 함께 기계 가독성 (ISO 8601 형식)에 대한 DateTime 속성의 중요성을 강조하여 Accessibilit를 향상시킵니다.

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

이 기사는 & lt; iframe & gt; 외부 컨텐츠를 웹 페이지, 공통 용도, 보안 위험 및 객체 태그 및 API와 같은 대안을 포함시키는 태그의 목적.
