博客
关于我
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 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>
    MySQL 数据库备份种类以及常用备份工具汇总
    查看>>
    mysql 数据库存储引擎怎么选择?快来看看性能测试吧
    查看>>
    MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
    查看>>
    MySQL 数据库的高可用性分析
    查看>>
    Mysql 数据库重置ID排序
    查看>>
    Mysql 数据类型一日期
    查看>>
    MySQL 数据类型和属性
    查看>>
    mysql 敲错命令 想取消怎么办?
    查看>>
    Mysql 整形列的字节与存储范围
    查看>>
    mysql 断电数据损坏,无法启动
    查看>>
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>