[UWP]使用Reveal

来源:https://www.cnblogs.com/dino623/archive/2018/01/23/Reveal.html
-Advertisement-
Play Games

1. 前言 之前在 "如何使用Fluent Design System" 這篇文章里已經簡單介紹過Reveal的用法,這篇再詳細介紹其它內容。 2. 自定義RevealButtonStyle 我覺得常用ItemsControl都已經自動應用了Reveal,用就是了。 沒有預設應用Reveal的控制項, ...


1. 前言

之前在 如何使用Fluent Design System 這篇文章里已經簡單介紹過Reveal的用法,這篇再詳細介紹其它內容。

2. 自定義RevealButtonStyle

我覺得常用ItemsControl都已經自動應用了Reveal,用就是了。

沒有預設應用Reveal的控制項,UWP也為其中一部分提供了可用的Reveal樣式。

只需簡單地應用Style即可:

<Button Content="Button Content" Style="{StaticResource ButtonRevealStyle}"/>

其它用法官方文檔也有很詳細的教程,一時也想不到能玩出什麼花樣。。

但既然Reveal最大的作用是為一組元素提示其可操作區域,那麼對無邊框按鈕來說Reveal就很重要了。UWP沒有提供無邊框按鈕的Reveal樣式,可以自己實現一個:

<Style TargetType="Button">
    <Setter Property="Background"
            Value="{ThemeResource ButtonRevealBackground}" />
    <Setter Property="Foreground"
            Value="{ThemeResource ButtonForeground}" />
    <Setter Property="BorderBrush"
            Value="{ThemeResource ButtonRevealBorderBrush}" />
    <Setter Property="BorderThickness"
            Value="{ThemeResource ButtonRevealBorderThemeThickness}" />
    <Setter Property="Margin"
            Value="3" />
    <Setter Property="HorizontalAlignment"
            Value="Left" />
    <Setter Property="VerticalAlignment"
            Value="Center" />
    <Setter Property="FontFamily"
            Value="{ThemeResource ContentControlThemeFontFamily}" />
    <Setter Property="FontWeight"
            Value="Normal" />
    <Setter Property="FontSize"
            Value="20" />
    <Setter Property="UseSystemFocusVisuals"
            Value="True" />
    <Setter Property="FocusVisualMargin"
            Value="-3" />
    <Setter Property="Height"
            Value="50" />
    <Setter Property="Width"
            Value="50" />
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="Button">
                <Grid x:Name="RootGrid">
                    <VisualStateManager.VisualStateGroups>
                        <VisualStateGroup x:Name="CommonStates">
                            <VisualState x:Name="Normal">
                                <Storyboard>
                                    <PointerUpThemeAnimation Storyboard.TargetName="RootGrid" />
                                </Storyboard>
                            </VisualState>
                            <VisualState x:Name="PointerOver">
                                <VisualState.Setters>
                                    <Setter Target="RootGrid.(RevealBrush.State)"
                                            Value="PointerOver" />
                                    <Setter Target="BackgroundElement.Fill"
                                            Value="{ThemeResource ButtonRevealBackgroundPointerOver}" />
                                    <Setter Target="BackgroundElement.Stroke"
                                            Value="{ThemeResource ButtonRevealBorderBrushPointerOver}" />
                                    <Setter Target="ContentPresenter.Foreground"
                                            Value="{ThemeResource ButtonForegroundPointerOver}" />
                                </VisualState.Setters>
                                <Storyboard>
                                    <PointerUpThemeAnimation Storyboard.TargetName="RootGrid" />
                                </Storyboard>
                            </VisualState>
                            <VisualState x:Name="Pressed">
                                <VisualState.Setters>
                                    <Setter Target="RootGrid.(RevealBrush.State)"
                                            Value="Pressed" />
                                    <Setter Target="BackgroundElement.Fill"
                                            Value="{ThemeResource ButtonRevealBackgroundPressed}" />
                                    <Setter Target="BackgroundElement.Stroke"
                                            Value="{ThemeResource ButtonRevealBorderBrushPressed}" />
                                    <Setter Target="ContentPresenter.Foreground"
                                            Value="{ThemeResource ButtonForegroundPressed}" />
                                </VisualState.Setters>
                                <Storyboard>
                                    <PointerDownThemeAnimation Storyboard.TargetName="RootGrid" />
                                </Storyboard>
                            </VisualState>
                            <VisualState x:Name="Disabled">
                                <VisualState.Setters>
                                    <Setter Target="BackgroundElement.Fill"
                                            Value="{ThemeResource ButtonRevealBackgroundDisabled}" />
                                    <Setter Target="BackgroundElement.Stroke"
                                            Value="{ThemeResource ButtonRevealBorderBrushDisabled}" />
                                    <Setter Target="ContentPresenter.Foreground"
                                            Value="{ThemeResource ButtonForegroundDisabled}" />
                                </VisualState.Setters>
                            </VisualState>
                        </VisualStateGroup>
                    </VisualStateManager.VisualStateGroups>
                    <Ellipse Stroke="{TemplateBinding BorderBrush}"
                             StrokeThickness="2"
                             Fill="Transparent"
                             x:Name="BackgroundElement" />
                    <ContentPresenter x:Name="ContentPresenter"
                                      Content="{TemplateBinding Content}"
                                      ContentTransitions="{TemplateBinding ContentTransitions}"
                                      ContentTemplate="{TemplateBinding ContentTemplate}"
                                      Padding="{TemplateBinding Padding}"
                                      HorizontalContentAlignment="{TemplateBinding HorizontalContentAlignment}"
                                      VerticalContentAlignment="{TemplateBinding VerticalContentAlignment}"
                                      AutomationProperties.AccessibilityView="Raw" />
                </Grid>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
