Wpf 自定義截圖的實現

来源:https://www.cnblogs.com/mingyao-yuan/archive/2020/07/23/13367831.html
-Advertisement-
Play Games

//記錄滑鼠按下 public static bool MouseBtnIsDown = false; //截圖起始坐標 public static Point StartPoint; //截圖的長寬 double width = 0; double height = 0; //滑鼠按下事件 pub ...



//記錄滑鼠按下
public static bool MouseBtnIsDown = false;
//截圖起始坐標
public static Point StartPoint;
//截圖的長寬
double width = 0;
double height = 0;

//滑鼠按下事件
public void grid_mouseleftdown(object sender, MouseButtonEventArgs e)
{
//記錄按下操作
MouseBtnIsDown = true;
//記錄滑鼠按下時的坐標
Point p = e.GetPosition((IInputElement)sender);
StartPoint = p;
}
/// <summary>
/// 滑鼠鬆開
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
public void grid_mouseleftup(object sender, MouseButtonEventArgs e)
{
//滑鼠鬆開
MouseBtnIsDown = false;
//選中item(需要進行畫框或截圖的控制項)
var item = TabControl.SelectedItem as TabItem;

//得到tabitem的content 為Grid
Grid grid = item.Content as Grid;
foreach (var a in grid.Children)
{
if (a is Grid)
{
//畫框grid
var b = a as Grid;
b.IsHitTestVisible = false;
}
}

//獲取滑鼠鬆開時的坐標
Point Endpoint = e.GetPosition((IInputElement)sender);
//截圖

RenderTargetBitmap renderTargetBitmap = new RenderTargetBitmap((int)ShotGrid.ActualWidth, (int)ShotGrid.ActualHeight, 96d, 96d, PixelFormats.Pbgra32);
renderTargetBitmap.Render(ShotGrid);
PngBitmapEncoder pngImage = new PngBitmapEncoder();
//控制項截圖再截取想要的圖
pngImage.Frames.Add(BitmapFrame.Create(renderTargetBitmap));
//轉image
MemoryStream memoryStream = new MemoryStream();
pngImage.Save(memoryStream);
Image<Rgb, byte> m_image = new Image<Rgb, byte>(new System.Drawing.Bitmap(memoryStream));
m_image.ROI = new System.Drawing.Rectangle((int)StartPoint.X, (int)StartPoint.Y, (int)width, (int)height);
string path = @"C:\Users\Administrator\Desktop\截圖\";
Directory.CreateDirectory(path);
m_image.Save(@"C:\Users\Administrator\Desktop\截圖\" + DateTime.Now.Ticks + ".png");
Record("截圖保存成功" + @"C:\Users\Administrator\Desktop\截圖\" + DateTime.Now.Ticks + ".png", false);
memoryStream.Dispose();
m_image.Dispose();

}
//滑鼠移動事件
public void grid_mousemove(object sender, System.Windows.Input.MouseEventArgs e)
{
//滑鼠當前的point
Point Endpoint = e.GetPosition((IInputElement)sender);

if (MouseBtnIsDown)
{
System.Windows.Shapes.Path path = new System.Windows.Shapes.Path();
//轉換成基於Image控制項的坐標
width = Endpoint.X - StartPoint.X - 1;
height = Endpoint.Y - StartPoint.Y;
//用來記錄左上角坐標
Point StartLeft = new Point();
//如果從左往右畫
if (Endpoint.X > StartPoint.X)
{
width = Endpoint.X - StartPoint.X;
StartLeft.X = StartPoint.X;
//如果從上往下畫
if (Endpoint.Y > StartPoint.Y)
{
height = Endpoint.Y - StartPoint.Y;
StartLeft.Y = StartPoint.Y;

}
else
{
height = StartPoint.Y - Endpoint.Y;
StartLeft.Y = StartPoint.Y - height;
}
}
else
{
width = StartPoint.X - Endpoint.X;
StartLeft.X = Endpoint.X;
if (Endpoint.Y > StartPoint.Y)
{
height = Endpoint.Y - StartPoint.Y;
StartLeft.Y = Endpoint.Y - height;

}
else
{
height = StartPoint.Y - Endpoint.Y;
StartLeft.Y = Endpoint.Y;
}
}
RectangleGeometry rec = new RectangleGeometry();
rec.Rect = new Rect(new System.Windows.Point(StartPoint.X, StartPoint.Y), new System.Windows.Size(width, height));
path.StrokeThickness = 2;
path.Data = rec;
path.StrokeDashArray = new DoubleCollection() { 2, 2 };
path.Stroke = System.Windows.Media.Brushes.WhiteSmoke;

//清空所有畫出來的框
(sender as Grid).Children.Clear();
(sender as Grid).Opacity = 1;
(sender as Grid).Background = Brushes.Transparent;

//添加方框
(sender as Grid).Children.Add(path);
//滑鼠移動一定要設置穿透 不然滑鼠抬起事件失靈
path.IsHitTestVisible = false;
rec.Freeze();
}

}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 效果圖看左上角 代碼如下: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>基於CSS3的3D立方體旋轉動畫</title> <style> /* 3d旋轉樣式 */ .cub { width: 2.5rem; height: ...
  • 最近工作中用到了jQuery UI中排序和拖拽功能,花了大概一天的時間,搞清楚了大概的參數配置,以及遇到的一些問題,總結如下。 sortable 簡單的配置如下: $('#subs-box').sortable({ axis: 'y', cursor: 'ns-resize', placeholde ...
  • 室內地圖製作經過易景空間地圖團隊的持續優化迭代,新版本地圖編輯器中的畫圓柱體、模型庫、快速畫道路、房間直接換紋理貼圖等功能終於上線了,目前市面上一款無需安裝軟體就能直接使用瀏覽器訪問的線上室內地圖製作編輯器。 ...
  • 摘要 重裝電腦系統後,使用npm install初始化項目依賴失敗了,錯誤提示:'proxy' config is set properly..........,具體的錯誤提示如下圖所示: 解決方案 經過報錯信息查詢解決辦法,最終找到了兩個比較好的方案,在此總結一下,以便下次再遇到此類問題。 方案一 ...
  • 引入Javascript的發展史 JavaScript的基本語法篇 1.與HTML結合的方式 2.0 註釋與數據類型 3.0 變數 4.0 運算符 (1)一元運算符 (2)比較運算符 (3)邏輯運算符 (4)三元運算符 5.流程式控制制語句 6.JS特殊語法 練習:在頁面上列印一個99乘法表 <!DOC ...
  • 隨著我國經濟的飛速發展,三維地下管網、地下管線系統直觀高效的參考,結合GIS、資料庫和三維技術,直觀顯示地下管線的空間層次和位置信息,資源的統籌利用審批工作提供準確,易景空間地圖專業致力於三維管網、管網建模、bim管線、三維管網檢測提供專業的技術服務,數據驅動快速生成三維管網矢量模型。 ...
  • 一,效果圖。 二,代碼。 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>CSS 偽類</title> <style> a:link { color: #FF0000; } /* unvisited link */ a:visi ...
  • 前言 本篇文章收錄於專輯:http://dwz.win/HjK,點擊解鎖更多數據結構與演算法的知識。 你好,我是彤哥,一個每天爬二十六層樓還不忘讀源碼的硬核男人。 前面幾節,我們一起學習了演算法的複雜度如何分析,並從最壞、平均、最好以及不能使用最壞情況全方位無死角的剖析了演算法的複雜度,在我們表示覆雜度的 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...