UWP保存截图到剪贴板

上一篇讲了怎么样把UWP的UIElement截图保存到文件,这一篇再介绍一下如果把UIElement截图复制到剪贴板。其实操作类似,只是保存文件需要FileSavePicker创建文件Stream, 而写入剪贴板我们需要创建MemoryStream,把数据转换后放在内存中,然后用DataPackage把图像数据复制到剪贴板。

直接看下面代码吧

            //use RenderTargetBitmap to render UIElement to image byte data array
            RenderTargetBitmap renderTargetBitmap = new RenderTargetBitmap();
            await renderTargetBitmap.RenderAsync(myUiElement);//any xmal element
            var pixelBuffer = await renderTargetBitmap.GetPixelsAsync();
            var pixels = pixelBuffer.ToArray();
            //Create MemoryStream to write image byte data to
            var stream = new InMemoryRandomAccessStream();
            var encoder = await BitmapEncoder.CreateAsync(BitmapEncoder.PngEncoderId, stream);
            encoder.SetPixelData(BitmapPixelFormat.Bgra8,
                        BitmapAlphaMode.Ignore,
                        (uint)renderTargetBitmap.PixelWidth,
                        (uint)renderTargetBitmap.PixelHeight,
                        DisplayInformation.GetForCurrentView().RawDpiX,
                        DisplayInformation.GetForCurrentView().RawDpiY,
                        pixels);
            await encoder.FlushAsync();
            //Set stream data into DataPackage object
            DataPackage dataPackage = new DataPackage();
            dataPackage.SetBitmap(RandomAccessStreamReference.CreateFromStream(stream));
            //Set DataPackage object into Clipboard
            Clipboard.SetContent(dataPackage);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值