背水一戰 Windows 10 (71) - 控制項(控制項基類): UIElement - RenderTransform(2D變換), Clip(剪裁)

来源:http://www.cnblogs.com/webabcd/archive/2017/10/23/7713981.html
-Advertisement-
Play Games

背水一戰 Windows 10 之 控制項(控制項基類 - UIElement ): RenderTransform(2D變換), Clip(剪裁) ...


[源碼下載]


背水一戰 Windows 10 (71) - 控制項(控制項基類): UIElement - RenderTransform(2D變換), Clip(剪裁)



作者:webabcd


介紹
背水一戰 Windows 10 之 控制項(控制項基類 - UIElement )

  • RenderTransform(2D變換)
  • Clip(剪裁)



示例
1、演示 UIElement 的 2D 變換的應用
Controls/BaseControl/UIElementDemo/RenderTransformDemo.xaml

<Page
    x:Class="Windows10.Controls.BaseControl.UIElementDemo.RenderTransformDemo"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.BaseControl.UIElementDemo"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid Background="Transparent">
        <Grid Margin="10 0 10 10">

            <!--
                RenderTransform - 2D 變換(位移,旋轉,縮放,扭曲等)
            -->

            <Grid HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>

                        <!--RotateTransform - 旋轉變換(順時針)-->
                        <!--
                            Angle - 旋轉角度。預設值 0
                            CenterX - 旋轉中心點的 X 軸坐標。預設值 0
                            CenterY - 旋轉中心點的 Y 軸坐標。預設值 0
                        -->
                        <RotateTransform Angle="15" CenterX="100" CenterY="50" />

                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <Grid Margin="400 0 0 0" HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <!--
                    RenderTransformOrigin - 位置變換的中心點(這是一個相對值,元素左上角為 0,0,元素右下角為 1,1,支持小於 0 或大於 1 的值)
                        這個值是 Point 類型,在 xaml 中可以用逗號或空格分隔
                -->
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3" RenderTransformOrigin="0.5,0.5">
                    <Rectangle.RenderTransform>
                        <RotateTransform Angle="15" />
                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <Grid Margin="800 0 0 0" HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>

                        <!--TranslateTransform - 平移變換-->
                        <!--
                            X - 水平方向上移動的距離。預設值 0
                            Y - 垂直方向上移動的距離。預設值 0
                        -->
                        <TranslateTransform X="100" Y="10" />

                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <Grid Margin="0 200 0 0" HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>

                        <!--ScaleTransform - 縮放變換-->
                        <!--
                            ScaleX - X 軸方向上縮放的倍數。預設值 1
                            ScaleY - Y 軸方向上縮放的倍數。預設值 1
                            CenterX - 縮放中心點的 X 軸坐標。預設值 0
                            CenterY - 縮放中心點的 Y 軸坐標。預設值 0
                        -->
                        <ScaleTransform ScaleX="1.1" ScaleY="1.3" CenterX="100" CenterY="50" />

                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <Grid Margin="400 200 0 0"  HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>

                        <!--SkewTransform - 扭曲變換(典型應用:在 二維 對象中模擬 三維 深度)-->
                        <!--
                            CenterX - 扭曲中心點的 X 軸坐標。預設值 0
                            CenterY - 扭曲中心點的 Y 軸坐標。預設值 0
                            AngleX - X 軸扭曲角度,Y 軸繞原點旋轉(逆時針)。CenterX 對此值所產生的呈現結果沒有影響。預設值 0
                            AngleY - Y 軸扭曲角度,X 軸繞原點旋轉(順時針)。CenterY 對此值所產生的呈現結果沒有影響。預設值 0
                        -->
                        <SkewTransform AngleX="30" AngleY="5" CenterX="0" CenterY="0" />

                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <Grid Margin="800 200 0 0"  HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>

                        <!--TransformGroup - 多個 Transform 組成的複合變換-->
                        <TransformGroup>
                            <TranslateTransform X="100" Y="10" />
                            <RotateTransform Angle="15" CenterX="100" CenterY="50" />
                        </TransformGroup>

                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <!--
                CompositeTransform - 將多種變換方式合而為一
                    CenterX - 變換中心點的 X 坐標
                    CenterY - 變換中心點的 Y 坐標
                    Rotation - 順時針旋轉角度
                    ScaleX - 沿 X 軸方向上的縮放比例
                    ScaleY - 沿 Y 軸方向上的縮放比例
                    SkewX - X 軸扭曲角度
                    SkewY - Y 軸扭曲角度
                    TranslateX - 沿 X 軸方向上的平移距離
                    TranslateY - 沿 Y 軸方向上的平移距離
            -->
            <Grid Margin="0 400 0 0" HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>
                        <CompositeTransform SkewX="30" Rotation="60" ScaleX="0.6" ScaleY="0.3" />
                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

            <!--
                MatrixTransform - 仿射矩陣變換
            
                |X|             |M11(預設值 1)      M21(預設值 0)       0|
                |Y| = |x y 1| * |M12(預設值 0)      M22(預設值 1)       0|
                |1|             |OffsetX(預設值 0)  OffsetY(預設值 0)   1|
            
                X = x * M11 + y * M12 + OffsetX
                Y = x * M21 + y * M22 + OffsetY
            
                利用 MatrixTransform 實現平移、旋轉、縮放、扭曲的 Demo 詳見 http://www.cnblogs.com/webabcd/archive/2008/11/03/1325150.html
            -->
            <Grid Margin="400 400 0 0" HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" StrokeDashArray="3,1" Stroke="Blue" StrokeThickness="3" />
                <Rectangle Width="200" Height="100" Fill="Yellow" Stroke="Red" StrokeThickness="3" Opacity="0.3">
                    <Rectangle.RenderTransform>
                        <!--
                            m11, m12, m21, m22, offsetX, offsetY
                        -->
                        <MatrixTransform Matrix="1, 0.5, 0, 1, 30, 10" />
                    </Rectangle.RenderTransform>
                </Rectangle>
            </Grid>

        </Grid>
    </Grid>
