Maison  >  Article  >  interface Web  >  Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

青灯夜游
青灯夜游avant
2022-03-22 10:56:453577parcourir

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 !

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

Qu'est-ce que le style pixel ?

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~像素风是一种以固定大小纯色像素方块作为基本单元,进行创作,包含但不限于绘画建筑游戏更各个领域的一种美术风格。
其中最让人耳熟能详的,当然是早期电子游戏的像素画面啦~

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

[早期红白机上"马里奥"的像素形象]

当然,早期电子游戏采用像素风,实际上是一种历史的无奈,硬件条件的限制,让游戏开发者不得不选择这种变现力强性能开销低的美术风格。

不过,时至今日像素风在各个领域依然潮流,则被赋予了更多审美复古上的意义。

思路分析

先看看本次要处理的“爱心图”的原图:

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !
[爱心图]

要将一张这样的图片变成像素,我脑海里首先蹦出了第一个思路:

思路一:通过canvas切割和填充

使用canvas将图片切割成N*N块,然后每块区域单独计算取色彩中值,并将其填充为实色,没错,这个思路无疑是可以很快且灵活的解决问题的。
但这样一来,没使用到CSS,同事阿洋的第一次约会岂不是就完全泡汤了?
❌❌
不行不行!我得换个思路,用CSS来实现!(推荐学习:css视频教程

思路二:大半径高斯模糊滤镜来取中值

主体思路如下:

  • 将图片分成N个div,每个div都持有图片的一部分。

  • 每个div都通过css-filter来进行一次blur(高斯模糊),视觉上达到取中值并填充div的效果。

按这个思路,其实只有一个难点,如何让每个div都持有图片的一部分?

呵,这可难不倒我那颗帮助同事大心脏

实施

其实不难:

  • 首先,我们用8*8将一个div分成64份,毫无疑问的grid布局。

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

代码:

<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(&#39;.mask-group&#39;)
    for(let i = 0; i< 64; i++) {
      const itemEl = document.createElement(&#39;div&#39;)
      itemEl.className = &#39;mask-item&#39;
      el.appendChild(itemEl)
    }
  }
</script>
  • 然后我们给每个.mask-item 元素设置一个心形背景

然后效果就变成了这样,因为每一张的背景都是从左上角开始的,因此肯定不符合预期。

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

接下来:我们需要在js的遍历中插入这么一句:

itemEl.style.backgroundPosition = `-${Math.floor(i%8) * 16}px -${Math.floor(i/8) * 16}px `

这行代码的作用,是给每一个.mask-item元素单独赋予一个background-position样式,通过计算让所有.mask-item元素的背景图的左上角都重叠到了一个坐标点上

效果如图:

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

3. 增加间隔和高斯模糊 按照设想,我们只需要给div加上间隔,再给上高斯模糊,就能达到效果了。 于是代码如下:

.mask-group {
  /* 以下为新增 */
  grid-row-gap: 2px;
  grid-column-gap: 2px;
}
.mask-item {
  /* 以下为新增 */
  filter: blur(8px)
}

但是效果却:

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

到底是哪里出了问题?
高斯模糊居然会作用到inner-box以外的区域!!

  1. mask-image 限定可视区域

没办法,为了限定高斯模糊的效果区域,我只能通过mask-image了。
先弄一张16*16像素的纯黑all-black.png文件。
代码如下:

.mask-item {
  /* 以下为新增 */
  -webkit-mask-image: url(&#39;./all-black.png&#39;);
  mask-image: url(&#39;./all-black.png&#39;);  
}

效果图:

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

嘿嘿,现在就像那么回事了,不过因为被高斯

Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !
  1. [L'image en pixels de "Mario" sur la première Famicom]
Bien sûr, les premiers jeux vidéo utilisaient 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 performancesfaible 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. 🎜

Analyse d'idées🎜🎜Premier coup d'œil à l'image originale de la "photo d'amour" à traiter cette fois : 🎜


[Amour Image] 🎜🎜Pour transformer une telle image en pixels, la première idée m'est venue à l'esprit : 🎜

Idée 1 : Découper et remplir la toile

🎜Utiliser la toile pour couper l'image en blocs N*N, puis calculez la couleur médiane de chaque zone séparément et remplissez-la d'une couleur unie. Oui, cette idée peut sans aucun doute résoudre le problème de manière rapide et flexible.
Mais dans ce cas, sans utiliser CSS, le premier rendez-vous de mon collègue Ayang ne serait-il pas complètement gâché ?
❌❌
Non, non ! Je dois changer d'avis et utiliser CSS pour l'implémenter ! (Apprentissage recommandé : tutoriel vidéo CSS) 🎜

Idée 2 : Filtre de flou gaussien à grand rayon pour obtenir la valeur médiane

🎜L'idée principale est la suivante : 🎜
    🎜🎜Diviser l'image en N divs, chaque div contient une partie de l’image. 🎜🎜🎜🎜Chaque div est flou (flou gaussien) via un filtre CSS, obtenant visuellement l'effet de prendre la valeur médiane et de remplir le div. 🎜🎜
🎜Selon cette idée, il n'y a en fait qu'une seule difficulté : Comment 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. 🎜

Ce n'est pas difficile à mettre en œuvre 🎜🎜 : 🎜
    🎜🎜Tout d'abord, nous utilisons 8*8 pour diviser un div into 64 Il n'y a aucun doute sur la disposition de la grille. 🎜🎜
🎜Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !🎜🎜Code : 🎜
.mask-item {
  /* 以下为更改 */
  filter: blur(8px) contrast(400%) saturate(400%);
}
    🎜🎜Ensuite, nous définissons un arrière-plan en forme de cœur pour chaque élément .mask-item🎜🎜
🎜Ensuite, l'effet est 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. 🎜🎜Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !🎜🎜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 : 🎜🎜Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » ! 🎜🎜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 : 🎜🎜Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !🎜🎜Qu'est-ce qui n'a pas fonctionné exactement ?
Flou gaussien affecte en fait les zones en dehors de la boîte intérieure ! ! 🎜
    🎜masque-image limite la zone visible🎜🎜🎜Pas question, afin de limiter la zone d'effet de flou gaussien, je ne peux utiliser que masque-image.
    Créez d'abord un fichier all-black.png noir pur de 16*16 pixels.
    Le code est le suivant : 🎜rrreee🎜Rendu : 🎜🎜Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !🎜🎜Hé, c'est comme ça maintenant, mais à 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%);
    }

    Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

    大功告成!!

    故事结局

    万万没想到,同事阿洋还是没能完成和产品妹妹小美的约会。
    原因居然是:
    产品妹妹觉得我写代码的样子过于靓仔,非要和我约会!

    Vous pouvez également utiliser CSS pour traiter les images et les transformer en « style pixel » !

    --全剧终--

    (学习视频分享: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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer