博客
关于我
2016年1月15日(DEMO12-2ALPHA混合。)
阅读量:784 次
发布时间:2019-03-25

本文共 1278 字,大约阅读时间需要 4 分钟。

alpha混合是一种常见的图形学操作,用于结合两个图像的模糊效果。在这里,我们将详细阐述alpha混合的计算方式及其应用。

alpha混合的核心思想是基于透明度(alpha值)来混合源图像(src1)和辅助图像(src2)。混合过程遵循公式:

  • Final = src1 * alpha + src2 * (1 - alpha)

这个公式适用于每个RGB分量的处理,从而实现颜色混合效果的分解。

alpha查找表的创建

创建alpha查找表的过程如下:

  • 将颜色值视为5.6.5格式,从中提取RGB分量。
  • 将每个分量与alpha值相乘:
    • R = r * alpha
    • G = g * alpha
    • B = b * alpha
  • 根据RGB分量生成一个16位的颜色字,并存储到查找表中,与原始颜色值对应的位置。
  • DDD RAW Liushui Xian Texture::RGB Alpha Table Builder 功能函数

    该函数用于创建alpha查找表,其参数包含:

    int RGB_Alpha_Table_Builder(int num_alpha_levels,//数级数

    // 检查指针是否有效if (!rgb_alpha_table) {    return -1;}// 用于存储从rgbindex中提取的RGB分量int r, g, b;// 用于存储alpha值float alpha = 0;float delta_alpha = EPSILON_E6 + 1 / ((float) (num_alpha_levels - 1));// 遍历所有alpha数级for (int alpha_level = 0; alpha_level < num_alpha_levels; alpha_level++) {    // 遍历所有颜色索引    for (int rgbindex = 0; rgbindex < 65536; rgbindex++) {        // 从rgbindex中提取RGB分量        _RGB565From16Bit(rgbindex, r, g, b);                // 计算乘积        r = (int) (r * alpha);        g = (int) (g * alpha);        b = (int) (b * alpha);                // 生成新的RGB值并存储到查找表中        rgb_alpha_table[alpha_level][rgbindex] = _RGB16Bit565(r, g, b);    }        // 计算下一个alpha值    alpha += delta_alpha;}return 1;

    }

    具体来说,该函数通过对源图像和辅助图像的每个颜色索引提取RGB分量并应用alpha值,生成新的定制颜色字,存储在查找表中。通过逐步递增alpha值,可以覆盖所有可能的透明度组合。

    转载地址:http://fyauk.baihongyu.com/

    你可能感兴趣的文章
    mysql 断电数据损坏,无法启动
    查看>>
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>