AnalogSignalPreviewView.axaml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. <UserControl
  2. x:Class="ShakerApp.Views.AnalogSignalPreviewView"
  3. xmlns="https://github.com/avaloniaui"
  4. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  5. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  6. xmlns:local="using:ShakerApp"
  7. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  8. xmlns:oxy="http://oxyplot.org/avalonia"
  9. xmlns:suki="https://github.com/kikipoulet/SukiUI"
  10. xmlns:vm="using:ShakerApp.ViewModels"
  11. d:DesignHeight="450"
  12. d:DesignWidth="800"
  13. x:DataType="vm:AnalogSignalPreviewViewModel"
  14. mc:Ignorable="d">
  15. <Grid>
  16. <oxy:PlotView
  17. Background="Transparent"
  18. Controller="{Binding PlotController}"
  19. Model="{Binding PlotModel}">
  20. <oxy:PlotView.DefaultTrackerTemplate>
  21. <ControlTemplate>
  22. <oxy:TrackerControl
  23. Background="#6F999999"
  24. BorderBrush="Transparent"
  25. CornerRadius="6"
  26. HorizontalLineVisibility="False"
  27. LineExtents="{Binding PlotModel.PlotArea}"
  28. LineStroke="Gray"
  29. Position="{Binding Position}"
  30. ShowPointer="True"
  31. VerticalLineVisibility="True">
  32. <oxy:TrackerControl.Content>
  33. <StackPanel Margin="10">
  34. <TextBlock Text="{DynamicResource Value}" />
  35. <TextBlock>
  36. <Run Text="{Binding XAxis.Title}" />
  37. <Run Text=":" />
  38. <Run Text="{Binding TrackerDatas[0].DataPoint.X, StringFormat='{}{0:F2}'}" />
  39. <Run Text="{Binding XAxis.Unit}" />
  40. </TextBlock>
  41. <ItemsControl ItemsSource="{Binding TrackerDatas}">
  42. <ItemsControl.ItemTemplate>
  43. <DataTemplate>
  44. <TextBlock IsVisible="{Binding Series.IsVisible}">
  45. <Run Text="{Binding Series.Title}" />
  46. <Run Text=":" />
  47. <Run Text="{Binding DataPoint.Y, StringFormat='{}{0:F4}'}" />
  48. <Run Text="{Binding $parent[ItemsControl].DataContext.YAxis.Unit}" />
  49. </TextBlock>
  50. </DataTemplate>
  51. </ItemsControl.ItemTemplate>
  52. </ItemsControl>
  53. </StackPanel>
  54. </oxy:TrackerControl.Content>
  55. </oxy:TrackerControl>
  56. </ControlTemplate>
  57. </oxy:PlotView.DefaultTrackerTemplate>
  58. </oxy:PlotView>
  59. <Button
  60. Margin="0,0,16,56"
  61. HorizontalAlignment="Right"
  62. VerticalAlignment="Bottom"
  63. Classes="Basic"
  64. Cursor="Hand">
  65. <Interaction.Behaviors>
  66. <EventTriggerBehavior EventName="Click">
  67. <InvokeCommandAction Command="{Binding Source={x:Static vm:PlotConfigViewModel.Instance}, Path=PlotConfigCommand}" CommandParameter="{Binding PlotModel}" />
  68. </EventTriggerBehavior>
  69. </Interaction.Behaviors>
  70. <PathIcon Background="Transparent" Data="{StaticResource SettingGeometry}">
  71. <PathIcon.Styles>
  72. <Style Selector="PathIcon:pointerover">
  73. <Setter Property="Foreground" Value="Black" />
  74. </Style>
  75. <Style Selector="PathIcon">
  76. <Setter Property="Foreground" Value="#AAAAAAAA" />
  77. </Style>
  78. </PathIcon.Styles>
  79. </PathIcon>
  80. </Button>
  81. <StackPanel
  82. HorizontalAlignment="Right"
  83. VerticalAlignment="Top"
  84. Orientation="Horizontal">
  85. <StackPanel Margin="10,0,0,0" Orientation="Horizontal">
  86. <TextBlock VerticalAlignment="Center" Text="{DynamicResource Statistics}" />
  87. <ToggleSwitch IsChecked="{Binding StatisticsVisibily, Mode=TwoWay}" />
  88. </StackPanel>
  89. <StackPanel
  90. Margin="10,0,0,0"
  91. IsVisible="{Binding THDVisibily}"
  92. Orientation="Horizontal">
  93. <TextBlock VerticalAlignment="Center" Text="THD" />
  94. <ToggleSwitch IsChecked="{Binding THDEnabled, Mode=TwoWay}" />
  95. </StackPanel>
  96. <Button
  97. HorizontalAlignment="Right"
  98. VerticalAlignment="Top"
  99. Classes="Basic"
  100. IsVisible="{Binding CanChangedAnalog}">
  101. <PathIcon Data="{StaticResource SettingGeometry}" />
  102. <Button.Flyout>
  103. <Flyout ShowMode="Standard">
  104. <suki:GlassCard
  105. Background="Black"
  106. CornerRadius="10"
  107. Opacity="1"
  108. OpacityMask="Black">
  109. <suki:GroupBox>
  110. <suki:GroupBox.Header>
  111. <TextBlock Foreground="White" Text="{DynamicResource SelectSignalType}" />
  112. </suki:GroupBox.Header>
  113. <ItemsControl ItemsSource="{Binding Menu}">
  114. <ItemsControl.ItemTemplate>
  115. <DataTemplate>
  116. <Grid
  117. Name="item"
  118. Height="{StaticResource ItemHeight}"
  119. x:DataType="vm:TimeDomainMenuViewModel"
  120. Background="Transparent"
  121. Cursor="Hand">
  122. <Interaction.Behaviors>
  123. <EventTriggerBehavior EventName="PointerReleased">
  124. <ChangePropertyAction
  125. PropertyName="SelectedAnalog"
  126. TargetObject="{Binding $parent[Button].DataContext}"
  127. Value="{Binding #item.DataContext.AnalogType}" />
  128. </EventTriggerBehavior>
  129. </Interaction.Behaviors>
  130. <Grid.Styles>
  131. <Style Selector="Grid:pointerover">
  132. <Setter Property="Background" Value="LightGray" />
  133. </Style>
  134. </Grid.Styles>
  135. <Grid.ColumnDefinitions>
  136. <ColumnDefinition Width="30" />
  137. <ColumnDefinition Width="*" />
  138. </Grid.ColumnDefinitions>
  139. <PathIcon
  140. Data="{x:Static suki:Icons.Check}"
  141. Foreground="White"
  142. IsVisible="{Binding IsChecked}" />
  143. <Line
  144. HorizontalAlignment="Right"
  145. VerticalAlignment="Center"
  146. Stroke="LightGray"
  147. StrokeThickness="2"
  148. StartPoint="0,4"
  149. EndPoint="0,24" />
  150. <TextBlock
  151. Grid.Column="1"
  152. Margin="10,0,0,0"
  153. HorizontalAlignment="Left"
  154. VerticalAlignment="Center"
  155. Foreground="White"
  156. Text="{local:ResourceBinding Key}" />
  157. </Grid>
  158. </DataTemplate>
  159. </ItemsControl.ItemTemplate>
  160. </ItemsControl>
  161. </suki:GroupBox>
  162. </suki:GlassCard>
  163. </Flyout>
  164. </Button.Flyout>
  165. </Button>
  166. </StackPanel>
  167. <StackPanel
  168. Margin="80,60"
  169. HorizontalAlignment="Left"
  170. VerticalAlignment="Top"
  171. IsHitTestVisible="False"
  172. Orientation="Horizontal">
  173. <Border
  174. HorizontalAlignment="Left"
  175. VerticalAlignment="Top"
  176. Background="#1FAAAAAA"
  177. CornerRadius="6"
  178. IsHitTestVisible="False"
  179. IsVisible="{Binding StatisticsVisibily}">
  180. <StackPanel Margin="10">
  181. <Grid Height="20" ColumnDefinitions="80,80,80,80,80">
  182. <TextBlock
  183. HorizontalAlignment="Center"
  184. VerticalAlignment="Center"
  185. Text="{DynamicResource ChannelName}" />
  186. <TextBlock
  187. Grid.Column="1"
  188. HorizontalAlignment="Center"
  189. VerticalAlignment="Center"
  190. Text="{DynamicResource Max}" />
  191. <TextBlock
  192. Grid.Column="2"
  193. HorizontalAlignment="Center"
  194. VerticalAlignment="Center"
  195. Text="{DynamicResource Min}" />
  196. <TextBlock
  197. Grid.Column="3"
  198. HorizontalAlignment="Center"
  199. VerticalAlignment="Center"
  200. Text="{DynamicResource Rms}" />
  201. <TextBlock
  202. Grid.Column="4"
  203. HorizontalAlignment="Center"
  204. VerticalAlignment="Center"
  205. Text="{DynamicResource Avg}" />
  206. </Grid>
  207. <ItemsControl ItemsSource="{Binding Statistics}">
  208. <ItemsControl.ItemTemplate>
  209. <DataTemplate>
  210. <Grid Height="20" ColumnDefinitions="80,80,80,80,80">
  211. <TextBlock
  212. HorizontalAlignment="Center"
  213. VerticalAlignment="Center"
  214. Text="{local:ResourceBinding Name}" />
  215. <TextBlock
  216. Grid.Column="1"
  217. HorizontalAlignment="Center"
  218. VerticalAlignment="Center"
  219. Text="{Binding Max, StringFormat='{}{0:F3}'}" />
  220. <TextBlock
  221. Grid.Column="2"
  222. HorizontalAlignment="Center"
  223. VerticalAlignment="Center"
  224. Text="{Binding Min, StringFormat='{}{0:F3}'}" />
  225. <TextBlock
  226. Grid.Column="3"
  227. HorizontalAlignment="Center"
  228. VerticalAlignment="Center"
  229. Text="{Binding RMS, StringFormat='{}{0:F3}'}" />
  230. <TextBlock
  231. Grid.Column="4"
  232. HorizontalAlignment="Center"
  233. VerticalAlignment="Center"
  234. Text="{Binding Average, StringFormat='{}{0:F3}'}" />
  235. </Grid>
  236. </DataTemplate>
  237. </ItemsControl.ItemTemplate>
  238. </ItemsControl>
  239. </StackPanel>
  240. </Border>
  241. <Border
  242. Margin="10,0,0,0"
  243. HorizontalAlignment="Left"
  244. VerticalAlignment="Top"
  245. Background="#1FAAAAAA"
  246. CornerRadius="6"
  247. IsHitTestVisible="False">
  248. <Border.IsVisible>
  249. <MultiBinding Converter="{StaticResource MutliBoolConverter}">
  250. <Binding Path="THDVisibily" />
  251. <Binding Path="THDEnabled" />
  252. </MultiBinding>
  253. </Border.IsVisible>
  254. <StackPanel Margin="10">
  255. <StackPanel Orientation="Horizontal">
  256. <TextBlock Text="{local:ResourceBinding THDTitle}" />
  257. <TextBlock Text="THD" />
  258. </StackPanel>
  259. <TextBlock
  260. HorizontalAlignment="Center"
  261. VerticalAlignment="Center"
  262. Text="{Binding THD, StringFormat={}{0:P2}}" />
  263. </StackPanel>
  264. </Border>
  265. </StackPanel>
  266. </Grid>
  267. </UserControl>