Maison >interface Web >tutoriel CSS >Parlons de la façon d'utiliser CSS box-shadow pour créer des animations créatives en pixels
Vous pouvez également créer des animations créatives en pixels en utilisant CSS ! L'article suivant vous présentera comment utiliser CSS box-shadow pour créer des animations créatives en pixels. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.
Dans ce numéro, nous allons utiliser l'attribut box-shadow en CSS3 pour peindre. Je pense que vous connaissez tous l'attribut box-shadow. Il est principalement utilisé pour ajouter des effets d'ombre au cadre des éléments, mais y avez-vous déjà pensé ? Et si vous l'utilisiez simplement pour dessiner des images ? Donc, tout de suite, nous utiliserons l'attribut box-shadow pour dessiner avec vous une animation en pixels - une ampoule en pixels. [Apprentissage recommandé : Tutoriel vidéo CSS]
box-shadow
pour implémenter le dessin, parlons d'abord des paramètres box-shadow
qui peuvent être passés pour lui permettre d'implémenter un petit bloc de pixels. Habituellement, lorsque nous utilisons box-shadow
, nous transmettons souvent 5 paramètres, à savoir le décalage x, le décalage y, le rayon de flou de l'ombre, le rayon de diffusion de l'ombre et la couleur de l'ombre. Ensuite, nous dessinons un pixel de 10x10. projection rectangulaire (remarque : ici, largeur
et hauteur
déterminent la taille d'un pixel lorsque le pixel art est affiché). box-shadow
实现绘图,那么我们就先讲讲, box-shadow
可以传哪些参数可以让他实现一个小像素块吧。
平时我们使用 box-shadow
往往会传入5个参数,分别为x偏移量, y偏移量, 阴影模糊半径, 阴影扩散半径, 阴影颜色 ,接下来,我们绘制一个10x10像素的矩形投影(注意:这里width
和 height
决定了像素画展示的时候一个像素有多大)。
.box{ width: 10px; height: 10px; background-color: red; /* x偏移量 | y偏移量 | 阴影模糊半径 | 阴影扩散半径 | 阴影颜色 */ box-shadow: 10px 10px 10px 10px black; }
可我们绘制像素画意图是取消其阴影,可以使用可选参数 inset
,如果没有指定 inset
,默认阴影在边框外,即阴影向外扩散。
使用 inset
关键字会使得阴影落在盒子内部,这样看起来就像是内容被压低了。 此时阴影会在边框之内 (即使是透明边框)、背景之上、内容之下。
接下来,加入用 inset
再来绘制这个矩形看看变化。
.box{ width: 10px; height: 10px; background-color: red; /* x偏移量 | y偏移量 | 阴影模糊半径 | 阴影扩散半径 | 阴影颜色 | 阴影向内扩散 */ box-shadow: 10px 10px 10px 10px black inset; }
这样一个小像素块就出现了,而且把原来的红色背景给覆盖掉了,但成也 inset
败也 inset
,正因为他可以压住盒子,同时也被盒子的大小所限制,并不能很好的排列好大量的像素块,所以放弃了这种做法。
现在我们换个想法,既然不要阴影显示,那么我们索性不要传入跟阴影有关的信息不就完了么,所以,我们接下来只要传入x偏移量, y偏移量 , 阴影颜色也能实现这个小像素块。
.box{ width: 10px; height: 10px; background-color: red; /* x偏移量 | y偏移量 | 阴影颜色 */ box-shadow: 10px 10px black; }
看我们同样也实现了一个小像素块但又会发现另外一个小问题。
.box{ width: 10px; height: 10px; background-color: red; box-shadow: 0px 0px black, 10px 10px black, 20px 20px black, 30px 30px black, 40px 40px black; }
当我们内联时会发现,原点的像素块是盖不住的,因为他永远在下层,即便是主块背景变成透明也是不可以的,但是我们可以庆幸因为只有一个点是这样,我们就把主块的点也填充自然不就解决了。
然后,我们不停地连接 box-shadow
绘制出图形,就会发现一幅像素画就完成了。
上一步我们绘制出了灯泡的形状,但是我们要那种一闪一闪的效果,在 box-shadow
里中是如何出来的呢?其实最暴力的一种办法是,再画一个发光的效果,格子隔一段时间全部替换掉,来实现发光效果。
但是灯泡代表什么?代表了灵感,我们怎么可以用暴力的手段去绘制呢,那样样式脚本的体积是非常大的,需要优雅一点。
所以,我在代码中用 scss
$size:10px; $light-color:rgb(75,73,81); $wick-color:rgb(130,129,136); $line-color:rgb(12,12,12); $bottom-color:rgb(153,152,157); $active-bottom-color:rgb(185,182,193); $active-light-color:rgb(241,218,126); $active-wick-color:rgb(255,236,201); $light-bg: -1*$size 1*$size 0 $light-color, 1*$size 1*$size 0 $light-color, // ... -3*$size 5*$size 0 $light-color; $wick-active: -1*$size 0 0 rgb(248,203,58), // ... 1*$size 7*$size 0 rgb(246,198,65); $wick: -1*$size 0 0 $wick-color, // ... 1*$size 7*$size 0 $wick-color; // ...more🎜🎜 Mais le but du dessin du pixel art est d'annuler son ombre. Vous pouvez utiliser le paramètre facultatif
inset
. Si inset
n'est pas spécifié, l'ombre par défaut est en dehors de la bordure, c'est à dire. c'est-à-dire que l'ombre s'étend vers l'extérieur.
L'utilisation du mot-clé inset
fera tomber l'ombre à l'intérieur de la boîte, donnant l'impression que le contenu est poussé vers le bas. À ce stade, l'ombre sera à l'intérieur de la bordure (même une bordure transparente), au-dessus de l'arrière-plan et en dessous du contenu. 🎜🎜Ensuite, ajoutez un inset
pour dessiner à nouveau ce rectangle et voir les changements. 🎜.light{ width:$size; height:$size; position: absolute; left:50%; top:50%; transform: translate(-50%,-$size*2); background-color:$light-color; box-shadow: $line, $wick, $light-bg, $light-bottom; animation:flash 2s linear infinite; } @keyframes flash { 0%,48%,58%,78%,94%,100%{ background-color:$light-color; box-shadow: $line, $wick, $light-bg, $light-bottom; } 50%,80%{ background-color:$active-wick-color; box-shadow: $line-active, $wick-active, $light-bg-active, $light-bottom-active; } }🎜🎜🎜 Un si petit bloc de pixels apparaît et recouvre le fond rouge d'origine, mais il réussit
inset
et échoue inset
précisément parce qu'il peut maintenir la boîte enfoncée en même temps. également limité par la taille de la boîte et ne pouvait pas bien organiser un grand nombre de blocs de pixels, cette approche a donc été abandonnée. 🎜🎜Changeons maintenant d'avis. Puisque nous ne voulons pas d'affichage d'ombre, nous n'avons tout simplement pas besoin de transmettre les informations liées à l'ombre. Nous devons donc simplement transmettre le décalage x, le décalage y et. la couleur de l'ombre. Implémentez ce petit bloc de pixels. 🎜.point{ &:checked + .light{ animation:none; background-color:$active-wick-color; box-shadow: $line-active, $wick-active, $light-bg-active, $light-bottom-active, $light-star; } }🎜🎜🎜 Étant donné que nous avons également implémenté un petit bloc de pixels, nous trouverons un autre petit problème. 🎜rrreee🎜🎜🎜 Lorsque nous inlineons, nous constaterons que le bloc de pixels à l'origine ne peut pas être recouvert, car il est toujours sur le calque inférieur. Même si l'arrière-plan du bloc principal devient transparent, ce n'est pas autorisé, mais nous pouvons être heureux car seulement. un point est comme ça, donc remplir les points du bloc principal résoudra naturellement le problème. 🎜🎜Ensuite, nous continuons à connecter
box-shadow
pour dessiner des graphiques, et nous constaterons qu'une peinture en pixels est terminée. 🎜🎜🎜box-shadow
Comment avez-vous fait. Li Zhong est sorti ? En fait, la méthode la plus violente consiste à dessiner un autre effet lumineux et à remplacer toutes les grilles à intervalles pour obtenir l'effet lumineux. 🎜🎜🎜🎜Mais Que représente l'ampoule ? Il représente l'inspiration. Comment pouvons-nous utiliser des moyens violents pour le dessiner ? La taille du script de style est très grande et doit être plus élégante. 🎜🎜J'ai donc utilisé scss
pour extraire beaucoup de choses du code et démonter l'ampoule pièce par pièce, comme : 🎜$size:10px; $light-color:rgb(75,73,81); $wick-color:rgb(130,129,136); $line-color:rgb(12,12,12); $bottom-color:rgb(153,152,157); $active-bottom-color:rgb(185,182,193); $active-light-color:rgb(241,218,126); $active-wick-color:rgb(255,236,201); $light-bg: -1*$size 1*$size 0 $light-color, 1*$size 1*$size 0 $light-color, // ... -3*$size 5*$size 0 $light-color; $wick-active: -1*$size 0 0 rgb(248,203,58), // ... 1*$size 7*$size 0 rgb(246,198,65); $wick: -1*$size 0 0 $wick-color, // ... 1*$size 7*$size 0 $wick-color; // ...more
最后,我们只要把拆出来的这几部分重新组合起来,就又变成灯泡了。当然闪烁动画也是同样拼接组合起来。
.light{ width:$size; height:$size; position: absolute; left:50%; top:50%; transform: translate(-50%,-$size*2); background-color:$light-color; box-shadow: $line, $wick, $light-bg, $light-bottom; animation:flash 2s linear infinite; } @keyframes flash { 0%,48%,58%,78%,94%,100%{ background-color:$light-color; box-shadow: $line, $wick, $light-bg, $light-bottom; } 50%,80%{ background-color:$active-wick-color; box-shadow: $line-active, $wick-active, $light-bg-active, $light-bottom-active; } }
最后,我们还要加入一个手动点亮的效果也是非常的简单。就是利用 checkbox
当选中时的 checked
伪类来找到 div.light
触发点亮效果,当然其样式依然需要你提前绘制拼接好。
.point{ &:checked + .light{ animation:none; background-color:$active-wick-color; box-shadow: $line-active, $wick-active, $light-bg-active, $light-bottom-active, $light-star; } }
现在看绘制的像素画,我们会发现其实并不难,只是想好要创作出什么画面,然后机械性的用 box-shadow
绘制一个个的像素点,非常的消耗时间和精力。这里推荐我之前制作的一款在线编辑像素画的软件——PXDragon ,虽然鸽了很久但是目前还是可以完成一些简单像素画绘制的,也可以导入图片自动生成像素画,同时可以导出 css
和 scss
代码来抹除很多机械性费时费力的绘制任务,如果想尝试此类展示可以一试,把创意用于构思构图而非机械劳动。
(学习视频分享:web前端)
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!