ProcessDetailView.xaml 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. <UserControl x:Class="MECF.Framework.UI.Client.CenterViews.DataLogs.ProcessHistory.ProcessDetailView"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:s="http://schemas.abtsoftware.co.uk/scichart"
  4. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  5. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  6. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  7. xmlns:converters="clr-namespace:Aitex.Core.UI.Converters;assembly=MECF.Framework.UI.Core"
  8. xmlns:micro="clr-namespace:Caliburn.Micro"
  9. xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
  10. mc:Ignorable="d" x:Name="userCotrol"
  11. Height="800" Width="1200">
  12. <UserControl.Resources>
  13. <converters:LineColorConverter x:Key="colorConverter"/>
  14. </UserControl.Resources>
  15. <StackPanel Orientation="Vertical" Height="{Binding ElementName=userCotrol, Path=ActualHeight}">
  16. <StackPanel Height="640" Orientation="Horizontal">
  17. <Border Margin="1" Width="250" BorderBrush="{DynamicResource Tab_BD}" BorderThickness="1" SnapsToDevicePixels="True" Background="{DynamicResource Tab_BG}" Padding="2">
  18. <TreeView x:Name="ParameterTreeView" ItemsSource="{Binding ParameterNodes}">
  19. <TreeView.ItemTemplate>
  20. <HierarchicalDataTemplate ItemsSource="{Binding ChildNodes}">
  21. <StackPanel Orientation="Horizontal">
  22. <CheckBox Visibility="{Binding IsVisibilityParentNode}" IsChecked="{Binding Selected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Margin="0,11,0,0">
  23. <i:Interaction.Triggers>
  24. <i:EventTrigger EventName="Click">
  25. <micro:ActionMessage MethodName="ParameterCheck">
  26. <micro:Parameter Value="{Binding }"/>
  27. </micro:ActionMessage>
  28. </i:EventTrigger>
  29. </i:Interaction.Triggers>
  30. </CheckBox>
  31. <TextBlock Text="{Binding Name}" Height="30" Margin="0,10,0,0"/>
  32. </StackPanel>
  33. </HierarchicalDataTemplate>
  34. </TreeView.ItemTemplate>
  35. </TreeView>
  36. </Border>
  37. <Border Margin="1" Width="945" BorderBrush="{DynamicResource Tab_BD}" BorderThickness="1" SnapsToDevicePixels="True" Background="{DynamicResource Tab_BG}" Padding="2">
  38. <StackPanel Orientation="Vertical">
  39. <s:SciChartSurface x:Name="sciChart" RenderableSeries="{Binding SelectedData}" s:ThemeManager.Theme="ExpressionLight" Annotations="{Binding Annotations}"
  40. Height="600" DebugWhyDoesntSciChartRender="False" BorderBrush="Gray" Focusable="False" IsTabStop="False">
  41. <!-- Create an X Axis -->
  42. <s:SciChartSurface.XAxis>
  43. <s:NumericAxis DrawMinorTicks="False"
  44. DrawMinorGridLines="False"
  45. Margin="0,0,0,0"
  46. TitleFontSize="15"
  47. FontSize="20"
  48. Id="DefaultAxisId" TitleFontWeight="Normal">
  49. </s:NumericAxis>
  50. </s:SciChartSurface.XAxis>
  51. <!-- Create a Y Axis -->
  52. <s:SciChartSurface.YAxis>
  53. <s:NumericAxis DrawMinorTicks="False"
  54. DrawMinorGridLines="False"
  55. AxisAlignment="Right"
  56. MinWidth="50" MaxWidth="50"
  57. HorizontalAlignment="Center"
  58. CursorTextFormatting="0.###"
  59. VisibleRange="{Binding VisibleRangeValue}"
  60. Id="DefaultAxisId" MajorDelta="0.1"
  61. MinorDelta="0.1" DrawMajorBands="False" Focusable="False"
  62. BorderThickness="0" AutoRange="{Binding ChartAutoRange}"
  63. DrawLabels="True" DrawMajorGridLines="True" DrawMajorTicks="False">
  64. <s:NumericAxis.GrowBy>
  65. <s:DoubleRange Min="0.1" Max="0.1"/>
  66. </s:NumericAxis.GrowBy>
  67. </s:NumericAxis>
  68. </s:SciChartSurface.YAxis>
  69. <s:SciChartSurface.ChartModifier>
  70. <s:ModifierGroup >
  71. <s:RubberBandXyZoomModifier x:Name="rubberBandZoomModifier" IsEnabled="True"
  72. IsXAxisOnly="False"
  73. ZoomExtentsY="True"
  74. IsAnimated="True" ExecuteOn="MouseLeftButton" ReceiveHandledEvents="True" />
  75. <s:CursorModifier IsEnabled="True" ShowTooltipOn="MouseOver" ShowAxisLabels="True"
  76. SourceMode="AllSeries" ShowTooltip="False" />
  77. <s:LegendModifier ShowLegend="False" GetLegendDataFor="AllSeries" x:Name="legendModifier"/>
  78. <s:ZoomExtentsModifier x:Name="zoomExtentsModifier" XyDirection="XYDirection" ExecuteOn="MouseDoubleClick"/>
  79. <s:ZoomPanModifier x:Name="zoomPanModifier" IsEnabled="True" ClipModeX="None" XyDirection="XYDirection" ExecuteOn="MouseRightButton" ZoomExtentsY="False" />
  80. <s:RolloverModifier x:Name="rolloverModifier"
  81. UseInterpolation="False" FontSize="9" IsEnabled="True"
  82. DrawVerticalLine="False" FontFamily="Arial,SimSun"
  83. SnapsToDevicePixels="False"
  84. ShowAxisLabels="False" />
  85. <s:MouseWheelZoomModifier x:Name="mouseWheelZoomModifier" XyDirection="XYDirection"/>
  86. </s:ModifierGroup>
  87. </s:SciChartSurface.ChartModifier>
  88. </s:SciChartSurface>
  89. <StackPanel Orientation="Horizontal">
  90. <Button Margin="0,2,0,2" Width="105" Content="Move Left">
  91. <i:Interaction.Triggers>
  92. <i:EventTrigger EventName="Click">
  93. <micro:ActionMessage MethodName="ToLeftClick">
  94. </micro:ActionMessage>
  95. </i:EventTrigger>
  96. </i:Interaction.Triggers>
  97. </Button>
  98. <Button Margin="1,2,0,2" Width="105" Content="Move Right">
  99. <i:Interaction.Triggers>
  100. <i:EventTrigger EventName="Click">
  101. <micro:ActionMessage MethodName="ToRightClick">
  102. </micro:ActionMessage>
  103. </i:EventTrigger>
  104. </i:Interaction.Triggers>
  105. </Button>
  106. <Button Margin="1,2,0,2" Width="105" Content="Move Up">
  107. <i:Interaction.Triggers>
  108. <i:EventTrigger EventName="Click">
  109. <micro:ActionMessage MethodName="ToMoveUpClick">
  110. </micro:ActionMessage>
  111. </i:EventTrigger>
  112. </i:Interaction.Triggers>
  113. </Button>
  114. <Button Margin="1,2,0,2" Width="105" Content="Move Down">
  115. <i:Interaction.Triggers>
  116. <i:EventTrigger EventName="Click">
  117. <micro:ActionMessage MethodName="ToMoveDownClick">
  118. </micro:ActionMessage>
  119. </i:EventTrigger>
  120. </i:Interaction.Triggers>
  121. </Button>
  122. <Button Content="Zoom In" Width="105" Margin="1,2,0,2">
  123. <i:Interaction.Triggers>
  124. <i:EventTrigger EventName="Click">
  125. <micro:ActionMessage MethodName="ZoomInClick">
  126. </micro:ActionMessage>
  127. </i:EventTrigger>
  128. </i:Interaction.Triggers>
  129. </Button>
  130. <Button Content="Zoom Out" Width="105" Margin="1,2,0,2">
  131. <i:Interaction.Triggers>
  132. <i:EventTrigger EventName="Click">
  133. <micro:ActionMessage MethodName="ZoomOutClick">
  134. </micro:ActionMessage>
  135. </i:EventTrigger>
  136. </i:Interaction.Triggers>
  137. </Button>
  138. <Button Content="Select Step" Width="105" Margin="1,2,0,2" Visibility="{Binding IsStepVisiable, Converter={StaticResource bool2VisibilityConverter}}">
  139. <i:Interaction.Triggers>
  140. <i:EventTrigger EventName="Click">
  141. <micro:ActionMessage MethodName="SelectStep"/>
  142. </i:EventTrigger>
  143. </i:Interaction.Triggers>
  144. </Button>
  145. </StackPanel>
  146. </StackPanel>
  147. </Border>
  148. </StackPanel>
  149. <DataGrid Height="158" Margin="1" AlternationCount="2" ColumnHeaderHeight="30"
  150. ItemsSource="{Binding SelectedData}" AutoGenerateColumns="False"
  151. CanUserAddRows="False" CanUserResizeRows="False" CanUserResizeColumns="True" FontFamily="Arial" FontSize="14">
  152. <DataGrid.Columns>
  153. <DataGridTemplateColumn Header="Visible">
  154. <DataGridTemplateColumn.CellTemplate>
  155. <DataTemplate>
  156. <CheckBox IsChecked="{Binding IsVisible, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" VerticalAlignment="Center" HorizontalAlignment="Center">
  157. </CheckBox>
  158. </DataTemplate>
  159. </DataGridTemplateColumn.CellTemplate>
  160. </DataGridTemplateColumn>
  161. <DataGridTemplateColumn Header="Name" Width="150">
  162. <DataGridTemplateColumn.CellTemplate>
  163. <DataTemplate>
  164. <TextBlock Text="{Binding DataName}" Margin="5,0" Foreground="{DynamicResource FG_Black}" TextWrapping="Wrap" HorizontalAlignment="Left" VerticalAlignment="Center" />
  165. </DataTemplate>
  166. </DataGridTemplateColumn.CellTemplate>
  167. </DataGridTemplateColumn>
  168. <DataGridTemplateColumn Header="Source" Width="300">
  169. <DataGridTemplateColumn.CellTemplate>
  170. <DataTemplate>
  171. <TextBlock Text="{Binding DataSource}" Margin="5,0" Foreground="{DynamicResource FG_Black}" TextWrapping="Wrap" HorizontalAlignment="Left" VerticalAlignment="Center" />
  172. </DataTemplate>
  173. </DataGridTemplateColumn.CellTemplate>
  174. </DataGridTemplateColumn>
  175. <DataGridTemplateColumn Header="Color" Width="60" >
  176. <DataGridTemplateColumn.CellTemplate>
  177. <DataTemplate>
  178. <Button Style="{DynamicResource Color_Button}" HorizontalAlignment="Stretch" Background="{Binding Stroke, Converter={StaticResource colorConverter}}" Width="50" Height="20">
  179. <i:Interaction.Triggers>
  180. <i:EventTrigger EventName="Click">
  181. <micro:ActionMessage MethodName="SelectColor">
  182. <micro:Parameter Value="{Binding}" ></micro:Parameter>
  183. </micro:ActionMessage>
  184. </i:EventTrigger>
  185. </i:Interaction.Triggers>
  186. </Button>
  187. </DataTemplate>
  188. </DataGridTemplateColumn.CellTemplate>
  189. </DataGridTemplateColumn>
  190. <DataGridTemplateColumn Header="Factor" Width="60">
  191. <DataGridTemplateColumn.CellTemplate>
  192. <DataTemplate>
  193. <TextBox Tag="Number" Text="{Binding DataFactor,Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="50" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBox>
  194. </DataTemplate>
  195. </DataGridTemplateColumn.CellTemplate>
  196. </DataGridTemplateColumn>
  197. <DataGridTemplateColumn Header="Offset" Width="60">
  198. <DataGridTemplateColumn.CellTemplate>
  199. <DataTemplate>
  200. <TextBox Tag="Number" Text="{Binding DataOffset,Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="50" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBox>
  201. </DataTemplate>
  202. </DataGridTemplateColumn.CellTemplate>
  203. </DataGridTemplateColumn>
  204. <DataGridTemplateColumn Header="Width" Width="60">
  205. <DataGridTemplateColumn.CellTemplate>
  206. <DataTemplate>
  207. <TextBox Tag="Number" Text="{Binding LineThickness,Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="50" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBox>
  208. </DataTemplate>
  209. </DataGridTemplateColumn.CellTemplate>
  210. </DataGridTemplateColumn>
  211. <DataGridTemplateColumn Header="Min." Width="60">
  212. <DataGridTemplateColumn.CellTemplate>
  213. <DataTemplate>
  214. <TextBlock Text="{Binding Tag.MinValue}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center" />
  215. </DataTemplate>
  216. </DataGridTemplateColumn.CellTemplate>
  217. </DataGridTemplateColumn>
  218. <DataGridTemplateColumn Header="Max." Width="60">
  219. <DataGridTemplateColumn.CellTemplate>
  220. <DataTemplate>
  221. <TextBlock Text="{Binding Tag.MaxValue}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center" />
  222. </DataTemplate>
  223. </DataGridTemplateColumn.CellTemplate>
  224. </DataGridTemplateColumn>
  225. <DataGridTemplateColumn Header="Ave." Width="60">
  226. <DataGridTemplateColumn.CellTemplate>
  227. <DataTemplate>
  228. <TextBlock Text="{Binding Tag.AverageValue}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center" />
  229. </DataTemplate>
  230. </DataGridTemplateColumn.CellTemplate>
  231. </DataGridTemplateColumn>
  232. <DataGridTemplateColumn Header="3-Sigma" Width="68">
  233. <DataGridTemplateColumn.CellTemplate>
  234. <DataTemplate>
  235. <TextBlock Text="{Binding Tag.Sigma3Value}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Center" VerticalAlignment="Center" />
  236. </DataTemplate>
  237. </DataGridTemplateColumn.CellTemplate>
  238. </DataGridTemplateColumn>
  239. <DataGridTemplateColumn Width="100">
  240. <DataGridTemplateColumn.HeaderTemplate >
  241. <DataTemplate>
  242. <Button Content="Export All" Width="85" Height="25" Padding="0">
  243. <i:Interaction.Triggers>
  244. <i:EventTrigger EventName="Click">
  245. <micro:ActionMessage MethodName="ExportAll">
  246. </micro:ActionMessage>
  247. </i:EventTrigger>
  248. </i:Interaction.Triggers>
  249. </Button>
  250. </DataTemplate>
  251. </DataGridTemplateColumn.HeaderTemplate>
  252. <DataGridTemplateColumn.CellTemplate>
  253. <DataTemplate>
  254. <Button Content="Export" Width="65" Height="25" Padding="0">
  255. <i:Interaction.Triggers>
  256. <i:EventTrigger EventName="Click">
  257. <micro:ActionMessage MethodName="Export">
  258. <micro:Parameter Value="{Binding }"/>
  259. </micro:ActionMessage>
  260. </i:EventTrigger>
  261. </i:Interaction.Triggers>
  262. </Button>
  263. </DataTemplate>
  264. </DataGridTemplateColumn.CellTemplate>
  265. </DataGridTemplateColumn>
  266. <DataGridTemplateColumn Width="100">
  267. <DataGridTemplateColumn.HeaderTemplate >
  268. <DataTemplate>
  269. <Button Content="Delete All" Width="85" Height="25" Padding="0">
  270. <i:Interaction.Triggers>
  271. <i:EventTrigger EventName="Click">
  272. <micro:ActionMessage MethodName="DeleteAll">
  273. </micro:ActionMessage>
  274. </i:EventTrigger>
  275. </i:Interaction.Triggers>
  276. </Button>
  277. </DataTemplate>
  278. </DataGridTemplateColumn.HeaderTemplate>
  279. <DataGridTemplateColumn.CellTemplate>
  280. <DataTemplate>
  281. <Button Content="Delete" Width="65" Height="25" Padding="0">
  282. <i:Interaction.Triggers>
  283. <i:EventTrigger EventName="Click">
  284. <micro:ActionMessage MethodName="Delete">
  285. <micro:Parameter Value="{Binding }"/>
  286. </micro:ActionMessage>
  287. </i:EventTrigger>
  288. </i:Interaction.Triggers>
  289. </Button>
  290. </DataTemplate>
  291. </DataGridTemplateColumn.CellTemplate>
  292. </DataGridTemplateColumn>
  293. </DataGrid.Columns>
  294. </DataGrid>
  295. </StackPanel>
  296. </UserControl>