Comment transformer des images en « style pseudo-pixel » ? Cet article vous présentera comment utiliser CSS pour traiter des images et les convertir en « style pixel ». J'espère que cela vous sera utile !
Le style pixel
est une sorte de utilisant des carrés de pixels de couleur unie de taille fixe
comme unité de base pour la création, y compris, mais sans s'y limiter, la peinture
, Un style artistique dans divers domaines tels que l'architecture
, les jeux
et plus encore.
Le plus connu est bien sûr les graphismes en pixels des premiers jeux vidéo
~像素风
是一种以固定大小纯色像素方块
作为基本单元,进行创作,包含但不限于绘画
、建筑
、游戏
更各个领域的一种美术风格。
其中最让人耳熟能详的,当然是早期电子游戏
的像素画面啦~
[早期红白机上"马里奥"的像素形象]
当然,早期电子游戏采用像素风
,实际上是一种历史的无奈,硬件条件的限制,让游戏开发者不得不选择这种变现力强
,性能开销
低的美术风格。
不过,时至今日
像素风在各个领域依然潮流,则被赋予了更多审美
和复古
上的意义。
先看看本次要处理的“爱心图”的原图:
[爱心图]
要将一张这样的图片变成像素,我脑海里首先蹦出了第一个思路:
使用canvas将图片切割成N*N块,然后每块区域单独计算取色彩中值,并将其填充为实色,没错,这个思路无疑是可以很快且灵活的解决问题的。
但这样一来,没使用到CSS,同事阿洋的第一次约会
岂不是就完全泡汤了?
❌❌
不行不行!我得换个思路,用CSS来实现!(推荐学习:css视频教程)
主体思路如下:
将图片分成N个div,每个div都持有图片的一部分。
每个div都通过css-filter来进行一次blur(高斯模糊)
,视觉上达到取中值并填充div
的效果。
按这个思路,其实只有一个难点,如何让每个div都持有图片的一部分?
呵,这可难不倒我那颗帮助同事大心脏
。
其实不难:
首先,我们用8*8将一个div分成64份,毫无疑问的grid布局。
代码:
<style> .mask-group { width: 128px; height: 128px; display: grid; grid-template-columns: repeat(8,1fr); grid-template-rows: repeat(8,1fr); } </style> <script> const el = document.querySelector('.mask-group') for(let i = 0; i< 64; i++) { const itemEl = document.createElement('div') itemEl.className = 'mask-item' el.appendChild(itemEl) } } </script>
然后我们给每个.mask-item 元素设置一个心形背景
然后效果就变成了这样
,因为每一张的背景都是从左上角开始的,因此肯定不符合预期。
接下来:我们需要在js的遍历中插入这么一句:
itemEl.style.backgroundPosition = `-${Math.floor(i%8) * 16}px -${Math.floor(i/8) * 16}px `
这行代码的作用,是给每一个.mask-item元素单独赋予一个background-position
样式,通过计算让所有.mask-item元素的背景图的左上角都重叠到了一个坐标点上
。
效果如图:
3. 增加间隔和高斯模糊
按照设想,我们只需要给div加上间隔
,再给上高斯模糊
,就能达到效果了。
于是代码如下:
.mask-group { /* 以下为新增 */ grid-row-gap: 2px; grid-column-gap: 2px; } .mask-item { /* 以下为新增 */ filter: blur(8px) }
但是效果却:
到底是哪里出了问题?高斯模糊
居然会作用到inner-box
以外的区域!!
没办法,为了限定高斯模糊的效果区域,我只能通过mask-image了。
先弄一张16*16像素的纯黑all-black.png文件。
代码如下:
.mask-item { /* 以下为新增 */ -webkit-mask-image: url('./all-black.png'); mask-image: url('./all-black.png'); }
效果图:
嘿嘿,现在就像那么回事了,不过因为被高斯
Le style pixel
est en fait une impuissance historique. Les limitations des conditions matérielles obligent les développeurs de jeux à choisir ce type de haute liquidité
et de surcharge de performances
faible style artistique. Cependant, aujourd'hui
, le style pixel est toujours populaire dans divers domaines, et on lui a donné des significations plus esthétiques
et rétro
. 🎜< img src ="https://img.php.cn/upload/image/128/187/946/164791698029272Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !" title="164791698029272Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !" alt="Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !"/>
[Amour Image] 🎜🎜Pour transformer une telle image en pixels, la première idée m'est venue à l'esprit : 🎜
premier rendez-vous
de mon collègue Ayang ne serait-il pas complètement gâché ? flou (flou gaussien)
via un filtre CSS, obtenant visuellement l'effet de prendre la valeur médiane et de remplir le div
. 🎜🎜faire en sorte que chaque div contienne une partie de l'image ?
🎜🎜Oh, ce n'est pas un problème pour moi qui ai grand cœur d'aider mes collègues
. 🎜.mask-item { /* 以下为更改 */ filter: blur(8px) contrast(400%) saturate(400%); }
Cela devient comme ça
, car l'arrière-plan de chaque image commence à partir du coin supérieur gauche, donc cela ne répond certainement pas aux attentes. 🎜🎜🎜🎜Connectez-vous Suivant : Nous devons insérer cette phrase dans le parcours js : 🎜rrreee🎜La fonction de cette ligne de code est d'attribuer un style background-position
à chaque élément .mask-item, et de calculer tous les Le coin supérieur gauche de l'image d'arrière-plan de l'élément .mask-item chevauche un point de coordonnées
. 🎜🎜L'effet est comme indiqué sur l'image : 🎜🎜🎜🎜3. Ajouter un intervalle et un flou gaussien
Selon l'idée, il suffit d'ajouter un espacement au div
, puis d'ajouter un flou gaussien
pour obtenir l'effet.
Le code est donc le suivant : 🎜rrreee🎜Mais l'effet est : 🎜🎜🎜🎜Qu'est-ce qui n'a pas fonctionné exactement ? Flou gaussien
affecte en fait les zones en dehors de la boîte intérieure
! ! 🎜à cause de la Gaussienne
, la couleur est beaucoup plus claire. Ce n'est pas grave, ajustez-la simplement. 🎜🎜🎜Ajustez la couleur🎜🎜🎜Le code est le suivant :🎜.mask-item { /* 以下为更改 */ filter: blur(8px) contrast(400%) saturate(400%); }
大功告成!!
万万没想到,同事阿洋还是没能
完成和产品妹妹小美的约会。
原因居然是:产品妹妹觉得我写代码的样子过于靓仔,非要和我约会!
--全剧终--
(学习视频分享: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!