国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C# - WPF/Silverlight實現圖片局部放大的方法分析

WPF/Silverlight實現圖片局部放大的方法分析

2021-12-29 13:26Rising_Sun C#

這篇文章主要介紹了WPF/Silverlight實現圖片局部放大的方法,結合實例形式分析了WPF/Silverlight針對圖片屬性操作相關實現技巧,需要的朋友可以參考下

本文實例講述了WPF/Silverlight實現圖片局部放大的方法。分享給大家供大家參考,具體如下:

最近的項目中也要用到一個局部圖片放大的功能,前面這篇《silverlight實現圖片局部放大效果的方法》雖然已經給出了原理、知識要點、尺寸要點及后端主要代碼,但遺憾的是沒有給出xaml的代碼。這里按照前文中的提示,動手用WPF實踐了一下,花了一個小時,終于搞出來了。這篇文章也就算是一個補充吧。

界面如下圖所示:

WPF/Silverlight實現圖片局部放大的方法分析

實現的原理和用到的知識點請點擊上面的鏈接,楊大俠已經說的很清楚了。這里主要強調的就是尺寸要點:

右側大圖可視區域與左側半透明矩形的“長寬比例”應該相同
“圖片原始尺寸長度比” 應該 “與左側小圖片長度比”相同
圖片原始大小/左側小圖大小 = 右側可視區域大小/半透明矩形大小

為了簡單起見,我們把尺寸固定死(其實是可以搞成活的),這里僅為了演示,以下尺寸滿足上面的條件。

準備一張原圖:dog.jpg  分辨率:1920 * 1080

左側小圖片顯示區域:用Canvas 顯示,尺寸:320 * 180

半透明矩形框尺寸:50*50

右側大圖顯示區域:用Canvas顯示,尺寸:300 * 300

以下是XAML代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<Window x:Class="WpfZoom.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="WPF局部放大效果" Height="370" Width="700">
  <Canvas x:Name="RootCanvas">
    <!--左側小圖-->
    <Canvas x:Name="SmallBox" Width="320" Height="180" Canvas.Left="20" Canvas.Top="20">
      <Canvas.Background>
        <ImageBrush ImageSource="Images/dog.jpg" Stretch="UniformToFill" />
      </Canvas.Background>
      <!--半透明矩形框-->
      <Rectangle x:Name="MoveRect" Fill="White" Opacity="0.3" Stroke="Red" Width="50" Height="50" Canvas.Top="78" Canvas.Left="202"
          MouseMove="MoveRect_MouseMove"
          MouseLeftButtonDown="MoveRect_MouseLeftButtonDown"
          MouseLeftButtonUp="MoveRect_MouseLeftButtonUp"/>
    </Canvas>
    <!--右側大圖-->
    <Canvas x:Name="BigBox" Width="300" Height="300" Canvas.Left="360" Canvas.Top="20">
      <!--右側原圖片 注意尺寸-->
      <Image x:Name="bigImg" Width="1920" Height="1080" Canvas.Left="0" Canvas.Top="-780" Source="Images/dog.jpg" />
      <Canvas.Clip>
        <RectangleGeometry Rect="0,0,300,300" />
      </Canvas.Clip>
    </Canvas>
  </Canvas>
</Window>

cs 代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
namespace WpfZoom
{
  /// <summary>
  /// MainWindow.xaml 的交互邏輯
  /// </summary>
  public partial class MainWindow : Window
  {
    //移動標志
    bool trackingMouseMove = false;
    //鼠標按下去的位置
    Point mousePosition;
    public MainWindow()
    {
      InitializeComponent();
      this.Loaded += new RoutedEventHandler(MainWindow_Loaded);
    }
    void MainWindow_Loaded(object sender, RoutedEventArgs e)
    {
      AdjustBigImage();
    }
    /// <summary>
    /// 半透明矩形框鼠標左鍵按下
    /// </summary>
    private void MoveRect_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
    {
      FrameworkElement element = sender as FrameworkElement;
      mousePosition = e.GetPosition(element);
      trackingMouseMove = true;
      if (null != element)
      {
        //強制獲取此元素
        element.CaptureMouse();
        element.Cursor = Cursors.Hand;
      }
    }
    /// <summary>
    /// 半透明矩形框鼠標左鍵彈起
    /// </summary>
    private void MoveRect_MouseLeftButtonUp(object sender, MouseButtonEventArgs e)
    {
      FrameworkElement element = sender as FrameworkElement;
      trackingMouseMove = false;
      element.ReleaseMouseCapture();
      mousePosition.X = mousePosition.Y = 0;
      element.Cursor = null;
    }
    /// <summary>
    /// 半透明矩形框移動
    /// </summary>
    private void MoveRect_MouseMove(object sender, MouseEventArgs e)
    {
      FrameworkElement element = sender as FrameworkElement;
      if (trackingMouseMove)
      {
        //計算鼠標在X軸的移動距離
        double deltaV = e.GetPosition(element).Y - mousePosition.Y;
        //計算鼠標在Y軸的移動距離
        double deltaH = e.GetPosition(element).X - mousePosition.X;
        //得到圖片Top新位置
        double newTop = deltaV + (double)element.GetValue(Canvas.TopProperty);
        //得到圖片Left新位置
        double newLeft = deltaH + (double)element.GetValue(Canvas.LeftProperty);
        //邊界的判斷
        if (newLeft <= 0)
        {
          newLeft = 0;
        }
        //左側圖片框寬度 - 半透明矩形框寬度
        if (newLeft >= (this.SmallBox.Width - this.MoveRect.Width))
        {
          newLeft = this.SmallBox.Width - this.MoveRect.Width;
        }
        if (newTop <= 0)
        {
          newTop = 0;
        }
        //左側圖片框高度度 - 半透明矩形框高度度
        if (newTop >= this.SmallBox.Height - this.MoveRect.Height)
        {
          newTop = this.SmallBox.Height - this.MoveRect.Height;
        }
        element.SetValue(Canvas.TopProperty, newTop);
        element.SetValue(Canvas.LeftProperty, newLeft);
        AdjustBigImage();
        if (mousePosition.X <= 0 || mousePosition.Y <= 0) { return; }
      }
    }
    /// <summary>
    /// 調整右側大圖的位置
    /// </summary>
    void AdjustBigImage()
    {
      //獲取右側大圖框與透明矩形框的尺寸比率
      double n = this.BigBox.Width / this.MoveRect.Width;
      //獲取半透明矩形框在左側小圖中的位置
      double left = (double)this.MoveRect.GetValue(Canvas.LeftProperty);
      double top = (double)this.MoveRect.GetValue(Canvas.TopProperty);
      //計算和設置原圖在右側大圖框中的Canvas.Left 和 Canvas.Top
      double newLeft = -left * n;
      double newTop = -top * n;
      bigImg.SetValue(Canvas.LeftProperty, newLeft);
      bigImg.SetValue(Canvas.TopProperty, newTop);
    }
  }
}

