WPF開發經驗-實現一種通用閥門控制項

来源:https://www.cnblogs.com/wwwen/archive/2022/12/19/16992344.html
-Advertisement-
Play Games

一 引入 在設計設備界面時,經常會有一種需求,展示一個閥門,閥門有通斷兩種狀態: 二 CommonValveControl 考慮實現一個自定義控制項,CommonValveControl。 使用自定義控制項比用戶控制項更靈活,更具擴展性,可以使用不同的樣式和模板。 CommonValveControl定義 ...


一 引入

在設計設備界面時,經常會有一種需求,展示一個閥門,閥門有通斷兩種狀態:

 

二 CommonValveControl

考慮實現一個自定義控制項,CommonValveControl。

使用自定義控制項比用戶控制項更靈活,更具擴展性,可以使用不同的樣式和模板。

CommonValveControl定義兩個依賴屬性,Orientation表示安裝展示的方向,Status表示閥門的通斷狀態。

public class CommonValveControl : Control
{
    static CommonValveControl()
    {
        DefaultStyleKeyProperty.OverrideMetadata(typeof(CommonValveControl), new FrameworkPropertyMetadata(typeof(CommonValveControl)));
    }
   
    public bool Status
    {
        get => (bool)GetValue(StatusProperty);
        set => SetValue(StatusProperty, value);
    }
    public static readonly DependencyProperty StatusProperty = DependencyProperty.Register(
       "Status",
       typeof(bool),
       typeof(CommonValveControl));
    
    public Orientation ValveOrientation
    {
        get => (Orientation)GetValue(CommonValveOrientationProperty);
        set => SetValue(CommonValveOrientationProperty, value);
    }
    public static readonly DependencyProperty CommonValveOrientationProperty = DependencyProperty.Register(
        "ValveOrientation",
        typeof(Orientation),
        typeof(CommonValveControl));
}

設計CommonValveControl的樣式模板,可通過設計不同的模板,以呈現出不同的效果。

通過ValveOrientation屬性觸發切換閥門的豎直狀態和水平狀態。

<Style TargetType="{x:Type local:CommonValveControl}">
    <Setter Property="Cursor" Value="Hand" />
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type local:CommonValveControl}">
                <Viewbox Stretch="Fill">
                    <Grid>
                        <Canvas Width="40" Height="40" >
                            <Ellipse Height="40" Width="40" Fill="Gray"/>
                            <Ellipse x:Name="InnerEllipse" Height="30" Width="30" Canvas.Left="5" Canvas.Top="5" 
                            <Rectangle x:Name="Rectangle" Fill="White" RadiusX="2" RadiusY="2"/>
                        </Canvas>
                    </Grid>
                </Viewbox>
                <ControlTemplate.Triggers>
                    <Trigger Property="Status" Value="false">
                        <Setter TargetName="InnerEllipse" Property="Fill" Value="Red"/>
                    </Trigger>
                    <Trigger Property="Status" Value="true">
                        <Setter TargetName="InnerEllipse" Property="Fill" Value="Green"/>
                    </Trigger>
                    <MultiTrigger>
                        <MultiTrigger.Conditions>
                            <Condition Property="ValveOrientation" Value="Horizontal"/>
                            <Condition Property="Status" Value="false"/>
                        </MultiTrigger.Conditions>
                        <Setter TargetName="Rectangle" Property="Width" Value="6"/>
                        <Setter TargetName="Rectangle" Property="Height" Value="30"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Left" Value="17"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Top" Value="5"/>
                    </MultiTrigger>
                    <MultiTrigger>
                        <MultiTrigger.Conditions>
                            <Condition Property="ValveOrientation" Value="Horizontal"/>
                            <Condition Property="Status" Value="true"/>
                        </MultiTrigger.Conditions>
                        <Setter TargetName="Rectangle" Property="Width" Value="30"/>
                        <Setter TargetName="Rectangle" Property="Height" Value="6"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Left" Value="5"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Top" Value="17"/>
                    </MultiTrigger>
                    <MultiTrigger>
                        <MultiTrigger.Conditions>
                            <Condition Property="ValveOrientation" Value="Vertical"/>
                            <Condition Property="Status" Value="false"/>
                        </MultiTrigger.Conditions>
                        <Setter TargetName="Rectangle" Property="Width" Value="30"/>
                        <Setter TargetName="Rectangle" Property="Height" Value="6"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Left" Value="5"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Top" Value="17"/>
                    </MultiTrigger>
                    <MultiTrigger>
                        <MultiTrigger.Conditions>
                            <Condition Property="ValveOrientation" Value="Vertical"/>
                            <Condition Property="Status" Value="true"/>
                        </MultiTrigger.Conditions>
                        <Setter TargetName="Rectangle" Property="Width" Value="6"/>
                        <Setter TargetName="Rectangle" Property="Height" Value="30"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Left" Value="17"/>
                        <Setter TargetName="Rectangle" Property="Canvas.Top" Value="5"/>
                    </MultiTrigger>
                </ControlTemplate.Triggers>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

