用Silverlight 3的位图API实现可写位图

网友投稿 217 2023-05-25

【51CTO快译】Silverlight 3 这次带来的全新位图API实现了如下的三个首要目标:

◆从无到有创建位图,以像素为单位

◆在客户端处理从服务器或本地加载的图像

◆从视觉树到位图的分区渲染,以达成类似于截屏的功能(另外,预渲染和缓存元素有时也能起到提高性能的作用)

从无到有创建位图

创建位图的关键在于System.Windows.Media.Imaging下的WriteableBitmap类。运用此类可以创建一个预先分配到普通图像元素上的源。

复制﹤Grid x:Name="LayoutRoot"﹥ ﹤Image x:Name="MyBitmap" Width="200" Height="200" /﹥ ﹤/Grid﹥ 1.2.3.4.5.

以下提供的代码可以实现一些很有趣的图形效果。

private void BuildBitmap()

{

const int imageWidth = 200;

const int imageHeight = 200;

WriteableBitmap b =

new WriteableBitmap(imageWidth, imageHeight,

PixelFormats.Bgr32);

b.Lock();

for (int x = 0; x ﹤ imageWidth; x++)

{

for (int y = 0; y ﹤ imageHeight; y++)

{

// generate a color in Pbgra32 format

byte[] components = new byte[4];

components[0] = (byte)(x % 255); // blue

components[1] = (byte)(y % 255); // green

components[2] = (byte)(x * y % 255); // red

components[3] = 0; // unused

// you could certainly do your own masking here

int pixelValue = BitConverter.ToInt32(components, 0);

// set the pixel value

b[y * imageWidth + x] = pixelValue;

}

}

b.Invalidate();

b.Unlock();

MyBitmap.Source = b;

}

复制1.

最终成品如下:

可以明显看出,以上代码经历了四个流程:锁定,写入,无效化,解锁。这是WPF兼容所需要的。

你也可以修改一个现有的位图,并渲染该位图的内容控件。

原文:Silverlight 3 – The Bitmap API / WriteableBitmap

作者:Pete Brown

【编辑推荐】

微软发布Silverlight 3首个Beta版 见微知著 Silverlight 3与Flash横向比较 Silverlight 3将支持3D图像和硬件加速

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:APISpace IP归属地API-IPv6
下一篇:APISpace 驾驶证OCR API
相关文章

 发表评论

暂时没有评论,来抢沙发吧~