附:完整實例代碼點擊此處本站下載。

希望本文所述對大家C#程序設計有所幫助。

延伸 · 閱讀

精彩推薦
  • C#C#實現XML文件讀取

    C#實現XML文件讀取

    這篇文章主要為大家詳細介紹了C#實現XML文件讀取的相關代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    Just_for_Myself6702022-02-22
  • C#C# 實現對PPT文檔加密、解密及重置密碼的操作方法

    C# 實現對PPT文檔加密、解密及重置密碼的操作方法

    這篇文章主要介紹了C# 實現對PPT文檔加密、解密及重置密碼的操作方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下...

    E-iceblue5012022-02-12
  • C#C#裁剪,縮放,清晰度,水印處理操作示例

    C#裁剪,縮放,清晰度,水印處理操作示例

    這篇文章主要為大家詳細介紹了C#裁剪,縮放,清晰度,水印處理操作示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    吳 劍8332021-12-08
  • C#C#設計模式之Visitor訪問者模式解決長隆歡樂世界問題實例

    C#設計模式之Visitor訪問者模式解決長隆歡樂世界問題實例

    這篇文章主要介紹了C#設計模式之Visitor訪問者模式解決長隆歡樂世界問題,簡單描述了訪問者模式的定義并結合具體實例形式分析了C#使用訪問者模式解決長...

    GhostRider9502022-01-21
  • C#C#通過KD樹進行距離最近點的查找

    C#通過KD樹進行距離最近點的查找

    這篇文章主要為大家詳細介紹了C#通過KD樹進行距離最近點的查找,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    帆帆帆6112022-01-22
  • C#深入解析C#中的交錯數組與隱式類型的數組

    深入解析C#中的交錯數組與隱式類型的數組

    這篇文章主要介紹了深入解析C#中的交錯數組與隱式類型的數組,隱式類型的數組通常與匿名類型以及對象初始值設定項和集合初始值設定項一起使用,需要的...

    C#教程網6172021-11-09
  • C#WPF 自定義雷達圖開發實例教程

    WPF 自定義雷達圖開發實例教程

    這篇文章主要介紹了WPF 自定義雷達圖開發實例教程,本文介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下...

    WinterFish13112021-12-06
  • C#Unity3D實現虛擬按鈕控制人物移動效果

    Unity3D實現虛擬按鈕控制人物移動效果

    這篇文章主要為大家詳細介紹了Unity3D實現虛擬按鈕控制人物移動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一...

    shenqingyu060520232410972022-03-11
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 亚洲卡一 | 久久免费99精品久久久久久 | 欧美片网站免费 | 亚洲va欧美va人人爽成人影院 | 亚洲午夜av| 久久久久久国产一级毛片高清版 | 日韩精品在线视频观看 | 免费国产一区 | 日本激情网| 国产免费看 | 91亚洲免费 | 久久久精品456亚洲影院 | 一级毛片免费播放 | 精品国产91亚洲一区二区三区www | 成人黄色在线 | 精品国产一区二区三区小蝌蚪 | 免费a视频 | www.久草| 国产一级一级毛片女人精品 | 日韩欧美视频 | 色xx综合网| 亚洲a在线观看 | 精品日韩一区 | 成人精品视频在线观看 | 日韩精品专区 | www.国产一区| 亚洲视频在线观看 | 日韩欧美国产精品综合嫩v 日韩a∨精品日韩在线观看 | 日韩欧美国产一区二区三区 | 亚洲第一色 | 偷拍自拍第一页 | 欧美九九| 国产精品成人观看视频国产奇米 | 日日骚av | 精品国产91亚洲一区二区三区www | 欧美一区二区在线视频 | www.青青草 | 91精品国产综合久久婷婷香蕉 | 国内免费自拍视频 | 日韩精品久久久 | 免费成人在线网站 |