WPF:靜態、動態資源以及資源詞典
靜態資源與動態資源
我們常常會使用樣式或者控制元件模板放在Window.Resources中,比如這樣:
靜態資源與動態資源使用如下:
<Window.Resources>
<SolidColorBrush x:Key="SolidColor" Color="#FF0000" />
</Window.Resources>
<Grid>
<StackPanel>
<Button Height="40" Margin="10" Content="Button1" Click="Button_Click" />
<Button Height="40"
Margin="10"
Content="Button2"
BorderBrush="{StaticResource SolidColor}"
BorderThickness="4" />
<Button Height="40"
Margin="10"
Content="Button3"
BorderBrush="{DynamicResource SolidColor}"
BorderThickness="4" />
</StackPanel>
</Grid>
區別:動態資源是在介面中根據指令可以變化的,靜態則不會
data:image/s3,"s3://crabby-images/8dd07/8dd073b31b3163a1e4118239344d4b43d0b47a0e" alt="image-20240820214834842"
資源詞典
當樣式多了,這個時候我們需要單獨建立一個資源去管理他,這個時候我們就有了資源詞典:
將Window.Resources中的程式碼移植過來:
data:image/s3,"s3://crabby-images/1176d/1176da83acfcfde7f403eed19ac0b86d80f96eeb" alt="image-20240820215241649"
這個時候還得在載入時將這個資源詞典載入過來,在app.xaml中載入
data:image/s3,"s3://crabby-images/90bdb/90bdb300db447c46cc9b486a696e981e78967ed4" alt="image-20240820215351454"
在main中也可以查詢對應的資源,如下:
data:image/s3,"s3://crabby-images/611e0/611e050d3b781c777df94f359a9cb8869b8385d6" alt="image-20240820215507890"
結果依然可以得到:
data:image/s3,"s3://crabby-images/ce004/ce0047291309d9556711616f53f809b40b681fee" alt="image-20240820215717618"