三 效果演示

Xaml代碼:

<Canvas>
    <local:PipeControl Width="106" Height="14" Canvas.Left="26" Canvas.Top="53"/>
    <local:PipeControl Width="14" Height="80" Canvas.Left="185" Canvas.Top="22" Orientation="Vertical"/>
    <local:CommonValveControl x:Name="valve1" Status="False" ValveOrientation="Horizontal" Width="40" Height="40" Canvas.Left="60" Canvas.Top="41"/>
    <local:CommonValveControl x:Name="valve2" Status="False" ValveOrientation="Vertical" Width="40" Height="40" Canvas.Left="172" Canvas.Top="41"/>
    <Button Content="Open" Click="OpenButton_Click" Canvas.Left="272" Canvas.Top="15" Width="66" Height="35"/>
    <Button Content="Close" Click="CloseButton_Click" Canvas.Left="272" Canvas.Top="71" Width="66" Height="35"/>
</Canvas>

 後臺代碼:

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
    }

    private void OpenButton_Click(object sender, RoutedEventArgs e)
    {
        valve1.Status = true;
        valve2.Status = true;
    }

    private void CloseButton_Click(object sender, RoutedEventArgs e)
    {
        valve1.Status = false;
        valve2.Status = false;
    }
}

 

__ 以 上 __

一團靜火的頭像
  • 本文作者: 一團靜火
  • 本文鏈接: https://www.cnblogs.com/wwwen/p/16992344.html
  • 關於博主: 水平有限,不足或錯誤之處,請批評指正。如果文章對您有幫助,可以點擊文章右下角【推薦】一下。
  • 版權聲明: 本博客所有文章除特別聲明外,系原創文章,均採用 BY-NC-SA 許可協議。轉載請註明出處!並保留此段內容。

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

    -Advertisement-
    Play Games
    更多相關文章
    • Shell 變數(一) bash shell 編程和其他編程語言差不多,同樣包含變數(存放字元串和數值的容器,可以進行修改、比較、傳遞)。在引用 bash 變數時,可以使用一些非常特殊的運算符。bash 還擁有內建變數,這些變數可以提供有關腳本中其他變數的重要信息。下麵介紹 bash 變數和一些特殊 ...
    • Qt C++界面開發過程中,使用自定義的QGroupBox類,重寫繪圖事件paintEvent時,出現邊框被覆蓋的情況,或邊框消失的問題。 ...
    • 來源:https://juejin.cn/post/7123091045071454238 一個優秀的 Controller 層邏輯 說到 Controller,相信大家都不陌生,它可以很方便地對外提供數據介面。它的定位,我認為是「不可或缺的配角」。 說它不可或缺是因為無論是傳統的三層架構還是現在的 ...
    • 一. anaconda 簡介 Anaconda是一個開源的Python發行版本,用來管理Python相關的包,安裝Anaconda可以很方便的切換不同的環境,使用不同的深度學習框架開發項目。 二. anaconda 下載地址 anaconda 官網地址: https://www.anaconda.c ...
    • 代碼里我們經常會出現大量的條件判斷,在這種情況下,我們可以實現狀態機避免過度使用 有一種方式是把各種狀態歸為各種狀態類 還有一種方式是修改實例的__class__屬性 1 """ 2 狀態機的實現 3 修改實例的__class__屬性 4 """ 5 6 7 class Connection: 8 ...
    • JZ47 禮物的最大價值 描述 描述 在一個m\times nm×n的棋盤的每一格都放有一個禮物,每個禮物都有一定的價值(價值大於 0)。你可以從棋盤的左上角開始拿格子里的禮物,並每次向右或者向下移動一格、直到到達棋盤的右下角。給定一個棋盤及其上面的禮物的價值,請計算你最多能拿到多少價值的禮物? 如 ...
    • 面向對象 1.面向對象簡介 類(Class): 用來描述具有相同的屬性和方法的對象的集合。它定義了該集合中每個對象所共有的屬性和方法。對象是類的實例。 方法:類中定義的函數。 類變數:類變數在整個實例化的對象中是公用的。類變數定義在類中且在函數體之外。類變數通常不作為實例變數使用。 數據成員:類變數 ...
    • 一:背景 1.講故事 今天是🐏的第四天,頭終於不巨疼了,寫文章已經沒什麼問題,趕緊爬起來寫。 這個月初有位朋友找到我,說他的程式出現了CPU爆高,讓我幫忙看下怎麼回事,簡單分析了下有兩點比較有意思。 這是一個安全生產的信息管理平臺,第一次聽說,我的格局小了。 這是一個經典的 CPU 爆高問題,過往 ...
    一周排行
      -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...