我的编程空间,编程开发者的网络收藏夹
学习永远不晚

CSS处理图像上文字的方法有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

CSS处理图像上文字的方法有哪些

这篇文章给大家分享的是有关CSS处理图像上文字的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

什么是css

css是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。它也是一种定义样式结构如字体、颜色、位置等的语言,并且css样式可以直接存储于HTML网页或者单独的样式单文件中,而样式规则的优先级由css根据这个层次结构决定,从而实现级联效果,发展至今,css不仅能装饰网页,也可以配合各种脚本对于网页进行格式化。

做项目过程中,我们可能会遇到这样的一个组件,该组件的图像上方是文本。 在某些情况下,根据所使用的图像,文字难以阅读,如文字是白色的,背景图偏浅。

这种情况有一些不同的解决方案,例如添加渐变叠加或着色的背景图像,文本阴影等。

简介

每个解决方案都应该解决一个问题。 我们来探讨本案的问题。 在设计图像上方有文字的组件时,我们需要注意使文字必须易于阅读的。

CSS处理图像上文字的方法有哪些

注意上图上,没有渐变覆盖的版本几乎不可读,这是对用户不利。 为了解决这个问题,我们需要在文本下方添加一个图层,便于阅读。 添加图层也有要注意的地方。因为,很多解决方案中没有考虑到可访问性。

多种解决方案

有多种解决方案可以使文本更易于阅读。 我们逐一看看。

CSS处理图像上文字的方法有哪些

如上图所示,针对此问题有不同的解决方案。 需要注意的是渐变的解决方案。 为什么? 因为这种方案容易让文本失去可以访问性。

(学习视频分享:css视频教程)

解决方案

The Gradient Overlay(渐变叠加)

一般而言,渐变叠加是让图像上的文字更加清晰的最常见解决方案,所以,我们重点来看看。

