【Android 应用开发】Paint 图形组合 Xfermod 简介 ( 图形组合集合描述 | Xfermod 简介 | PorterDuff 简介 )

简介: 【Android 应用开发】Paint 图形组合 Xfermod 简介 ( 图形组合集合描述 | Xfermod 简介 | PorterDuff 简介 )

图形组合 集合描述


图形组合 集合描述 :


1.下面我们先描述两个集合 :


① 集合 A : 由像素点组成的集合 A , 每个像素点都有颜色值 和 位置 属性 ; 像素点组成的图形如下 :

image.png

② 集合 B : 由像素点组成的集合 B , 每个像素点都有颜色值 和 位置 属性 ; 像素点组成的图形如下 :

image.png

2.绘制区域指定 :


① 并集 A ∪ B A \cup BA∪B 绘制 :

image.png

② 交集 A ∩ B A \cap BA∩B 绘制 :

image.png

③ 相对补集 A − B A - BA−B ( 属于集合A 不属于集合B ) 绘制 :

image.png

④ 相对补集 B − A B - AB−A ( 属于集合B 不属于集合A ) 绘制 :

image.png

3.绘制像素点颜色指定 : 在确定了绘制区域后 , 然后再确定绘制区域内的像素点颜色 :

image.png

① 交集重叠区域 绘制 集合 A 的像素点颜色 ;

image.png

② 交集重叠区域 绘制 集合 B 的像素点颜色 ;

image.png

③ 交集重叠区域 绘制 集合 A 与 集合 B 两个像素点颜色经过某种运算之后的颜色 ;

image.png

④ 某区域 ( 集合 A 区域 , 集合 B 区域 , 交集区域 ⋯ \cdots⋯ 等等 ) 清空区域内的像素点颜色 , 即透明 ;


4.图形组合 ( Xfermod ) : Xfermod 中定义了绘制各种区域 和 每个像素点颜色的 方式和规范 :


① 指定绘制区域 : 像素点集合 A 与 B 的交集 , 并集 , 补集 ( 相对补集 − -− | 绝对补集 ∼ \sim∼ ) , 对称差 等像素点集合区域 ;

② 指定绘制区域像素点的颜色 : 绘制的像素点颜色进行计算 , 清空颜色 , 绘制集合A中的像素点颜色 , 绘制集合 B 中的像素点颜色 , 绘制两个集合中对应的像素点进行某种计算后的颜色 ;



Xfermod 简介


Xfermod 简介 :


操作的载体 : 像素是要操作的元素 , 图形组合 控制的是图像指定 像素 的位置的颜色值 ;

操作过程 : 将要绘制的图形的像素 ( 源图像 Souurce ) 与 画布上对应位置的像素 ( 目标图像 Destination ) , 按照一定规则完成 两个 图像的组合 ;

常用的 Xfermod 类 : Xfermod 有三个子类分别是 :

① AvoidXfermode : 已过时 , 不支持硬件加速 , 不再研究 ;

② PixelXorXfermode : 已过时 , 不在研究 ;

③ PorterDuffXfermode : 该图形组合模式是目前使用的主流方式 , 也是唯一方式 , 下面详细讲述该类型的图形组合 ;



PorterDuff 由来


PorterDuff 由来 :


1.重要论文 : Thomas Porter ( 托马斯 ⋅ \cdot⋅ 波特 ) 和 Tom Duff ( 汤姆 ⋅ \cdot⋅ 达夫 ) 在 1984年 发表的一篇具有重大意义的论文 , 其名称是 “Compositing Digital Images” ( 组合数字图像 ) ;

2.名称由来 : PorterDuff 图形组合模式 类名称 , 是向其所做的工作致以敬意 ;

3.论文内容 : 在这篇论文中 , 两位作者描述了 12 种图形合成运算符 ,

4.合成运算符作用 ( 控制颜色 ) : 源图像 与 目标图像 进行组合 , 其组合结果的对应位置像素有对应的颜色值 , 合成运算符就是控制这个颜色值是多少 ;

① 目标图像 ( Destination ) : 渲染目标的内容 ( The content of the render target ) ;

② 源图像 ( Source ) : 要渲染的图形对象 ( The Graphics object to render ) ;



Xfermod 合成模式分类


Xfermod 合成模式分类 :


1.透明度合成模式 :

① 论文中定义 : Thomas Porter ( 托马斯 ⋅ \cdot⋅ 波特 ) 和 Tom Duff ( 汤姆 ⋅ \cdot⋅ 达夫 ) 的工作 仅侧重与 源 ( Source ) 和 目标 ( Destination ) 合成 结果 对透明度通道的影响 ;

② 原始论文中描述的 12 个合成操作符 , 被称为 “Alpha Compositing modes” ( 透明度合成模式 ) ;

2.混合合成模式 :

① 不被 Alpha 通道约束 : 这些模式同样定义了 源 和 目标 的合成结果 , 但其结果不被 Alpha ( 透明度 ) 通道约束 ;

