给你点儿“颜色”瞧瞧
myzbx 2024-12-04 13:56 44 浏览
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。
任何一个和用户有交互的产品,都离不开颜色,你是否在设计稿或代码中或者任何一个标识颜色的地方看到过,比如:#FF00FF、#169、#CCFF00FF。
先介绍下RGB的基本原理,RGB是Red、Green、Blue三种颜色的缩写,叫做三原色(小学的图画课应该是学过的)。三种颜色以最大亮度进行混合的话,会变成白色,哇,好神奇。
整个理论以下图所示,假设在一个没有一点光的小黑屋里面,墙面展示为黑色,打开三束灯,分别红,绿,蓝,中间三种颜色交叉的地方,就形成了白色。也就是这些光会叠加产生效果,并混合成新的颜色。
当前无论手机还是计算机,究竟支持多少种颜色呢?答案是都达到了真彩色的标准,也就是支持1670w种颜色,已经超过了人眼能够分辨颜色的极限了,1670w这个数字怎么来的,一会儿我们一起推算。
一般一种颜色用8bit表示,也就是01010101这样8个二进制数,2的8次方是256,所以一个颜色就分为256级,从0到255,共256级,0表示黑色(红灯还没打开),255标识红色强度最大(红灯已全部打开),这个时候255对应的二进制为11111111(你如果懂二进制的知识的话,应该很好看懂),这样RGB三种颜色分别用8为表示的话,一共24位表示一个颜色,例如111111111111111111111111,表示了RGB都是255级的亮度,也就是表示了上图当中最中间交叉的那个部分,也就是表示了白色。
但是二进制表示计算机读起来比较容易,因为计算机处理的就是01的字串,但是人可读性并不好,所以人类用16进制来标识二进制,会所见01字串的长度,16进制的意思就是逢16进1,但是我们的阿拉伯数字最大是9,那对于10到15的六个数字分别用A,B,C,D,E,F来表示,1111应该用F来表示,所以白色用16进制表示为FFFFFF,在web开发或设计中,前面加上#号标识颜色,所以你就看到了文章开头介绍的颜色表示法#FFFFFF这样的形式,在CSS设计中,如果FF这样重叠的数字,可以再进行一次缩减标识为#FFF,类似#CCFF00FF前面的CC是表示的Alpha通道,即标识的透明度。
RGB三种颜色分别有256级亮度,那三种颜色的组合数就是256*256*256=16777216,也就是2的24次方,所以分别用8位RGB来表示的颜色数量公用1670w种颜色,足以覆盖人类眼睛的辨识程度。
再介绍下经常提到的位深度的概念,在windows系统中,右键属性一张图片,看详细信息,如下图:
这里面的位深度就是指一张图片内的一个像素是用多少位来表示的,如我们刚才介绍的RGB分别是8位,位深度就是24,这种图片叫做RGB24,当然这个只是指RGB总共的二进制位数,也有可能是32位叫做RGB32,除了RGB的24位,剩余的8为表示Alpha通道,也就是透明信息,当前的交互和动画展现,如果没有Alpha,那做起来应该都是比较生硬的,一般都会用Alpha表示渐隐渐显的效果,在图片中是用来将图片中层叠的概念表达的更加清楚。
一般有如下几种RGB格式,包括RGB565,RGB24,RGB32,ARGB8888,最后一种的A表示Alpha,跟刚才介绍的RGB32差不多一个意思。
像RGB565这种用16位表示一个颜色,那只能表示2的16次方,表达出65536种颜色,但是好处是非常节省内存(因为一个像素只用32位一半的数据就能存储了),但是会损失图片的清晰度,一般用于纯色图片或这本身颜色就比较少的图片,会大幅减少内存的占用。
本篇基本介绍了计算机中三原色的原理,及你见过的一些陌生的颜色值的表示方法,几个简单的推理方法,介绍了下位深度的概念。当内存和图片质量发生冲突时,可考虑设计上用纯色或极其简单的颜色来设计,然后将图片用更少的位数表达,这样会大幅节省内存,前提是设计上能够保持简洁并能够达到设计效果。
再跟大家算个帐,一张图片假设是1920*1080的大小,那这张图片至少要占用1920*1080*4字节的内存,也就是4Mb,也即一个带有alpha通道的图片,都会是这个大小,唯一有处理空间的是没有alpha,并且颜色比较简单的图,可以用RGB565来表达,这样可以减小一半的内存占用,对于程序性能来说,是不小的提升,难道内存,速度,性能指标不是产品设计当中的重要一环和重要的考量指标吗?
颜色知识十分简单,希望以后不要对颜色感觉到任何陌生。
#专栏作家#
给产品经理讲技术,微信公众号(pm_teacher),人人都是产品经理专栏作家。资深程序猿,专注客户端开发若干年,对前端、后台技术略懂,热衷于对新的科技领域的探索。
相关推荐
- 如何设计一个优秀的电子商务产品详情页
-
加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...
- 怎么在JS中使用Ajax进行异步请求?
-
大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...
- 中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革
-
前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...
- 前端监控 SDK 开发分享_前端监控系统 开源
-
一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...
- Ajax 会被 fetch 取代吗?Axios 怎么办?
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...
- 前端面试题《AJAX》_前端面试ajax考点汇总
-
1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...
- Ajax 详细介绍_ajax
-
1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...
- 6款可替代dreamweaver的工具_替代powerdesigner的工具
-
dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...
- 我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊
-
接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...
- 福斯《死侍》发布新剧照 "小贱贱"韦德被改造前造型曝光
-
时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...
- 2021年超详细的java学习路线总结—纯干货分享
-
本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...
- 不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!
-
Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...
- 2025 年 Python 爬虫四大前沿技术:从异步到 AI
-
作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...
- 最贱超级英雄《死侍》来了!_死侍超燃
-
死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...
- 停止javascript的ajax请求,取消axios请求,取消reactfetch请求
-
一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)
