- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在创建散点图的屏幕截图时遇到问题。我的屏幕截图总是包含一个黑框。
这是我的 XAML 代码:
<s:SurfaceWindow
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:s="http://schemas.microsoft.com/surface/2008"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d" x:Class="MakeScreenshots.SurfaceWindow1"
Title="MakeScreenshots" Width="1000" Height="700"
>
<s:SurfaceWindow.Resources>
<ImageBrush x:Key="WindowBackground" Stretch="None" Opacity="0.6" ImageSource="pack://application:,,,/Resources/WindowBackground.jpg"/>
</s:SurfaceWindow.Resources>
<Grid x:Name="GlobalGrid" Background="{StaticResource WindowBackground}" Width="1000" Height="700" >
<s:ScatterView x:Name="ScatterViewScreenShot" Margin="108,89,176,73" Width="700" Height="500">
<s:ScatterView.Background>
<SolidColorBrush Color="{DynamicResource {x:Static SystemColors.ActiveCaptionColorKey}}"/>
</s:ScatterView.Background>
<s:ScatterViewItem Margin="0,-26.953,-130.946,-23.047" Content="ScatterViewItem 3" HorizontalAlignment="Right" Width="125.826"/>
<s:ScatterViewItem Margin="0,0,-490.513,-151.256" HorizontalAlignment="Right" Width="125.77" Height="60.427" VerticalAlignment="Bottom" Content="ScatterViewItem 2"/>
<s:ScatterViewItem Content="ScatterViewItem 1" Margin="-331.43,0,0,-129.589" HorizontalAlignment="Left" Width="177.949" Height="67.905" VerticalAlignment="Bottom"/>
</s:ScatterView>
<Button x:Name="MakeScreenShotButton" Click="MakeScreenShotButton_Click" Content="MakeScreenShot" Margin="267,17,343,0" VerticalAlignment="Top" Height="38.96"/>
<Button Content="MakeScreenShotButton2" Height="39" HorizontalAlignment="Left" Margin="116,614,0,0" Name="button1" VerticalAlignment="Top" Width="301" Click="MakeScreenShotButton2_Click" />
<Button Content="MakeScreenShotButton3" Click="MakeScreenShotButton3_Click" Height="39" HorizontalAlignment="Left" Margin="822,207,0,0" Name="button2" VerticalAlignment="Top" Width="147" />
<Button Content="MakeScreenShotButton4" Click="MakeScreenShotButton4_Click" Height="39" HorizontalAlignment="Left" Margin="822,349,0,0" Name="button3" VerticalAlignment="Top" Width="147" />
<Button Content="MakeScreenShotButton5" Click="MakeScreenShotButton5_Click" Height="39" HorizontalAlignment="Left" Margin="822,443,0,0" Name="button4" VerticalAlignment="Top" Width="147" />
</Grid>
</s:SurfaceWindow>
这是 C# 代码:
private void MakeScreenShotButton_Click(object sender, RoutedEventArgs e)
{
RenderTargetBitmap targetBitmap = new RenderTargetBitmap((int)ScatterViewScreenShot.ActualWidth, (int)ScatterViewScreenShot.ActualHeight, 80d, 80d, PixelFormats.Default);
targetBitmap.Render(ScatterViewScreenShot);
// add the RenderTargetBitmap to a Bitmapencoder
JpegBitmapEncoder encoder = new JpegBitmapEncoder();
encoder.Frames.Add(BitmapFrame.Create(targetBitmap));
// Encoder zum Speichern des Bildes
JpegBitmapEncoder encoderToSave = new JpegBitmapEncoder();
encoderToSave.Frames.Add(BitmapFrame.Create(targetBitmap));
// Speichern des Bildes auf der Festplatte
string fileName = "M:\\TestForStackOverflow.jpg";
System.IO.FileStream fs = System.IO.File.Open(fileName, System.IO.FileMode.OpenOrCreate);
encoderToSave.Save(fs);
encoder.QualityLevel = 40;
MemoryStream ms = new MemoryStream();
encoder.Save(ms);
// Convert Image to byte[]
byte[] imageBytes = ms.ToArray();
int anzahlBytes = imageBytes.Length;
string imageAsBase64String = Convert.ToBase64String(imageBytes);
TCP_Client client = new TCP_Client("192.168.5.3", 4321);
client.sendeNachricht(imageAsBase64String);
}
private void MakeScreenShotButton2_Click(object sender, RoutedEventArgs e)
{
// 1. Bitmap der gewünschten Größe erstellen
int width = (int)ScatterViewScreenShot.ActualWidth;
int height = (int)ScatterViewScreenShot.ActualHeight;
RenderTargetBitmap rtb = new RenderTargetBitmap(width, height, 100d, 100d, PixelFormats.Default); // 500 x 500 genau wie bei den Produktfotos
// 2. Control in Bitmap hinein rendern
Visual vis = (Visual)ScatterViewScreenShot;
rtb.Render(vis);
// 3. Control-Image erzeugen und dem Control-Image als Source das Bitmap übergeben
System.Windows.Controls.Image img = new System.Windows.Controls.Image();
img.Source = rtb;
img.Stretch = Stretch.None;
// 4. Aktualisieren der Größe des Elements entsprechend des Inhaltes mittels der Methoden Measure und Arrange.
img.Measure(new System.Windows.Size(width, height));
System.Windows.Size sizeImage = img.DesiredSize;
img.Arrange(new System.Windows.Rect(new System.Windows.Point(0, 0), sizeImage));
// 5. Image wird mit der korrekten Größe erneut gerendert und an PngBitmapEncoder übergeben
RenderTargetBitmap rtb2 = new RenderTargetBitmap((int)rtb.Width, (int)rtb.Height, 60, 60, PixelFormats.Default);
rtb2.Render(img);
PngBitmapEncoder jpeg = new PngBitmapEncoder();
jpeg.Frames.Add(BitmapFrame.Create(rtb2));
// 6. Image in Stream schreiben
MemoryStream ms = new MemoryStream();
jpeg.Save(ms);
// Convert Image to byte[]
byte[] imageBytes = ms.ToArray();
int anzahlBytes = imageBytes.Length;
string imageAsBase64String = Convert.ToBase64String(imageBytes);
TCP_Client client = new TCP_Client("192.168.5.3", 4321);
client.sendeNachricht(imageAsBase64String);
}
private void MakeScreenShotButton3_Click(object sender, RoutedEventArgs e)
{
int width_x = 240;
int width_y = 400;
Bitmap screen = TakeScreenshot(100, 100, width_x, width_y);
System.Drawing.Image img = (System.Drawing.Image)screen;
//Image img = Image.FromFile("bla.jpg");
MemoryStream ms = new MemoryStream();
try
{
//Ein ImageCodecInfo-Objekt für den JPEG-Codec anlegen
ImageCodecInfo jpegCodec = null;
//Den Qualitätsarameter konfigurieren (Qualitätsfaktor in
//Prozent angeben)
EncoderParameter qualitaetsParameter = new EncoderParameter(
System.Drawing.Imaging.Encoder.Quality, 40);
//Alle im System verfügbaren Codecs auflisten
ImageCodecInfo[] alleCodecs = ImageCodecInfo.GetImageEncoders();
EncoderParameters codecParameter = new EncoderParameters(1);
codecParameter.Param[0] = qualitaetsParameter;
//Den JPEG-Codec unter allen Codecs finden und dem
//Codec-Info-Objekt zuweisen
for (int i = 0; i < alleCodecs.Length; i++)
{
if (alleCodecs[i].MimeType == "image/jpeg")
{
jpegCodec = alleCodecs[i];
break;
}
}
// Bild in Stream schreiben
img.Save(ms, jpegCodec, codecParameter);
}
catch (ArgumentException w)
{
throw w;
}
// Console.WriteLine(StreamToBase64(ms, System.Drawing.Imaging.ImageFormat.Jpeg));
String bildBase64 = StreamToBase64(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
TCP_Client client = new TCP_Client("192.168.5.3", 4321);
client.sendeNachricht(bildBase64);
}
private void MakeScreenShotButton4_Click(object sender, RoutedEventArgs e)
{
// save current canvas transform
Transform transform = ScatterViewScreenShot.LayoutTransform;
// get size of control
System.Windows.Size sizeOfControl = new System.Windows.Size(ScatterViewScreenShot.ActualWidth, ScatterViewScreenShot.ActualHeight);
// measure and arrange the control
ScatterViewScreenShot.Measure(sizeOfControl);
// arrange the surface
ScatterViewScreenShot.Arrange(new Rect(sizeOfControl));
// craete and render surface and push bitmap to it
RenderTargetBitmap renderBitmap = new RenderTargetBitmap((Int32)sizeOfControl.Width, (Int32)sizeOfControl.Height, 96d, 96d, PixelFormats.Pbgra32);
// now render surface to bitmap
renderBitmap.Render(ScatterViewScreenShot);
// encode png data
PngBitmapEncoder pngEncoder = new PngBitmapEncoder();
// puch rendered bitmap into it
pngEncoder.Frames.Add(BitmapFrame.Create(renderBitmap));
/* Speichern des Bildes auf der Festplatte
string fileName = "M:\\ScreenshotClick4.jpg";
System.IO.FileStream fs = System.IO.File.Open(fileName, System.IO.FileMode.OpenOrCreate);
pngEncoder.Save(fs);*/
// Encoder zum Senden des Bildes
JpegBitmapEncoder encoder = new JpegBitmapEncoder();
encoder.Frames.Add(BitmapFrame.Create(renderBitmap));
MemoryStream ms = new MemoryStream();
encoder.Save(ms);
// Convert Image to byte[]
byte[] imageBytes = ms.ToArray();
int anzahlBytes = imageBytes.Length;
string imageAsBase64String = Convert.ToBase64String(imageBytes);
TCP_Client client = new TCP_Client("192.168.5.3", 4321);
client.sendeNachricht(imageAsBase64String);
}
private void MakeScreenShotButton5_Click(object sender, RoutedEventArgs e)
{
int scale = 1;
double actualHeight = ScatterViewScreenShot.RenderSize.Height;
double actualWidth = ScatterViewScreenShot.RenderSize.Width;
double renderHeight = actualHeight * scale;
double renderWidth = actualWidth * scale;
RenderTargetBitmap renderTarget = new RenderTargetBitmap((int)renderWidth, (int)renderHeight, 96, 96, PixelFormats.Pbgra32);
VisualBrush sourceBrush = new VisualBrush(ScatterViewScreenShot);
DrawingVisual drawingVisual = new DrawingVisual();
DrawingContext drawingContext = drawingVisual.RenderOpen();
using (drawingContext)
{
drawingContext.PushTransform(new ScaleTransform(actualWidth, actualHeight));
drawingContext.DrawRectangle(sourceBrush, null, new Rect(new System.Windows.Point(0, 0), new System.Windows.Point(actualWidth, actualHeight)));
}
renderTarget.Render(drawingVisual);
JpegBitmapEncoder jpgEncoder = new JpegBitmapEncoder();
jpgEncoder.QualityLevel = 40;
jpgEncoder.Frames.Add(BitmapFrame.Create(renderTarget));
MemoryStream ms = new MemoryStream();
jpgEncoder.Save(ms);
// Convert Image to byte[]
byte[] imageBytes = ms.ToArray();
int anzahlBytes = imageBytes.Length;
string imageAsBase64String = Convert.ToBase64String(imageBytes);
TCP_Client client = new TCP_Client("192.168.5.3", 4321);
client.sendeNachricht(imageAsBase64String);
}
#region Hilfsmethoden
public string StreamToBase64(MemoryStream ms, System.Drawing.Imaging.ImageFormat format)
{
// Convert Image to byte[]
byte[] imageBytes = ms.ToArray();
// Convert byte[] to Base64 String
string base64String = Convert.ToBase64String(imageBytes);
return base64String;
}
private Bitmap TakeScreenshot(int StartX, int StartY, int Width, int Height)
{
Bitmap Screenshot = new Bitmap(Width, Height);
Graphics G = Graphics.FromImage(Screenshot);
G.CopyFromScreen(StartX, StartY, 0, 0, new System.Drawing.Size(Width, Height), CopyPixelOperation.SourceCopy);
return Screenshot;
}
#endregion
}
}
最佳答案
我发现以下文章有解决您的问题的方法:Taking WPF“Screenshots”(Link 到博文)
///
/// Gets a JPG "screenshot" of the current UIElement
///
/// UIElement to screenshot
/// Scale to render the screenshot
/// JPG Quality
/// Byte array of JPG data
public static byte[] GetJpgImage(this UIElement source, double scale, int quality)
{
double actualHeight = source.RenderSize.Height;
double actualWidth = source.RenderSize.Width;
double renderHeight = actualHeight * scale;
double renderWidth = actualWidth * scale;
RenderTargetBitmap renderTarget = new RenderTargetBitmap((int) renderWidth, (int) renderHeight, 96, 96, PixelFormats.Pbgra32);
VisualBrush sourceBrush = new VisualBrush(source);
DrawingVisual drawingVisual = new DrawingVisual();
DrawingContext drawingContext = drawingVisual.RenderOpen();
using (drawingContext)
{
drawingContext.PushTransform(new ScaleTransform(scale, scale));
drawingContext.DrawRectangle(sourceBrush, null, new Rect(new Point(0, 0), new Point(actualWidth, actualHeight)));
}
renderTarget.Render(drawingVisual);
JpegBitmapEncoder jpgEncoder = new JpegBitmapEncoder();
jpgEncoder.QualityLevel = quality;
jpgEncoder.Frames.Add(BitmapFrame.Create(renderTarget));
Byte[] _imageArray;
using (MemoryStream outputStream = new MemoryStream())
{
jpgEncoder.Save(outputStream);
_imageArray = outputStream.ToArray();
}
return _imageArray;
}
关于wpf - 如何在 WPF 中制作 UIElement 的屏幕截图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9094494/
图像采集源除了显示控件(上一篇《.NET 控件转图片》有介绍从界面控件转图片),更多的是窗口以及屏幕。 窗口截图最常用的方法是GDI,直接上Demo吧: 1 private
我正在尝试编写一个程序来使用全局热键获取屏幕截图。下面是相应的代码: from datetime import datetime import os from pynput import keyboa
我正在构建一个应用程序,它应该为任何具有 Android 4 及更高版本的无根设备实现屏幕~镜像~,2 帧/秒就足够了。 我正在尝试使用 ADB“framebuffer:”命令来抓取设备屏幕截图 AD
如何使用 C++ 捕获屏幕截图?我将使用 Win32。 请不要使用 MFC 代码。 最佳答案 #include "windows.h" // should be less than and great
代码如下: import java.awt.Dimension; import java.awt.Rectangle; import java.awt.Robot; import java.aw
我目前正在构建一个 Google Chrome 扩展程序,该扩展程序可以从不同页面获取多个屏幕截图并将其发布到端点上。我遇到的问题是时间不对。我的意思是,在页面停止加载之前就太早截取屏幕截图了。其次,
我有一个 View Controller ,其中导航栏是透明的。我的下一个 View 是表格 View ,其中导航栏是白色的。 为了停止不需要的动画,我在表格 View 的“viewDidDissap
我正在尝试从多个 URL 制作屏幕截图。我的代码工作正常,但结果我得到了事件窗口的图像。但我需要带有浏览器顶部的完整屏幕截图(URL) file = open('links.txt', 'r', en
我正在尝试(并实现)获取屏幕截图: robot = new Robot(); BufferedImage biScreen = robot.createScreenCapture(rectScreen
是否有任何应用程序可以拍摄 android 设备的视频/屏幕截图。我知道在桌面上捕获屏幕视频/图像的软件很少,例如 camtasia、snagit。 Android 设备有类似的东西吗? 我知道使用
想要捕获可能处于非事件状态的选项卡的图像。 问题是,当使用此处显示的方法时,选项卡通常在捕获完成之前没有时间加载,从而导致失败。 chrome.tabs.update() 回调在标签页被捕获之前执行。
我想在新的 tkinter 窗口 (TopLevel) 中显示我的屏幕截图,但我不想将其保存在电脑上。当我保存它时它工作正常但是当我尝试从内存加载屏幕截图时出现错误:图像不存在。 我的主窗口是root
我正在 try catch 我当前所在的屏幕,因此当我覆盖下一个 View Controller 时,我可以使它成为它后面的 ImageView 并使其显示为半透明。这是有效的,但现在它在中间产生了一
我正在寻找将 docx(以及后来的 excel 和 powerpoint)文档的第一页转换为图像的方法。我宁愿不手动解析文档的整个 xml,因为这看起来工作量很大;) 所以我想我只是想收集一些关于如何
好吧,碰巧我正在编写一个程序来截取一些屏幕截图,并且在处理另一个进程已经在使用的文件时遇到了一些困难,希望有人能帮助我找到一种方法来“关闭”这个进程或启发我如何继续. //Create a new b
我即将在 App Store 上发布我的应用程序,我想截取我的应用程序的屏幕截图,但状态栏中没有所有信息,例如运营商和 Debug模式等。 我知道 Marshmallow 有一个 System UI
UIGraphicsBeginImageContext(self.reportList.frame.size); CGRect tableViewFrame = self.reportList.fra
是否有任何简洁的方法来访问 android 设备的屏幕截图以编程方式。我正在寻找大约 15-20fps。 我找到了一个代码android\generic\frameworks\base\service
好的,我正在尝试为多个网站运行多个屏幕截图!我已经获得了多个站点的一个屏幕截图,我还可以获得一个站点的多个 Viewport 屏幕截图,但我有 34 个站点需要这样做!那么有人知道用 casperjs
我正在为 iOS 制作一个贴纸包,在将其提交到 App Store 之前,我需要包含至少一张来自 5.5 英寸 iPhone 和 12.9 英寸 iPad Pro 的应用截图。这些都是我没有的设备。
我是一名优秀的程序员,十分优秀!