AGG第四十二课 Blitting an image over another with transparency

图像叠加与透明色处理
本文讨论了如何在不支持透明度的位图上实现特定颜色的透明效果,并提出了一种通过自定义渲染器来检查并跳过指定颜色像素的方法。

问题:

I've managed to blit a loaded image onto another through the method 

"copy_from(...)" of renderer_base.

I'd like to know how can i blit the same image and also specifying a color 

that will NOT overwrite the pixels of the destination image ( a color that 

will then result transparent ).

I complete my question by specifying that the source image is a BMP and 

therefore doesn't support transparency and alpha channel in the pixel 

values.

Any suggestion is appreciated

回答:

Yes, your simple question isn't actually that simple. I could add this 

functionality to copy_from, but I don't know what exactly to add. Do you 

need to make transparent only one color? Or a number of colors? Or maybe it 

should be some volume in RGB with transparency determined by the distance 

from a certain point. OK, suppose you need only one color, bu someone else 

may want to make a number of colors translucent. And so on. We need a kind 

of a general solution.


For now you can try to use a method similar to the one in 

examples/image_alpha.cpp

See class span_conv_brightness_alpha_rgb8 and modify it as you want.

But it's a transformer, so that, works slower than copy_from. Besides, with 

any kind of a filter (bilinear and such) the colors are not exact, so, it's 

probably makes sense to use span_image_filter_rgb_nn instead of 

span_image_filter_rgb_bilinear.


Maybe it makes sense to add some functor to copy_from(), but I have no idea 

how to do that in a general way and without losing performance. Perhaps 

there should be another function more like blend_from(). Any ideas?

答复:

Actually I've gone for a "specialized" solution, that just solves my case. 

In detail, I created a new renderer that's only suitable to copy bitmaps one 

over another with 1 transparent color.

I only have ported the "copy_from" method from renderer_base along with all 

the clipping helper methods and obejcts of your original rendere_base.

I added a method that sets a trasparency color:


    setTransaprentColor(color_type color)

    {

        ...

    }


In the "copy_from" method, I get the color of the source bitmap with the 

"pixel(x,y)" method, check it against "transparentColor" and, if equal, I 

simply skip the point with a "continue" statement.

Else, I call "copy_pixel" on the underlying rendering_buffer with the exact 

value of the source bitmap pixel.


It's evident that it can be easily extended to a generic "array" of 

transparent colors, with the cost of cycling through all of them to see if 

one of them matches the source color. Even better, one could even imagine to 

"map" some source color with some other colors (along with its own alpha 

channel) once the source RGB values are matched against the RGB values of 

the "transformer" object. I thought about it and it is not difficult to code 

such a transformer object and pass it to a renderer. But that would be too 

much for my special case and also kind of "expensive" in terms of 

performance, so I just left it "for future expansions" ;-)


     本文转自fengyuzaitu 51CTO博客,原文链接:http://blog.51cto.com/fengyuzaitu/1969721,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值