广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >如何利用CSS处理图片转为像素风
  • 841
分享到

如何利用CSS处理图片转为像素风

2024-04-02 19:04:59 841人浏览 薄情痞子
摘要

小编给大家分享一下如何利用CSS处理图片转为像素风,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是像素风?像素风是一种以固定

小编给大家分享一下如何利用CSS处理图片转为像素风,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

什么是像素风?

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

如何利用CSS处理图片转为像素风

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

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

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

思路分析

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

如何利用CSS处理图片转为像素风
[爱心图]

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

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

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

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

主体思路如下:

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

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

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

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

实施

其实不难:

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

如何利用CSS处理图片转为像素风

代码:

<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 元素设置一个心形背景

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

如何利用CSS处理图片转为像素风

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

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

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

效果如图:

如何利用CSS处理图片转为像素风

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

.mask-group {
  
  grid-row-gap: 2px;
  grid-column-gap: 2px;
}
.mask-item {
  
  filter: blur(8px)
}

但是效果却:

如何利用CSS处理图片转为像素风

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

  1. mask-image 限定可视区域

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

.mask-item {
  
  -WEBkit-mask-image: url('./all-black.png');
  mask-image: url('./all-black.png');  
}

效果图:

如何利用CSS处理图片转为像素风

嘿嘿,现在就像那么回事了,不过因为被高斯的原因,颜色淡了不少,没事,微调一下即可。

  1. 调整颜色

代码如下:

.mask-item {
  
  filter: blur(8px) contrast(400%) saturate(400%);
}

如何利用CSS处理图片转为像素风

以上是“如何利用CSS处理图片转为像素风”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网VUE频道!

--结束END--

本文标题: 如何利用CSS处理图片转为像素风

本文链接: https://www.lsjlt.com/news/94966.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何利用CSS处理图片转为像素风
    小编给大家分享一下如何利用CSS处理图片转为像素风,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是像素风?像素风是一种以固定...
    99+
    2022-10-19
  • 如何使用Python将图片转为漫画风格
    本篇内容主要讲解“如何使用Python将图片转为漫画风格”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用Python将图片转为漫画风格”吧!安装OpenCV首先,我们需要安装OpenCV。...
    99+
    2023-07-06
  • 如何利用Python将彩色图像转为灰度图像
    小编给大家分享一下如何利用Python将彩色图像转为灰度图像,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!第一种方法Python的cv2库中自带彩色转灰度的方法,...
    99+
    2023-06-22
  • 如何利用python实现图片批处理
    前言 在训练神经网络之前,我们往往需要对数据集进行批量处理。本文以图片为例,介绍如何使用python实现图片的批量处理,包括批量命名,批量更改图像像素,批量对图片进行Harris、C...
    99+
    2022-11-12
  • 详解如何使用OpenCV和像素处理图像灰度化
    目录数字图像处理图像读入和通道结构像素级灰度化处理不同算法之间的效果比较图像灰度化的输出和显示数字图像处理 在数字图像处理中,我们经常需要将彩色图像转换为灰度图像,以便应用各种算法。...
    99+
    2023-05-17
    OpenCV 像素图像灰度化 OpenCV 图像处理
  • 如何使用icon fonts来辅助CSS处理图片
    这篇文章主要讲解了“如何使用icon fonts来辅助CSS处理图片”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用icon fonts来辅助CSS处...
    99+
    2022-10-19
  • 如何使用批处理实现css和js图片压缩
    这篇文章主要介绍如何使用批处理实现css和js图片压缩,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!代码如下:@echo off ::设置YUI Compressor启动目录 ...
    99+
    2023-06-08
  • 如何在Android中利用ImageView.src对图片进行拉伸处理
    如何在Android中利用ImageView.src对图片进行拉伸处理?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。方法如下:<LinearLayout andro...
    99+
    2023-05-31
    imageview android age
  • 如何利用MySQL和C++开发一个简单的图片处理功能
    要利用MySQL和C++开发一个简单的图片处理功能,你可以按照以下步骤进行:1. 创建一个MySQL数据库,并设计一个表来存储图片的...
    99+
    2023-10-21
    MySQL
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作