</Page>

Controls/BaseControl/UIElementDemo/RenderTransformDemo.xaml.cs

/*
 * UIElement - UIElement(繼承自 DependencyObject, 請參見 /Controls/BaseControl/DependencyObjectDemo/)
 *     RenderTransform - 2D 變換(位移,旋轉,縮放,扭曲等)
 *     RenderTransformOrigin - 2D 變換的原點(這是一個相對值,元素左上角為 0,0,元素右下角為 1,1,支持小於 0 或大於 1 的值)
 *     
 *     
 * 本例用於演示 UIElement 的 2D 變換的應用
 */

using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.BaseControl.UIElementDemo
{
    public sealed partial class RenderTransformDemo : Page
    {
        public RenderTransformDemo()
        {
            this.InitializeComponent();
        }
    }
}


2、演示 UIElement 的 Clip 的應用
Controls/BaseControl/UIElementDemo/ClipDemo.xaml

<Page
    x:Class="Windows10.Controls.BaseControl.UIElementDemo.ClipDemo"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:Windows10.Controls.BaseControl.UIElementDemo"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d">

    <Grid Background="Transparent">
        <StackPanel Margin="10 0 10 10">

            <Grid HorizontalAlignment="Left" VerticalAlignment="Top">
                <Rectangle Width="200" Height="100" Fill="Red" />
                <Rectangle Width="200" Height="100" Fill="Green">

                    <!--
                        Clip - 剪裁 UIElement 的指定區域(即讓 UIElement 的指定區域變為透明)
                        
                        註:目前只能通過 RectangleGeometry 剪裁 UIElement
                    -->
                    <Rectangle.Clip>
                        <RectangleGeometry Rect="10 10 50 50" />
                    </Rectangle.Clip>
                </Rectangle>
            </Grid>

        </StackPanel>
    </Grid>
</Page>

Controls/BaseControl/UIElementDemo/ClipDemo.xaml.cs

/*
 * UIElement - UIElement(繼承自 DependencyObject, 請參見 /Controls/BaseControl/DependencyObjectDemo/)
 *     Clip - 剪裁 UIElement 的指定區域(目前只支持通過 RectangleGeometry 剪裁 UIElement)
 *     
 *     
 * 本例用於演示 UIElement 的 Clip 的應用
 */

using Windows.UI.Xaml.Controls;

namespace Windows10.Controls.BaseControl.UIElementDemo
{
    public sealed partial class ClipDemo : Page
    {
        public ClipDemo()
        {
            this.InitializeComponent();
        }
    }
}



OK
[源碼下載]


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

-Advertisement-
Play Games
更多相關文章
  • Html.DropDownList傳值: 可以傳入明確的IEnumerable<SelectListItem>,也可以通過ViewBag或者ViewData隱式地傳入,前提是需要相同的名稱,比如:ViewBag.GenreId或者ViewData["GenreId"]。 示例: 視圖: 註意: 1. ...
  • C#的編譯器總是將匿名類型編譯成internal的,當在視圖中直接使用控制器傳遞的匿名對象時就會報錯錯誤代碼:控制器代碼視圖代碼執行結果:********************************************************************************* ...
  • 此示例展示了框架級依賴註入如何在 ASP.NET Core 中工作。 其簡單但功能強大,足以完成大部分的依賴註入工作。 ...
  • 直接代碼 樣式代碼 調用實例 效果展示 本文原創出處:http://www.cnblogs.com/PettyHandSome/ 歡迎各位轉載,但是未經作者本人同意,轉載文章之後必須在文章頁面明顯位置給出作者和原文連接,否則保留追究法律責任的權利! ...
  • 1.起因 同事在調用錄音控制項生成的MP3,在部分瀏覽器中載入失敗,出現彈框提示。 經過同事的對比,發現當文件屬性中比特率 為0kbps,時長為空的時候就會出現上圖這種情況。並給找到一個解決方案,使用ffmpeg進行一次轉碼後就會出現比特率和時長,瀏覽器也可以正常載入。 異常的情況 正常的情況 2.問 ...
  • 1、實現ILifeSpanHandler介面,為了支持帶type="POST" target="_blank"的鏈接,並且為了後面能夠獲取到ChromiumWebBrowser並釋放舊的ChromiumWebBrowser,新窗體還是要讓它彈的,只不過後面會隱藏它,代碼如下: using CefSh ...
  • Options: using CommandLine; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namesp ...
  • Server.Transfer 這個方法相比以前介紹的方法稍微複雜一點,但在頁面間值傳遞中卻是特別有用的,使用該方法你可以在另一個頁面以對象屬性的方式來存取顯露的值,當然了,使用這種方法,你需要額外寫一些代碼以創建一些屬性以便可以在另一個頁面訪問它,但是,這個方式帶來的好處也是顯而易見的。 總的來說 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...