实现渐变叠加时,有两种方式:

  • 使用单独的元素进行渐变(伪元素或空的<p>

  • 应用渐变作为背景图像。

以上每一种方法都有其优点和缺点,我们一起来看看。

.card__content {  position: absolute;    background: linear-gradient(to top, rgba(0, 0, 0, 0.85), transparent);}

CSS处理图像上文字的方法有哪些

乍一看,你可能会认为渐变效果很好,这是不够全面的。如果用更多样的图片测试了同样的渐变效果,结果如下:

CSS处理图像上文字的方法有哪些

白色文本和图像之间的对比度并不总是很清晰。 对于某些人来说,可以接受,但是使用这种渐变是一个巨大的错误,因为文字无法访问。

原因是该渐变在垂直方向上应覆盖更多的空间,因此它的高度需要更大。 渐变等于内容的大小在所有情况下都无法使用。 为了解决这个问题,我们可以使用min-height,如下所示:

  • .card__content元素的min-height

  • Flexbox 将内容推到底部。

.card__content {  position: absolute;    display: flex;  flex-direction: column;  justify-content: flex-end;  background: linear-gradient(to top, rgba(0, 0, 0, 0.85), transparent);}

另一种解决方案是仅使用padding-top 来代替min-heightflexbox

.card__content {  position: absolute;  padding-top: 60px;  background: linear-gradient(to top, rgba(0, 0, 0, 0.85), transparent);}

请注意左卡和右卡之间的差异,渐变高度较大。

那看起来不错,我们可以做得更好吗? 当然是!

缓渐变

如果仔细观察,我们会发现渐变结束的地方很突兀,这家就是所谓的硬边现象。

为了使它更好,我们可以将缓动概念应用于渐变。 这样一来,渐变将显得更加自然,并且在渐变结束时也不会注意到硬边。

CSS处理图像上文字的方法有哪些

在CSS中,我们需要有多个渐变停止点来实现缓动,因为在撰写本文时还没有原生的方法可以做到这一点。 好消息是CSS工作组正在讨论在CSS渐变中实施缓动的可能性,但何时实现尚不明确。

值得庆幸的是,Andreas Larsen先生创建了一个方便的PostCSS和Sketch插件,可将正常渐变转换为简化的渐变。

这是上面例子的CSS渐变:

.card__content {  background-image: linear-gradient(    0deg,    hsla(0, 0%, 35.29%, 0) 0%,    hsla(0, 0%, 34.53%, 0.034375) 16.36%,    hsla(0, 0%, 32.42%, 0.125) 33.34%,    hsla(0, 0%, 29.18%, 0.253125) 50.1%,    hsla(0, 0%, 24.96%, 0.4) 65.75%,    hsla(0, 0%, 19.85%, 0.546875) 79.43%,    hsla(0, 0%, 13.95%, 0.675) 90.28%,    hsla(0, 0%, 7.32%, 0.765625) 97.43%,    hsla(0, 0%, 0%, 0.8) 100%  );}

CSS处理图像上文字的方法有哪些

水平渐变

处理图片上的文字不仅可以是垂直的,我们还可以将它们用作水平渐变。 像下面这种情况,它需要一个水平渐变。

CSS处理图像上文字的方法有哪些

这是上面的CSS渐变,我使用了前面提到的工具来生成缓和的渐变。

background: linear-gradient(  to right,  hsl(0, 0%, 0%) 0%,  hsla(0, 0%, 0%, 0.964) 7.4%,  hsla(0, 0%, 0%, 0.918) 15.3%,  hsla(0, 0%, 0%, 0.862) 23.4%,  hsla(0, 0%, 0%, 0.799) 31.6%,  hsla(0, 0%, 0%, 0.73) 39.9%,  hsla(0, 0%, 0%, 0.655) 48.2%,  hsla(0, 0%, 0%, 0.577) 56.2%,  hsla(0, 0%, 0%, 0.497) 64%,  hsla(0, 0%, 0%, 0.417) 71.3%,  hsla(0, 0%, 0%, 0.337) 78.1%,  hsla(0, 0%, 0%, 0.259) 84.2%,  hsla(0, 0%, 0%, 0.186) 89.6%,  hsla(0, 0%, 0%, 0.117) 94.1%,  hsla(0, 0%, 0%, 0.054) 97.6%,  hsla(0, 0%, 0%, 0) 100%);

混合纯色和渐变

这里从Netflix网站了解了这种模式。 在未登录用户的主页上,有一个带有大背景图像的标题。

CSS处理图像上文字的方法有哪些

我喜欢它,但是它隐藏了很多图像细节。 确保仅在图像具有装饰性时才使用此功能。

<div class="hero">  <img class="lazy" data-src="cover.jpg" alt="" />  <div class="hero__content">    <h3>Unlimited movies, TV shows, and more.</h3>    <p>Watch anywhere. Cancel anytime.</p>  </div></div>```<div class="hero">  <img class="lazy" data-src="cover.jpg" alt="" />  <div class="hero__content">    <h3>Unlimited movies, TV shows, and more.</h3>    <p>Watch anywhere. Cancel anytime.</p>  </div></div>
.hero:after {  content: "";  position: absolute;  left: 0;  top: 0;  width: 100%;  height: 100%;  background-color: rgba(0, 0, 0, 0.4);  background-image: linear-gradient(    to top,    rgba(0, 0, 0, 0.8),    rgba(0, 0, 0, 0) 60%,    rgba(0, 0, 0, 0.8) 100%  );}

下面是拆解过程。

CSS处理图像上文字的方法有哪些

渐变叠加和文本阴影

有一个很有用的小技巧,可以让文字比图像更好。就是使用 text-shadow,这可能不容易注意到,但在图像无法加载的情况下,这是非常有用的。

看下面的例子:

.whatever-text {  text-shadow: 0 2px 3px rgba(0, 0, 0, 0.3);}

CSS处理图像上文字的方法有哪些

渐变叠加,文本阴影和不透明度

这是在Facebook的视频播放器上注意到的模式。 他们使用多种技术来使文本(和其他UI元素)清晰可见。 与视频播放器打交道时,确保其上方的元素应引人注目非常重要。

CSS处理图像上文字的方法有哪些

.player__icon {  opacity: 0.9;}.player__time {  color: #fff;  text-shadow: 0 0 5px #fff;}

播放图标为opacity: 0.9。 这有助于使它们与下面的背景融为一体。 给人一种感觉:控件是混合在一起的。

此外,在白色文本中使用白色文本阴影是使文本更清晰的有效方法。你是否想要证明,即使背景是完全白色的图像,上面的方法也可以工作?给你。

CSS处理图像上文字的方法有哪些

YouTube也对他们的视频做类似的事情。

CSS处理图像上文字的方法有哪些

径向渐变

我从Netflix了解到的一个有趣的解决方案是使用径向渐变。 下面是它的工作原理:

  • 设置底色背景颜色。

  • 将图像以75%的宽度放置到右上角。

  • 覆盖层等于图像的大小和位置。

CSS处理图像上文字的方法有哪些

.hero {  background-color: #000;  min-height: 300px;}.hero__image {  position: absolute;  right: 0;  top: 0;  width: 75%;  height: 100%;  object-fit: cover;}.hero:after {  content: "";  position: absolute;  right: 0;  top: 0;  width: 75%;  height: 100%;  background: radial-gradient(    ellipse 100% 100% at right center,    transparent 80%,    #000  );}

不过,Netflix团队使用了一张图像作为覆盖层。这里不能确定原因,可能是一个跨浏览器的问题或其他东西。

选择可访问的覆盖颜色

这是一个很棒的工具,可以帮助我们根据图像选择正确的叠加不透明度。

CSS处理图像上文字的方法有哪些

一般而言,如果你确保渐变叠加层可以正确填充文本,并且具有不错的色彩对比,那就可以了。

测试

解决方案要经过测试,才能被认为是好的,对吧? 我用来测试渐变叠加层的一种方法是在其下方添加白色背景。 如果文本可读,则渐变将适用于我们使用的任何图像。 如果没有,则需要进行调整和增强。

CSS处理图像上文字的方法有哪些

在上面的例子中,我选择了标题下的纯色,对比度是4.74,这样比较好。

感谢各位的阅读!关于“CSS处理图像上文字的方法有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

CSS处理图像上文字的方法有哪些

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

下载Word文档

猜你喜欢

CSS处理图像上文字的方法有哪些

这篇文章给大家分享的是有关CSS处理图像上文字的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。什么是csscss是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加
2023-06-14

C#的Bitmap图像处理方法有哪些

本篇内容介绍了“C#的Bitmap图像处理方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Bitmap类Bitmap对象封装了GDI
2023-06-25

Web中文字体处理的方法有哪些

本篇内容介绍了“Web中文字体处理的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!背景介绍Web 项目中,使用一个合适的字体能给用
2023-06-27

Torch中的图像处理模块有哪些

Torch中的图像处理模块主要包括以下几个:torchvision.transforms:用于图像的常见变换和预处理操作,如缩放、裁剪、旋转、翻转等。torch.nn.functional:包含一些图像处理相关的函数,如卷积操作、池化操作、
Torch中的图像处理模块有哪些
2024-03-08

常用的图像处理软件有哪些

常用的图像处理软件有:1、照片修图,一款手机的专属修图小工具;2、ps修图软件,特别专业的一款手机应用软件;3、天天P图,特别有趣的一款修图手机应用app;4、照片编辑P图,专门为修图推出的一款功能非常强大的软件;5、P图照片编辑器等等。常
2023-07-10

python的文本处理方法有哪些

今天小编给大家分享一下python的文本处理方法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、字符串常量1.1、定
2023-06-04

python处理字符串的方法有哪些

Python处理字符串的常用方法有以下几种:字符串拼接:使用"+"操作符将两个字符串连接起来。字符串切片:使用索引来截取字符串的部分内容。字符串长度:使用len()函数获取字符串的长度。字符串格式化:使用.format()方法或f字符
python处理字符串的方法有哪些
2024-02-29

python字符串处理的方法有哪些

Python中字符串处理的方法有很多,以下是其中一些常用的方法:切片:可以使用索引和切片操作来获取字符串的子串。例如,使用`str[start:end]`可以获取从索引`start`到`end-1`之间的子串。连接:使用`+`运算符可以将两
2023-10-24

golang字符串处理的方法有哪些

在Go语言中,有许多内置的字符串处理方法和函数。以下是一些常用的方法:len(str):返回字符串的长度。str[index]:返回字符串中指定索引位置的字符。str[start:end]:返回字符串中指定范围的子串。strings.
2023-10-22

Golang的字符串处理方法有哪些?

标题:Golang的字符串处理方法及代码示例Golang是一种快速、简洁并且高效的编程语言,它提供了丰富的字符串处理方法,让开发者能够轻松对字符串进行各种操作。在本文中,我们将介绍一些常用的Golang字符串处理方法,并提供具体的代码示例
Golang的字符串处理方法有哪些?
2024-03-13

Python传统图像处理皮肤区域检测的方法有哪些

这篇文章主要介绍“Python传统图像处理皮肤区域检测的方法有哪些”,在日常操作中,相信很多人在Python传统图像处理皮肤区域检测的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python传统图
2023-06-21

常用的Matlab图像处理函数有哪些

常用的Matlab图像处理函数有以下几个:imread:用于读取图像文件并将其存储为矩阵形式的图像。imshow:用于显示图像。imresize:用于调整图像的大小。imrotate:用于旋转图像。imfilter:用于应用各种滤波
2023-10-24

php多文件处理的方法有哪些

PHP有多种方法可以处理多个文件,以下是一些常见的方法:1. 使用for循环遍历文件列表:可以使用`opendir()`函数打开一个文件夹,然后使用`readdir()`函数读取文件列表,并使用for循环处理每个文件。```php$dir
2023-09-26

python中有哪些处理字符串的方法

本篇文章给大家分享的是有关python中有哪些处理字符串的方法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、join:将一个序列中的元素用某个字符(串)拼接,组成一个大的字
2023-06-15

Python中有哪些处理文件方法

这篇文章给大家介绍Python中有哪些处理文件方法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1 、读取文件数据文本文件可存储的数据量非常丰富,像天气数据、交通数据、文学作品等。每当我们需要分析或修改储存在文件中的信
2023-06-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录