【学Rust写CAD】29 Alpha256结构体(alpha256.rs)

源码

rust 复制代码
#[derive(Clone, Copy)]
pub struct Alpha256(u32);

impl Alpha256{
    #[inline]
    pub fn from(alpha:u32)->Alpha256{
        Alpha256(alpha+1)
    }

    // Calculates 256 - (value * alpha256) / 255 in range [0,256],
    // for [0,255] value and [0,256] alpha256.
    #[inline]
    fn alpha_mul_inv256(self,value: u32) -> u32 {
        let prod = value * self.0;
        256 - ((prod + (prod >> 8)) >> 8)
    }

    // Calculates (value * alpha256) / 255 in range [0,256],
    // for [0,255] value and [0,256] alpha256.
    fn alpha_mul_256(self,value: u32) -> u32 {
        let prod = value * self.0;
        (prod + (prod >> 8)) >> 8
    }
}

源码分析

代码定义了一个名为 Alpha256 的结构体,用于处理与透明度(alpha)相关的计算。以下是对代码的逐步解释:

  1. 结构体定义
rust 复制代码
#[derive(Clone, Copy)]
pub struct Alpha256(u32);

Alpha256 是一个简单的包装类型,内部包含一个 u32 值。

#[derive(Clone, Copy)] 表示该结构体可以自动实现 Clone 和 Copy trait,因此它可以被复制(按位拷贝)而无需移动所有权。

  1. 构造函数
rust 复制代码
#[inline]
pub fn from(alpha: u32) -> Alpha256 {
    Alpha256(alpha + 1)
}

from 是一个构造函数,接受一个 u32 参数 alpha,并返回 Alpha256 实例。

设计意图是将输入的 alpha 范围从 [0, 255] 转换为 [1, 256](避免除零或无效计算)。

  1. 方法:alpha_mul_inv256
rust 复制代码
#[inline]
fn alpha_mul_inv256(self, value: u32) -> u32 {
    let prod = value * self.0;
    256 - ((prod + (prod >> 8)) >> 8)
}
  • 功能:计算 256 - (value * alpha256) / 255,结果范围在 [0, 256]。

  • 输入:

    • value:范围 [0, 255] 的像素值。

    • self.0:范围 [1, 256] 的 alpha 值(由构造函数保证)。

计算过程:

  1. prod = value * self.0:先计算原始乘积(范围 [0, 255 * 256])。

  2. (prod + (prod >> 8)) >> 8:这是快速近似除以 255 的技巧:

  • prod >> 8 等价于 prod / 256。

  • prod + (prod >> 8) 近似于 prod * (1 + 1/256),即 prod * 257/256。

  • 右移 8 位(>> 8)相当于除以 256,因此最终结果为 (prod * 257) / 65536 ≈ prod / 254.98(接近 prod / 255)。

  1. 256 - ...:计算补值,得到反向的 alpha 混合结果。
  • 用途:用于"反向混合"计算(如 1 - alpha 的效果)。
  1. 方法:alpha_mul_256
rust 复制代码
fn alpha_mul_256(self, value: u32) -> u32 {
    let prod = value * self.0;
    (prod + (prod >> 8)) >> 8
}
  • 功能:计算 (value * alpha256) / 255,结果范围在 [0, 256]。

  • 输入:与 alpha_mul_inv256 相同。

  • 计算过程:

    • 和 alpha_mul_inv256 的前半部分完全一致,只是没有最后的 256 - ... 步骤。
  • 用途:直接计算 alpha 混合后的值(例如 value * (alpha / 255))。

关键点

  1. 快速除以 255 的近似:
  • 公式 (prod + (prod >> 8)) >> 8 是优化技巧,避免了昂贵的除法操作。

  • 误差分析:对于 prod = 255 * 256,真实值为 256,而计算结果为 (65280 + 255) >> 8 = 255(误差 1/256)。

  1. Alpha 范围:
  • 构造函数将输入 alpha 从 [0, 255] 映射到 [1, 256],是为了避免 alpha = 0 时的无效计算。
  1. 用途:
  • 这些方法通常用于图像处理中的透明度混合(如 blend = foreground * alpha + background * (1 - alpha))。
相关推荐
小喷友3 小时前
阶段三:进阶(Rust 高级特性)
前端·rust
Python私教4 小时前
源滚滚Rust全栈班v1.02 无符号整数详解
开发语言·后端·rust
专注VB编程开发20年18 小时前
CSS 的命名方式像是 PowerShell 的动词-名词结构,缺乏面向对象的层级关系
开发语言·后端·rust
伍哥的传说19 小时前
Tailwind CSS v4 终极指南:体验 Rust 驱动的闪电般性能与现代化 CSS 工作流
前端·css·rust·tailwindcss·tailwind css v4·lightning css·utility-first
专注VB编程开发20年21 小时前
rust语言-对象多级访问
服务器·前端·rust
编码浪子1 天前
趣味学RUST基础篇(构建一个命令行程序2重构)
开发语言·重构·rust
susnm1 天前
组件生命周期
rust·全栈
bruce541101 天前
Axum 最佳实践:如何构建优雅的 Rust 错误处理系统?(三)
rust
Source.Liu2 天前
【Python基础】 15 Rust 与 Python 基本类型对比笔记
笔记·python·rust
咸甜适中2 天前
rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(二十六)windows平台运行时隐藏控制台
笔记·学习·rust·egui