</Style>

這個樣式實現了一個圓形的無邊框按鈕。看起來各種Reveal的Brush等資源都已高度封裝好,不容易自定義。實際運行起來賞心悅目,這種效果,我很喜歡:

剛開始真的覺得這是程式員為了炫技而產生的效果,實際上配合Acrylic用起來整個不僅整個UI閃閃發光(很多人就是喜歡這個效果),而且提示可操作區域的解決方案中Reveal是目前我最滿意的一個。像上面那個無邊框按鈕,它可以比幽靈按鈕更進一步的簡約,但滑鼠接近時又可以清清楚楚提示哪些地方是可以操作的。

3. 註意事項

Reveal雖然很美好,用起來也很多講究,重覆一次以前提過的註意事項:

  • 只應該在可操作的元素上使用Reveal。
  • 不要在孤立的元素上使用Reveal。
  • 不要在大面積的元素上使用Reveal。
  • 靜態元素(例如文字和背景)不應該使用Reveal。
  • 不應該讓Reveal干擾重要的信息。

也就是說在List或一組按鈕上使用才是正確用法。別一時興起將SystemControlBackgroundAccentRevealBorderBrush之類的用在背景。

其它事項如Reveal沒有生效及版本相容性,可見之前的文章:如何使用Fluent Design System (下)

4. 結語

光照一直是設計師夢寐以求的元素,但不要因為可以用就去亂用,要適可而止(講到我自己都覺得自己很婆婆媽媽了)。

5. 參考

Reveal highlight

6. 源碼

Fluent Design System Sample


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

-Advertisement-
Play Games
更多相關文章
  • 首先獲取兩鐘不同玉米的產量數據。 因為用了python的pandas包,因此讀取數據前需要先引入pandas包。 圖1 不同玉米用A B 表示,以下是讀取了數據的前5行。 圖2 分別把品種 A和品種B 的 玉米產量賦值給X和Y 。 然後用scipy.stats 包中的 levene 函數 檢驗數據方 ...
  • 操作系統 : CentOS7.3.1611_x64 go 版本 : go1.8.3 linux/amd64 vim版本 :version 7.4.160 vim配置go語言語法高亮的問題已經遇到過好幾次了,每次都去查找太麻煩,這裡總結下。 安裝git: 安裝vim-go : 配置vimrc文件: 如 ...
  • 前言 redis 大家都使用過, 可以安裝在windows下, 也可以安裝在linux下, 一般還是linux下安裝比較多. 這裡來介紹一下redis在linux下的安裝 一. 下載 https://redis.io/ 二. 安裝 1. 下載之後, 將文件拷貝到 linux 中. 我這裡是放在 /h ...
  • ###反射## getattr,hasattr,setattr,delattr,和類裡面的欄位有關,具體看例子 #1 class Person: def __init__(self,name,age): self.name = name self.age = age def show_lover(s ...
  • java.util.Date 就是在除了SQL語句的情況下麵使用 java.sql.Date 是針對SQL語句使用的,它只包含日期而沒有時間部分 直接說就是:java.sql.Date就是與資料庫Date相對應的一個類型,而java.util.Date是純java的Date 它都有getTime方法 ...
  • 1:列表: Python的列表比C語言的數組強大的多,數組只能存放相同類型的數據,而列表則像一個大集裝箱可以存放整形、浮點型、字元串、對象等 2:創建列表的方法 3:向列表中添加元素的方法 1)append() 向列表末尾添加一個參數 2)extend() 參數為一個列表,從原列表擴展原有列表 3) ...
  • 在 《不一樣的Interceptor》中我們著重介紹了Dora.Interception中最為核心的對象Interceptor,以及定義Interceptor類型的一些約定。由於Interceptor總是通過攔截某個方法的調用進而實現對前置或者後置操作的註入,所以我們定義的Interceptor類型... ...
  • 上一篇文章介紹了OAuth2.0以及如何使用.Net來實現基於OAuth的身份驗證,本文是對上一篇文章的補充,主要是介紹OAuth與Jwt以及OpenID Connect之間的關係與區別。 本文主要內容有: ● Jwt簡介 ● .Net的Jwt實現 ● OAuth與Jwt ● .Net中使用Jwt ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...