ProcessHistoryView.xaml 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. <UserControl x:Class="MECF.Framework.UI.Client.CenterViews.DataLogs.ProcessHistory.ProcessHistoryView"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  5. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  6. xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity"
  7. xmlns:sciChart="http://schemas.abtsoftware.co.uk/scichart"
  8. xmlns:xctk="http://schemas.xceed.com/wpf/xaml/toolkit"
  9. xmlns:control="clr-namespace:Aitex.Core.UI.Control;assembly=MECF.Framework.UI.Core"
  10. xmlns:converters="clr-namespace:Aitex.Core.UI.Converters;assembly=MECF.Framework.UI.Core"
  11. xmlns:micro="clr-namespace:Caliburn.Micro"
  12. xmlns:controls="clr-namespace:OpenSEMI.Ctrlib.Controls"
  13. mc:Ignorable="d"
  14. d:DesignHeight="450" d:DesignWidth="1800">
  15. <UserControl.Resources>
  16. <converters:LineColorConverter x:Key="colorConverter"/>
  17. <converters:ControlWidthOrHeightConverter x:Key="controlWidthOrHeightConverter"/>
  18. </UserControl.Resources>
  19. <Grid>
  20. <Grid.RowDefinitions>
  21. <RowDefinition ></RowDefinition>
  22. <RowDefinition Height="5" ></RowDefinition>
  23. <RowDefinition Height="200" ></RowDefinition>
  24. </Grid.RowDefinitions>
  25. <Grid x:Name="grid1">
  26. <Grid.RowDefinitions>
  27. <RowDefinition ></RowDefinition>
  28. <RowDefinition Height="Auto" ></RowDefinition>
  29. </Grid.RowDefinitions>
  30. <Grid>
  31. <TabControl>
  32. <TabItem Header="Chart">
  33. <sciChart:SciChartSurface Name="sciChart" RenderableSeries="{Binding SelectedData}"
  34. sciChart:ThemeManager.Theme="ExpressionLight"
  35. Annotations="{Binding Annotations}"
  36. Padding="0,0,0,0"
  37. DebugWhyDoesntSciChartRender="False" BorderBrush="Gray" Focusable="False" IsTabStop="False">
  38. <sciChart:SciChartSurface.Resources>
  39. <!-- This is the style for the control that hosts the Axis Label -->
  40. <Style x:Key="CursorModAxisLabelStyle" TargetType="sciChart:AxisLabelControl">
  41. <Setter Property="Background" Value="#AAFF6600" />
  42. <Setter Property="BorderBrush" Value="#FFFF6600" />
  43. <Setter Property="BorderThickness" Value="1" />
  44. <Setter Property="Foreground" Value="White" />
  45. <Setter Property="FontSize" Value="25" />
  46. </Style>
  47. <Style x:Key="CursorTooltipStyle" TargetType="sciChart:CursorLabelControl">
  48. <Setter Property="Template">
  49. <Setter.Value>
  50. <ControlTemplate TargetType="sciChart:CursorLabelControl">
  51. <Border Background="#AAFF6600"
  52. BorderBrush="#FFFF6600"
  53. BorderThickness="2"
  54. Opacity="0.7"
  55. Padding="2.5">
  56. <!--<ItemsControl ItemsSource="{Binding DataContext.SeriesData.SeriesInfo, RelativeSource={RelativeSource TemplatedParent}}">
  57. <ItemsControl.ItemTemplate>
  58. <DataTemplate DataType="s:SeriesInfo">
  59. <ContentControl Content="{Binding}" ContentTemplate="{Binding Path=RenderableSeries.(s:CursorModifier.TooltipTemplate)}" />
  60. </DataTemplate>
  61. </ItemsControl.ItemTemplate>
  62. </ItemsControl>-->
  63. </Border>
  64. </ControlTemplate>
  65. </Setter.Value>
  66. </Setter>
  67. </Style>
  68. </sciChart:SciChartSurface.Resources>
  69. <sciChart:SciChartSurface.XAxis>
  70. <sciChart:DateTimeAxis DrawMinorTicks="True"
  71. DrawMinorGridLines="True"
  72. sciChart:CursorModifier.AxisLabelContainerStyle="{StaticResource CursorModAxisLabelStyle}"
  73. Margin="0,0,0,0"
  74. SubDayTextFormatting="MM/dd HH:mm:ss"
  75. TitleFontSize="10"
  76. AutoRange="{Binding AutoRangeX}"
  77. VisibleRange="{Binding TimeRange, Mode=TwoWay}"
  78. TextFormatting="yyyy/MM/dd HH:mm:ss"
  79. Id="DefaultAxisId"/>
  80. </sciChart:SciChartSurface.XAxis>
  81. <!-- Create a Y Axis -->
  82. <sciChart:SciChartSurface.YAxis>
  83. <sciChart:NumericAxis DrawMinorTicks="True"
  84. DrawMinorGridLines="True"
  85. AxisAlignment="Right"
  86. AutoRange="{Binding AutoRangeY}"
  87. VisibleRange="{Binding ValueRange, Mode=TwoWay}"
  88. Id="DefaultAxisId">
  89. <sciChart:NumericAxis.GrowBy>
  90. <sciChart:DoubleRange Min="0.1" Max="0.1"/>
  91. </sciChart:NumericAxis.GrowBy>
  92. </sciChart:NumericAxis>
  93. </sciChart:SciChartSurface.YAxis>
  94. <sciChart:SciChartSurface.ChartModifier>
  95. <sciChart:ModifierGroup ExecuteOn="MouseDoubleClick">
  96. <sciChart:RubberBandXyZoomModifier x:Name="rubberBandZoomModifier" IsEnabled="True"
  97. IsXAxisOnly="False"
  98. ZoomExtentsY="False"
  99. IsAnimated="True" ExecuteOn="MouseLeftButton" ReceiveHandledEvents="True" />
  100. <sciChart:SeriesSelectionModifier ExecuteOn="MouseLeftButton" ReceiveHandledEvents="True">
  101. <sciChart:SeriesSelectionModifier.SelectedSeriesStyle>
  102. <Style TargetType="sciChart:BaseRenderableSeries">
  103. <Setter Property="Stroke" Value="Red"/>
  104. <Setter Property="StrokeThickness" Value="3"/>
  105. <Setter Property="PointMarkerTemplate">
  106. <Setter.Value>
  107. <ControlTemplate>
  108. <sciChart:EllipsePointMarker Width="7" Height="7" Fill="#FF00DC" Stroke="White"/>
  109. </ControlTemplate>
  110. </Setter.Value>
  111. </Setter>
  112. </Style>
  113. </sciChart:SeriesSelectionModifier.SelectedSeriesStyle>
  114. </sciChart:SeriesSelectionModifier>
  115. <sciChart:ZoomExtentsModifier x:Name="zoomExtentsModifier" XyDirection="XYDirection" ReceiveHandledEvents="True" ExecuteOn="MouseDoubleClick"/>
  116. <sciChart:CursorModifier IsEnabled="True" ShowTooltipOn="MouseOver"
  117. ShowAxisLabels="True" SourceMode="AllSeries"
  118. ShowTooltip="False" />
  119. <!--自由平移-->
  120. <sciChart:ZoomPanModifier x:Name="zoomPanModifier" ReceiveHandledEvents="True" IsEnabled="True" ClipModeX="None" XyDirection="XYDirection" ExecuteOn="MouseRightButton" ZoomExtentsY="False" />
  121. <sciChart:LegendModifier ShowLegend="False" Orientation="Horizontal" Margin="10" HorizontalAlignment="Right"
  122. LegendPlacement="Inside" GetLegendDataFor="AllSeries"
  123. ShowVisibilityCheckboxes="False"/>
  124. <sciChart:RolloverModifier x:Name="rolloverModifier"
  125. UseInterpolation="False" FontSize="9" IsEnabled="True"
  126. DrawVerticalLine="False" FontFamily="Arial,SimSun"
  127. SnapsToDevicePixels="False"
  128. ShowAxisLabels="False" />
  129. <sciChart:MouseWheelZoomModifier x:Name="mouseWheelZoomModifier" XyDirection="XDirection"/>
  130. </sciChart:ModifierGroup>
  131. </sciChart:SciChartSurface.ChartModifier>
  132. </sciChart:SciChartSurface>
  133. </TabItem>
  134. <TabItem Header="Table Gormat">
  135. <ScrollViewer Grid.Row="1" HorizontalScrollBarVisibility="Auto" VerticalScrollBarVisibility="Auto">
  136. <DataGrid Grid.Row="1" Margin="10,5,0,5"
  137. Width="{Binding ElementName=grid1,Path=ActualWidth,Converter={StaticResource controlWidthOrHeightConverter}}"
  138. ScrollViewer.CanContentScroll="True"
  139. ScrollViewer.VerticalScrollBarVisibility="Auto"
  140. ScrollViewer.HorizontalScrollBarVisibility="Auto"
  141. HorizontalAlignment="Left"
  142. AutoGenerateColumns="False" Name="dataGrid1"
  143. CanUserAddRows="False"
  144. FrozenColumnCount="1"
  145. CanUserSortColumns="False"
  146. FontSize="14">
  147. <DataGrid.ColumnHeaderStyle>
  148. <Style>
  149. <Setter Property="Block.Foreground" Value="Black"/>
  150. </Style>
  151. </DataGrid.ColumnHeaderStyle>
  152. </DataGrid>
  153. </ScrollViewer>
  154. </TabItem>
  155. </TabControl>
  156. </Grid>
  157. <Button Content="Select Data" Grid.Row="1" Width="100" Height="30" HorizontalAlignment="Left" Margin="0,5" IsEnabled="{Binding IsPermission}">
  158. <i:Interaction.Triggers>
  159. <i:EventTrigger EventName="Click">
  160. <micro:ActionMessage MethodName="SelectData">
  161. </micro:ActionMessage>
  162. </i:EventTrigger>
  163. </i:Interaction.Triggers>
  164. </Button>
  165. </Grid>
  166. <GridSplitter Grid.Row="1" Background="LightBlue" HorizontalAlignment="Stretch" VerticalAlignment="Center" Height="5" Margin="0">
  167. </GridSplitter>
  168. <DataGrid Grid.Row="2" Margin="5,0,0,0"
  169. AlternationCount="2" ColumnHeaderHeight="30" IsEnabled="{Binding IsPermission}"
  170. ItemsSource="{Binding SelectedData}" AutoGenerateColumns="False"
  171. CanUserAddRows="False" CanUserResizeRows="False" CanUserResizeColumns="True" FontFamily="Arial" FontSize="14">
  172. <DataGrid.Columns>
  173. <DataGridTemplateColumn>
  174. <DataGridTemplateColumn.HeaderTemplate >
  175. <DataTemplate>
  176. <StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Center">
  177. <!--<CheckBox Foreground="{DynamicResource FG_White}" VerticalAlignment="Center">
  178. <i:Interaction.Triggers>
  179. <i:EventTrigger EventName="Click">
  180. <cal:ActionMessage MethodName="VisibleCheckAll">
  181. </cal:ActionMessage>
  182. </i:EventTrigger>
  183. </i:Interaction.Triggers>
  184. </CheckBox>-->
  185. <TextBlock Text="Visible" VerticalAlignment="Bottom" Margin="3,0,0,0"/>
  186. </StackPanel>
  187. </DataTemplate>
  188. </DataGridTemplateColumn.HeaderTemplate>
  189. <DataGridTemplateColumn.CellTemplate>
  190. <DataTemplate>
  191. <CheckBox IsChecked="{Binding IsVisible, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" >
  192. <!--<i:Interaction.Triggers>
  193. <i:EventTrigger EventName="Click">
  194. <cal:ActionMessage MethodName="VisibleCheck">
  195. <cal:Parameter Value="{Binding }"/>
  196. </cal:ActionMessage>
  197. </i:EventTrigger>
  198. </i:Interaction.Triggers>-->
  199. </CheckBox>
  200. </DataTemplate>
  201. </DataGridTemplateColumn.CellTemplate>
  202. </DataGridTemplateColumn>
  203. <DataGridTemplateColumn Header="Source" MinWidth="200">
  204. <DataGridTemplateColumn.CellTemplate>
  205. <DataTemplate>
  206. <TextBlock Text="{Binding DataSource}" Margin="5,0" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  207. </DataTemplate>
  208. </DataGridTemplateColumn.CellTemplate>
  209. </DataGridTemplateColumn>
  210. <DataGridTemplateColumn Header="Name" MinWidth="150">
  211. <DataGridTemplateColumn.CellTemplate>
  212. <DataTemplate>
  213. <TextBlock Text="{Binding DataName}" Margin="5,0" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  214. </DataTemplate>
  215. </DataGridTemplateColumn.CellTemplate>
  216. </DataGridTemplateColumn>
  217. <DataGridTemplateColumn Header="Color" MinWidth="100" >
  218. <DataGridTemplateColumn.CellTemplate>
  219. <DataTemplate>
  220. <Button Style="{DynamicResource Color_Button}" HorizontalAlignment="Stretch" Background="{Binding Stroke, Converter={StaticResource colorConverter}}" Width="50">
  221. <i:Interaction.Triggers>
  222. <i:EventTrigger EventName="Click">
  223. <micro:ActionMessage MethodName="SelectColor">
  224. <micro:Parameter Value="{Binding}" ></micro:Parameter>
  225. </micro:ActionMessage>
  226. </i:EventTrigger>
  227. </i:Interaction.Triggers>
  228. </Button>
  229. </DataTemplate>
  230. </DataGridTemplateColumn.CellTemplate>
  231. </DataGridTemplateColumn>
  232. <DataGridTemplateColumn Header="Factor" MinWidth="100">
  233. <DataGridTemplateColumn.CellTemplate>
  234. <DataTemplate>
  235. <controls:TextBoxEx AllowBackgroundChange="False" Text="{Binding DataFactor, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="80" Margin="5,0" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  236. <!--<i:Interaction.Triggers>
  237. <i:EventTrigger EventName="LostFocus">
  238. <cal:ActionMessage MethodName="FactorLostFocus">
  239. <cal:Parameter Value="{Binding}" />
  240. </cal:ActionMessage>
  241. </i:EventTrigger>
  242. <i:EventTrigger EventName="KeyDown">
  243. <cal:ActionMessage MethodName="FactorKeyDown">
  244. <cal:Parameter Value="$eventargs" />
  245. <cal:Parameter Value="{Binding}" />
  246. </cal:ActionMessage>
  247. </i:EventTrigger>
  248. </i:Interaction.Triggers>-->
  249. </DataTemplate>
  250. </DataGridTemplateColumn.CellTemplate>
  251. </DataGridTemplateColumn>
  252. <DataGridTemplateColumn Header="Offset" MinWidth="100">
  253. <DataGridTemplateColumn.CellTemplate>
  254. <DataTemplate>
  255. <controls:TextBoxEx AllowBackgroundChange="False" Text="{Binding DataOffset, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="80" Margin="5,0" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" >
  256. <!--<i:Interaction.Triggers>
  257. <i:EventTrigger EventName="LostFocus">
  258. <cal:ActionMessage MethodName="OffsetLostFocus">
  259. <cal:Parameter Value="{Binding}" />
  260. </cal:ActionMessage>
  261. </i:EventTrigger>
  262. <i:EventTrigger EventName="KeyDown">
  263. <cal:ActionMessage MethodName="OffsetKeyDown">
  264. <cal:Parameter Value="$eventargs" />
  265. <cal:Parameter Value="{Binding}" />
  266. </cal:ActionMessage>
  267. </i:EventTrigger>
  268. </i:Interaction.Triggers>-->
  269. </controls:TextBoxEx>
  270. </DataTemplate>
  271. </DataGridTemplateColumn.CellTemplate>
  272. </DataGridTemplateColumn>
  273. <DataGridTemplateColumn Header="Width" MinWidth="60">
  274. <DataGridTemplateColumn.CellTemplate>
  275. <DataTemplate>
  276. <controls:TextBoxEx AllowBackgroundChange="False" Text="{Binding LineThickness, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" Width="80" Margin="5,0" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" >
  277. <!--<i:Interaction.Triggers>
  278. <i:EventTrigger EventName="LostFocus">
  279. <cal:ActionMessage MethodName="WidthLostFocus">
  280. <cal:Parameter Value="{Binding}" />
  281. </cal:ActionMessage>
  282. </i:EventTrigger>
  283. <i:EventTrigger EventName="KeyDown">
  284. <cal:ActionMessage MethodName="WidthKeyDown">
  285. <cal:Parameter Value="$eventargs" />
  286. <cal:Parameter Value="{Binding}" />
  287. </cal:ActionMessage>
  288. </i:EventTrigger>
  289. </i:Interaction.Triggers>-->
  290. </controls:TextBoxEx>
  291. </DataTemplate>
  292. </DataGridTemplateColumn.CellTemplate>
  293. </DataGridTemplateColumn>
  294. <DataGridTemplateColumn Width="120">
  295. <DataGridTemplateColumn.HeaderTemplate >
  296. <DataTemplate>
  297. <Button Content="Export All" Width="85" Height="25">
  298. <i:Interaction.Triggers>
  299. <i:EventTrigger EventName="Click">
  300. <micro:ActionMessage MethodName="ExportAll">
  301. </micro:ActionMessage>
  302. </i:EventTrigger>
  303. </i:Interaction.Triggers>
  304. </Button>
  305. </DataTemplate>
  306. </DataGridTemplateColumn.HeaderTemplate>
  307. <DataGridTemplateColumn.CellTemplate>
  308. <DataTemplate>
  309. <Button Content="Export" Width="65" Height="25">
  310. <i:Interaction.Triggers>
  311. <i:EventTrigger EventName="Click">
  312. <micro:ActionMessage MethodName="Export">
  313. <micro:Parameter Value="{Binding }"/>
  314. </micro:ActionMessage>
  315. </i:EventTrigger>
  316. </i:Interaction.Triggers>
  317. </Button>
  318. </DataTemplate>
  319. </DataGridTemplateColumn.CellTemplate>
  320. </DataGridTemplateColumn>
  321. <DataGridTemplateColumn Width="120">
  322. <DataGridTemplateColumn.HeaderTemplate >
  323. <DataTemplate>
  324. <Button Content="Delete All" Width="85" Height="25">
  325. <i:Interaction.Triggers>
  326. <i:EventTrigger EventName="Click">
  327. <micro:ActionMessage MethodName="DeleteAll">
  328. </micro:ActionMessage>
  329. </i:EventTrigger>
  330. </i:Interaction.Triggers>
  331. </Button>
  332. </DataTemplate>
  333. </DataGridTemplateColumn.HeaderTemplate>
  334. <DataGridTemplateColumn.CellTemplate>
  335. <DataTemplate>
  336. <Button Content="Delete" Width="65" Height="25">
  337. <i:Interaction.Triggers>
  338. <i:EventTrigger EventName="Click">
  339. <micro:ActionMessage MethodName="Delete">
  340. <micro:Parameter Value="{Binding }"/>
  341. </micro:ActionMessage>
  342. </i:EventTrigger>
  343. </i:Interaction.Triggers>
  344. </Button>
  345. </DataTemplate>
  346. </DataGridTemplateColumn.CellTemplate>
  347. </DataGridTemplateColumn>
  348. </DataGrid.Columns>
  349. </DataGrid>
  350. </Grid>
  351. </UserControl>