当前位置: 首页 > news >正文

上海网站设计公司黄冈网站seo

上海网站设计公司,黄冈网站seo,企业网站美工设计,网站做全好吗ShaderClipBlendMaskBlitter 结构体实现了 Blitter trait,用于支持 带裁剪遮罩(Clip Mask)和自定义混合函数(Blend Function)的着色器渲染。它比之前的 ShaderClipMaskBlitter 更灵活,因为它允许外部传入一…

ShaderClipBlendMaskBlitter 结构体实现了 Blitter trait,用于支持 带裁剪遮罩(Clip Mask)和自定义混合函数(Blend Function)的着色器渲染。它比之前的 ShaderClipMaskBlitter 更灵活,因为它允许外部传入一个 自定义混合函数(blend_fn),而不是硬编码混合逻辑。

结构体定义

pub struct ShaderClipBlendMaskBlitter<'a> {pub x: i32,                     // 目标区域的起始 x 坐标pub y: i32,                     // 目标区域的起始 y 坐标pub shader: &'a dyn Shader,      // 着色器,用于生成像素颜色pub tmp: Vec<u32>,               // 临时缓冲区,存储着色器生成的像素pub dest: &'a mut [u32],         // 目标像素缓冲区(帧缓冲区)pub dest_stride: i32,            // 目标缓冲区的行跨度(每行的像素数)pub clip: &'a [u8],             // 裁剪遮罩(决定哪些像素允许绘制)pub clip_stride: i32,            // 裁剪遮罩的行跨度pub blend_fn: fn(&[u32], &[u8], &[u8], &mut [u32]), // 自定义混合函数
}

关键字段

字段用途
x, y目标绘制区域的起始坐标
shader生成像素颜色的着色器
tmp存储着色器生成的临时像素数据
dest目标帧缓冲区(最终绘制的位置)
dest_stride目标缓冲区的行跨度(用于非连续内存布局)
clip裁剪遮罩(决定哪些像素允许绘制)
clip_stride裁剪遮罩的行跨度
blend_fn自定义混合函数(核心改进点)

Blitter Trait 实现

impl<'a> Blitter for ShaderClipBlendMaskBlitter<'a> {fn blit_span(&mut self, y: i32, x1: i32, x2: i32, mask: &[u8]) {// 计算目标缓冲区的当前行偏移let dest_row = (y - self.y) * self.dest_stride;// 计算裁剪遮罩的当前行偏移let clip_row = y * self.clip_stride;// 计算要处理的像素数量let count = (x2 - x1) as usize;// 使用着色器生成像素颜色,存储到 tmp 缓冲区self.shader.shade_span(x1, y, &mut self.tmp[..], count);// 调用自定义混合函数进行像素混合(self.blend_fn)(&self.tmp[..],                          // 着色器生成的像素mask,                                   // 遮罩(控制透明度)&self.clip[(clip_row + x1) as usize..], // 裁剪遮罩(控制是否允许绘制)&mut self.dest[(dest_row + x1 - self.x) as usize..], // 目标像素缓冲区);}
}

关键改进:自定义混合函数

之前的 ShaderClipMaskBlitter 使用硬编码的 over_in_in 混合逻辑,而 ShaderClipBlendMaskBlitter 允许动态传入混合函数:

rust
复制
pub blend_fn: fn(&[u32], &[u8], &[u8], &mut [u32]),
混合函数的参数
参数 用途
&[u32] 着色器生成的像素(tmp 缓冲区)
&[u8] 遮罩(mask,控制透明度)
&[u8] 裁剪遮罩(clip,控制是否允许绘制)
&mut [u32] 目标像素缓冲区(最终写入位置)
示例混合函数
假设我们要实现一个 乘法混合(Multiply Blend),可以这样定义:

rust
复制
fn multiply_blend(
src: &[u32], // 着色器生成的像素
mask: &[u8], // 透明度遮罩
clip: &[u8], // 裁剪遮罩
dest: &mut [u32], // 目标像素
) {
for i in 0…src.len() {
if clip[i] != 0 { // 只有 clip 不为 0 时才绘制
let mask_val = mask[i] as f32 / 255.0;
let src_pixel = src[i];
let dest_pixel = dest[i];

        // 乘法混合公式: result = src * dest * masklet r = ((src_pixel >> 16) & 0xFF) as f32 * ((dest_pixel >> 16) & 0xFF) as f32 * mask_val;let g = ((src_pixel >> 8) & 0xFF) as f32 * ((dest_pixel >> 8) & 0xFF) as f32 * mask_val;let b = (src_pixel & 0xFF) as f32 * (dest_pixel & 0xFF) as f32 * mask_val;dest[i] = ((r as u32) << 16) | ((g as u32) << 8) | (b as u32);}
}

}
使用时:

rust
复制
let blitter = ShaderClipBlendMaskBlitter {
blend_fn: multiply_blend,
// 其他字段…
};
与 ShaderClipMaskBlitter 的对比
特性 ShaderClipMaskBlitter ShaderClipBlendMaskBlitter
混合方式 硬编码 over_in_in 自定义 blend_fn
灵活性 固定混合逻辑 支持任意混合模式(乘法、叠加、屏幕等)
适用场景 单一混合需求 需要动态切换混合模式的场景
适用场景
图形渲染引擎

支持不同的混合模式(如 Multiply、Screen、Overlay)。

UI 框架

不同控件可以使用不同的混合方式(如半透明窗口、叠加特效)。

游戏开发

动态光照(Additive 混合)、粒子效果(Alpha Blend)。

总结
ShaderClipBlendMaskBlitter 是一个高度可定制的像素混合渲染器,支持:

着色器生成像素

遮罩控制透明度

裁剪遮罩控制绘制区域

自定义混合函数

适用于需要 动态切换混合模式 的高级图形渲染场景。

http://www.cadmedia.cn/news/6909.html

相关文章:

  • 临海建设局网站导航全自动推广引流软件免费
  • 视频代做网站杭州seo联盟
  • 上海网站建设公司怎么分辨好坏郑州网
  • 惠州高端网站建设seo科技网
  • 网站管理机制建设情况网络促销方案
  • 威海住房和城乡建设厅网站首页深圳百度公司地址在哪里
  • 羽毛球赛事在哪看什么是搜索引擎优化?
  • 肇庆建设银行招聘网站品牌营销推广公司
  • 南宁网站快速排名提升网络服务器地址怎么查
  • 张槎网站制作汽车网络营销的方式有哪些
  • 成都优化网站推广全国疫情高峰感染进度
  • 网站统计代码怎么添加百度提交网站收录入口
  • 重庆市制作网站公司哪家好洛阳网站seo
  • 大连网站建设免费高端营销型网站
  • 网站开发 微盘上首页的seo关键词优化
  • 网上购物系统软件开发广州seo
  • 瑞安公司网站建设宁波网站制作与推广价格
  • 武汉市委书记人选无锡seo优化
  • 剑三做月饼活动网站外贸接单平台
  • 图片链接生成器在线seo外链收录
  • 上海英文网站建设近期热点新闻
  • 南京市规划建设展览馆网站沧州百度推广总代理
  • 网站做ulr跳转怎样优化标题关键词
  • 沧州网站优化公司海南网站设计
  • 女性时尚网站源码上海网站seoseodian
  • 引流推广网站seo搜索引擎优化排名
  • 女生千万别学市场营销常用的seo查询工具
  • 大理建设局网站长春关键词优化平台
  • 成都大丰网站建设例表网网站怎么优化seo
  • 建设中专网站首页海城seo网站排名优化推广