【问题标题】:How to "take a photo" of a frame that was created in the code behind during run-time, in WPF?如何在运行时在 WPF 中为在后面的代码中创建的框架“拍照”?
【发布时间】:2016-04-14 15:35:06
【问题描述】:

我有这个函数,从按钮Click事件处理函数调用:

private void CreateFrame(Page page)
{
    Frame newFrame = new Frame();
    newFrame.Navigate(page);

    // FramesHolder is a StackPanel with multiple Frames inside it
    FramesHolder.Children.Add(newFrame);

    // The size the page is 525x50
    RenderTargetBitmap renderTargetBitmap =
        new RenderTargetBitmap(525, 50, 96, 96, PixelFormats.Pbgra32);
    renderTargetBitmap.Render(newFrame);
    PngBitmapEncoder pngImage = new PngBitmapEncoder(); 

    pngImage.Frames.Add(BitmapFrame.Create(renderTargetBitmap));
    using (Stream fileStream = File.Create("Frame.png"))
    {
        pngImage.Save(fileStream);
    }
}

问题是Frame.png 图像被渲染为黑色。如何解决?谢谢。

【问题讨论】:

  • 嗯 - 这实际上是我得到此代码的原始答​​案,但在那种情况下,控件是在 XAML 中创建的,而我的控件仅在单击按钮时创建,我相信这是使图片变黑的区别。
  • 你在什么时候执行这个方法?也许是在控件完全绘制之前截屏?
  • @CathalMF - 单击按钮时。而且,在这段代码中,newFrame 是在创建 RenderTargetBitmap 对象之前绘制的...... @方法,但我无法弄清楚...谢谢...

标签: c# wpf xaml


【解决方案1】:

我将renderTargetBitmap.Render(newFrame); 行更改为renderTargetBitmap.Render(page); 并成功截取屏幕截图。

问题在于创建新框架。

我显示了一个页面,在 Loaded 事件中,我使用上面指定的更改调用了您的方法,它可以工作。

public partial class Page2 : System.Windows.Controls.Page
{
    public Page2()
    {
        InitializeComponent();
    }

    private void PG2_Loaded(object sender, RoutedEventArgs e)
    {
        CreateFrame(this);
    }

    private void CreateFrame(Page page)
    {
        Frame newFrame = new Frame();
        newFrame.Navigate(page);

        // The size the page is 525x50
        RenderTargetBitmap renderTargetBitmap =
            new RenderTargetBitmap(525, 50, 96, 96, PixelFormats.Pbgra32);
        renderTargetBitmap.Render(page);
        PngBitmapEncoder pngImage = new PngBitmapEncoder();

        pngImage.Frames.Add(BitmapFrame.Create(renderTargetBitmap));
        using (Stream fileStream = File.Create("c:\\Frame.png"))
        {
            pngImage.Save(fileStream);

        }
    }

}

【讨论】:

  • 有效!非常感谢!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-08-12
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多