② 为了方便起见 , PorterDuff 类中还提供了其它几种 Blending modes ( 混合合成模式 ) ;

这些混合合成模式不是 Thomas Porter ( 托马斯 ⋅ \cdot⋅ 波特 ) 和 Tom Duff ( 汤姆 ⋅ \cdot⋅ 达夫 ) 提出的 , 但是为了方便起见 , 还是将 几种 混合合成模式定义在了类中 ;


目录
相关文章
|
1月前
|
存储 XML 开发工具
探索安卓应用开发:从基础到进阶
在这篇文章中,我们将一起踏上安卓应用开发的旅程。不论你是编程新手还是希望提升技能的开发者,这里都有你需要的东西。我们会从最基础的概念开始,逐步深入到更复杂的主题。文章将涵盖开发环境设置、用户界面设计、数据处理以及性能优化等方面。通过理论与实践的结合,你将能够构建出既美观又高效的安卓应用。让我们一起开启这段技术之旅吧!
|
1月前
|
Android开发 Swift iOS开发
深入探索iOS与Android操作系统的架构差异及其对应用开发的影响
在当今数字化时代,移动设备已经成为我们日常生活和工作不可或缺的一部分。其中,iOS和Android作为全球最流行的两大移动操作系统,各自拥有独特的系统架构和设计理念。本文将深入探讨iOS与Android的系统架构差异,并分析这些差异如何影响应用开发者的开发策略和用户体验设计。通过对两者的比较,我们可以更好地理解它们各自的优势和局限性,从而为开发者提供有价值的见解,帮助他们在这两个平台上开发出更高效、更符合用户需求的应用。
|
22天前
|
搜索推荐 Android开发 开发者
安卓应用开发中的自定义控件实践
在安卓应用开发的广阔天地中,自定义控件如同璀璨的星辰,点亮了用户界面设计的夜空。它们不仅丰富了交互体验,更赋予了应用独特的个性。本文将带你领略自定义控件的魅力,从基础概念到实际应用,一步步揭示其背后的原理与技术细节。我们将通过一个简单的例子——打造一个具有独特动画效果的按钮,来展现自定义控件的强大功能和灵活性。无论你是初学者还是资深开发者,这篇文章都将为你打开一扇通往更高阶UI设计的大门。
|
1月前
|
缓存 监控 前端开发
探索Android应用开发之旅:从新手到专家
【10月更文挑战第42天】本文将带你踏上Android应用开发的旅程,无论你是初学者还是有经验的开发者。我们将一起探索如何从零开始创建你的第一个Android应用,并逐步深入到更高级的主题,如自定义视图、网络编程和性能优化。通过实际示例和清晰的解释,你将学会如何构建高效、吸引人的Android应用。让我们一起开启这段激动人心的旅程吧!
|
1月前
|
开发框架 前端开发 Android开发
探索安卓和iOS应用开发中的跨平台解决方案
【10月更文挑战第42天】在移动应用开发的广阔天地中,安卓和iOS系统如同两座巍峨的山峰,分别占据着半壁江山。开发者们在这两座山峰之间穿梭,努力寻找一种既能节省资源又能提高效率的跨平台开发方案。本文将带你走进跨平台开发的世界,探讨各种解决方案的优势与局限,并分享一些实用的代码示例,助你在应用开发的道路上更加游刃有余。
|
1月前
|
搜索推荐 前端开发 Android开发
安卓应用开发中的自定义视图实现
【10月更文挑战第30天】在安卓开发的海洋中,自定义视图是那抹不可或缺的亮色,它为应用界面的个性化和交互体验的提升提供了无限可能。本文将深入探讨如何在安卓平台创建自定义视图,并展示如何通过代码实现这一过程。我们将从基础出发,逐步引导你理解自定义视图的核心概念,然后通过一个实际的代码示例,详细讲解如何将理论应用于实践,最终实现一个美观且具有良好用户体验的自定义控件。无论你是想提高自己的开发技能,还是仅仅出于对安卓开发的兴趣,这篇文章都将为你提供价值。
|
1月前
|
前端开发 Android开发 UED
安卓应用开发中的自定义控件实践
【10月更文挑战第35天】在移动应用开发中,自定义控件是提升用户体验、增强界面表现力的重要手段。本文将通过一个安卓自定义控件的创建过程,展示如何从零开始构建一个具有交互功能的自定义视图。我们将探索关键概念和步骤,包括继承View类、处理测量与布局、绘制以及事件处理。最终,我们将实现一个简单的圆形进度条,并分析其性能优化。
|
Android开发
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
316 0
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
|
前端开发 Android开发
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(一)
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(一)
429 0
|
21天前
|
搜索推荐 前端开发 API
探索安卓开发中的自定义视图:打造个性化用户界面
在安卓应用开发的广阔天地中,自定义视图是一块神奇的画布,让开发者能够突破标准控件的限制,绘制出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战技巧,逐步揭示如何在安卓平台上创建和运用自定义视图来提升用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你打开新的视野,让你的应用在众多同质化产品中脱颖而出。
42 19