MainWindow.xaml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. <Window x:Class="FastGithub.UI.MainWindow"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  5. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  6. xmlns:local="clr-namespace:FastGithub.UI"
  7. mc:Ignorable="d"
  8. Title="FastGithub" Height="480" Width="640" WindowStartupLocation="CenterScreen">
  9. <Window.Resources>
  10. <ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
  11. <Style x:Key="TabControlWithUnderLineStyle" TargetType="{x:Type TabControl}">
  12. <Setter Property="Padding" Value="2"/>
  13. <Setter Property="HorizontalContentAlignment" Value="Center"/>
  14. <Setter Property="VerticalContentAlignment" Value="Center"/>
  15. <Setter Property="Background" Value="White"/>
  16. <Setter Property="BorderBrush" Value="#FFACACAC"/>
  17. <Setter Property="BorderThickness" Value="1"/>
  18. <Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.ControlTextBrushKey}}"/>
  19. <Setter Property="Template">
  20. <Setter.Value>
  21. <ControlTemplate TargetType="{x:Type TabControl}">
  22. <Grid x:Name="templateRoot" ClipToBounds="True" SnapsToDevicePixels="True" KeyboardNavigation.TabNavigation="Local">
  23. <Grid.ColumnDefinitions>
  24. <ColumnDefinition x:Name="ColumnDefinition0"/>
  25. <ColumnDefinition x:Name="ColumnDefinition1" Width="0"/>
  26. </Grid.ColumnDefinitions>
  27. <Grid.RowDefinitions>
  28. <RowDefinition x:Name="RowDefinition0" Height="Auto"/>
  29. <RowDefinition x:Name="RowDefinition1" Height="*"/>
  30. </Grid.RowDefinitions>
  31. <TabPanel x:Name="HeaderPanel" HorizontalAlignment="Center" Background="Transparent" Grid.Column="0" IsItemsHost="True" Margin="0" Grid.Row="0" KeyboardNavigation.TabIndex="1" Panel.ZIndex="1"/>
  32. <Line X1="0" X2="{Binding ActualWidth, RelativeSource={RelativeSource Self}}" Stroke="Gray" StrokeThickness="0.1" VerticalAlignment="Bottom" Margin="0 0 0 1" SnapsToDevicePixels="True"/>
  33. <Border x:Name="ContentPanel" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" Grid.Column="0" KeyboardNavigation.DirectionalNavigation="Contained" Grid.Row="1" KeyboardNavigation.TabIndex="2" KeyboardNavigation.TabNavigation="Local">
  34. <ContentPresenter x:Name="PART_SelectedContentHost" ContentTemplate="{TemplateBinding SelectedContentTemplate}" Content="{TemplateBinding SelectedContent}" ContentStringFormat="{TemplateBinding SelectedContentStringFormat}" ContentSource="SelectedContent" Margin="0" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
  35. </Border>
  36. </Grid>
  37. <ControlTemplate.Triggers>
  38. <Trigger Property="TabStripPlacement" Value="Bottom">
  39. <Setter Property="Grid.Row" TargetName="HeaderPanel" Value="1"/>
  40. <Setter Property="Grid.Row" TargetName="ContentPanel" Value="0"/>
  41. <Setter Property="Height" TargetName="RowDefinition0" Value="*"/>
  42. <Setter Property="Height" TargetName="RowDefinition1" Value="Auto"/>
  43. </Trigger>
  44. <Trigger Property="TabStripPlacement" Value="Left">
  45. <Setter Property="Grid.Row" TargetName="HeaderPanel" Value="0"/>
  46. <Setter Property="Grid.Row" TargetName="ContentPanel" Value="0"/>
  47. <Setter Property="Grid.Column" TargetName="HeaderPanel" Value="0"/>
  48. <Setter Property="Grid.Column" TargetName="ContentPanel" Value="1"/>
  49. <Setter Property="Width" TargetName="ColumnDefinition0" Value="Auto"/>
  50. <Setter Property="Width" TargetName="ColumnDefinition1" Value="*"/>
  51. <Setter Property="Height" TargetName="RowDefinition0" Value="*"/>
  52. <Setter Property="Height" TargetName="RowDefinition1" Value="0"/>
  53. </Trigger>
  54. <Trigger Property="TabStripPlacement" Value="Right">
  55. <Setter Property="Grid.Row" TargetName="HeaderPanel" Value="0"/>
  56. <Setter Property="Grid.Row" TargetName="ContentPanel" Value="0"/>
  57. <Setter Property="Grid.Column" TargetName="HeaderPanel" Value="1"/>
  58. <Setter Property="Grid.Column" TargetName="ContentPanel" Value="0"/>
  59. <Setter Property="Width" TargetName="ColumnDefinition0" Value="*"/>
  60. <Setter Property="Width" TargetName="ColumnDefinition1" Value="Auto"/>
  61. <Setter Property="Height" TargetName="RowDefinition0" Value="*"/>
  62. <Setter Property="Height" TargetName="RowDefinition1" Value="0"/>
  63. </Trigger>
  64. <Trigger Property="IsEnabled" Value="False">
  65. <Setter Property="TextElement.Foreground" TargetName="templateRoot" Value="{DynamicResource {x:Static SystemColors.GrayTextBrushKey}}"/>
  66. </Trigger>
  67. </ControlTemplate.Triggers>
  68. </ControlTemplate>
  69. </Setter.Value>
  70. </Setter>
  71. </Style>
  72. <Style x:Key="TabItemExWithUnderLineStyle" TargetType="{x:Type TabItem}">
  73. <Setter Property="Foreground" Value="Black"/>
  74. <Setter Property="Background" Value="Transparent"/>
  75. <Setter Property="BorderBrush" Value="#FFACACAC"/>
  76. <Setter Property="Margin" Value="0"/>
  77. <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
  78. <Setter Property="VerticalContentAlignment" Value="Stretch"/>
  79. <Setter Property="Template">
  80. <Setter.Value>
  81. <ControlTemplate TargetType="{x:Type TabItem}">
  82. <Grid x:Name="templateRoot" SnapsToDevicePixels="True" Background="Transparent">
  83. <Border x:Name="_underline" BorderBrush="#37aefe" BorderThickness="0" Margin="{TemplateBinding Margin}"/>
  84. <Grid>
  85. <TextBlock x:Name="txt" Visibility="Visible" VerticalAlignment="Center" HorizontalAlignment="Center" Text="{TemplateBinding Header}" ToolTip="{TemplateBinding Header}" Foreground="{TemplateBinding Foreground}" TextTrimming="CharacterEllipsis" />
  86. </Grid>
  87. </Grid>
  88. <ControlTemplate.Triggers>
  89. <MultiDataTrigger>
  90. <MultiDataTrigger.Conditions>
  91. <Condition Binding="{Binding IsMouseOver, RelativeSource={RelativeSource Self}}" Value="true"/>
  92. <Condition Binding="{Binding TabStripPlacement, RelativeSource={RelativeSource FindAncestor, AncestorLevel=1, AncestorType={x:Type TabControl}}}" Value="Top"/>
  93. </MultiDataTrigger.Conditions>
  94. <Setter Property="FocusVisualStyle" Value="{x:Null}" />
  95. <Setter Property="Foreground" TargetName="txt" Value="#37aefe"/>
  96. </MultiDataTrigger>
  97. <MultiDataTrigger>
  98. <MultiDataTrigger.Conditions>
  99. <Condition Binding="{Binding IsEnabled, RelativeSource={RelativeSource Self}}" Value="false"/>
  100. <Condition Binding="{Binding TabStripPlacement, RelativeSource={RelativeSource FindAncestor, AncestorLevel=1, AncestorType={x:Type TabControl}}}" Value="Left"/>
  101. </MultiDataTrigger.Conditions>
  102. <Setter Property="Opacity" TargetName="templateRoot" Value="0.56"/>
  103. </MultiDataTrigger>
  104. <MultiDataTrigger>
  105. <MultiDataTrigger.Conditions>
  106. <Condition Binding="{Binding IsEnabled, RelativeSource={RelativeSource Self}}" Value="false"/>
  107. <Condition Binding="{Binding TabStripPlacement, RelativeSource={RelativeSource FindAncestor, AncestorLevel=1, AncestorType={x:Type TabControl}}}" Value="Bottom"/>
  108. </MultiDataTrigger.Conditions>
  109. <Setter Property="Opacity" TargetName="templateRoot" Value="0.56"/>
  110. </MultiDataTrigger>
  111. <MultiDataTrigger>
  112. <MultiDataTrigger.Conditions>
  113. <Condition Binding="{Binding IsEnabled, RelativeSource={RelativeSource Self}}" Value="false"/>
  114. <Condition Binding="{Binding TabStripPlacement, RelativeSource={RelativeSource FindAncestor, AncestorLevel=1, AncestorType={x:Type TabControl}}}" Value="Right"/>
  115. </MultiDataTrigger.Conditions>
  116. <Setter Property="Opacity" TargetName="templateRoot" Value="0.56"/>
  117. </MultiDataTrigger>
  118. <MultiDataTrigger>
  119. <MultiDataTrigger.Conditions>
  120. <Condition Binding="{Binding IsEnabled, RelativeSource={RelativeSource Self}}" Value="false"/>
  121. <Condition Binding="{Binding TabStripPlacement, RelativeSource={RelativeSource FindAncestor, AncestorLevel=1, AncestorType={x:Type TabControl}}}" Value="Top"/>
  122. </MultiDataTrigger.Conditions>
  123. <Setter Property="Opacity" TargetName="templateRoot" Value="0.56"/>
  124. </MultiDataTrigger>
  125. <MultiDataTrigger>
  126. <MultiDataTrigger.Conditions>
  127. <Condition Binding="{Binding IsSelected, RelativeSource={RelativeSource Self}}" Value="true"/>
  128. <Condition Binding="{Binding TabStripPlacement, RelativeSource={RelativeSource FindAncestor, AncestorLevel=1, AncestorType={x:Type TabControl}}}" Value="Top"/>
  129. </MultiDataTrigger.Conditions>
  130. <Setter Property="FocusVisualStyle" Value="{x:Null}" />
  131. <Setter Property="Panel.ZIndex" Value="1"/>
  132. <Setter Property="Foreground" TargetName="txt" Value="#37aefe"/>
  133. <Setter Property="BorderThickness" TargetName="_underline" Value="0 0 0 2"/>
  134. </MultiDataTrigger>
  135. </ControlTemplate.Triggers>
  136. </ControlTemplate>
  137. </Setter.Value>
  138. </Setter>
  139. </Style>
  140. </ResourceDictionary>
  141. </Window.Resources>
  142. <Grid Background="#00ffffff">
  143. <TabControl Style="{StaticResource TabControlWithUnderLineStyle}" Foreground="Black" Background="Transparent" BorderBrush="Transparent" BorderThickness="0">
  144. <TabItem Style="{StaticResource TabItemExWithUnderLineStyle}" Header="流量" Height="40" Width="60" Margin="5 0" FontSize="18">
  145. <Grid Background="#f7f7f7">
  146. <local:FlowChart Margin="16" />
  147. </Grid>
  148. </TabItem>
  149. <TabItem Style="{StaticResource TabItemExWithUnderLineStyle}" Header="日志" Height="40" Width="60" Margin="5 0" FontSize="18">
  150. <Grid Background="#f7f7f7">
  151. <local:UdpLogListBox/>
  152. </Grid>
  153. </TabItem>
  154. <TabItem Style="{StaticResource TabItemExWithUnderLineStyle}" Header="问答" Height="40" Width="60" Margin="5 0" FontSize="18">
  155. <Grid Background="#f7f7f7">
  156. <local:IssuesWebbrowser/>
  157. </Grid>
  158. </TabItem>
  159. <TabItem Style="{StaticResource TabItemExWithUnderLineStyle}" Header="打赏" Height="40" Width="60" Margin="5 0" FontSize="18">
  160. <Grid Background="#f7f7f7">
  161. <Image Source="Resource/reward.png" Margin="16" />
  162. </Grid>
  163. </TabItem>
  164. </TabControl>
  165. </Grid>
  166. </Window>