加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

CSS中将图片处理成像素风格的思绪和方法是什么

发布时间:2023-09-13 14:10:07 所属栏目:语言 来源:
导读:这篇文章主要讲解了“CSS中将图片处理成像素风格的思路和方法是什么”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编
这篇文章主要讲解了“CSS中将图片处理成像素风格的思路和方法是什么”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。

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

[早期红白机上"马里奥"的像素形象]
 
当然,早期电子游戏采用像素风,实际上是一种历史的无奈,硬件条件的限制,让游戏开发者不得不选择这种变现力强,性能开销低的美术风格。
 
不过,时至今日像素风在各个领域依然潮流,则被赋予了更多审美和复古上的意义。
 
思路分析
 
要将一张这样的图片变成像素,我脑海里首先蹦出了第一个思路:
 
思路一:通过canvas切割和填充
 
使用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 限定可视区域
 
没办法,为了限定高斯模糊的效果区域,我只能通过mask-image了。
 
先弄一张16*16像素的纯黑all-black.png文件。
 
代码如下:
 
.mask-item {
 
  /* 以下为新增 */
 
  -webkit-mask-image: url('./all-black.png');
 
  mask-image: url('./all-black.png');  
 
}

嘿嘿,现在就像那么回事了,不过因为被高斯的原因,颜色淡了不少,没事,微调一下即可。
 
调整颜色
 
代码如下:
 
.mask-item {
 
  /* 以下为更改 */
 
  filter: blur(8px) contrast(400%) saturate(400%);
 
}

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

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章