DataHistoryView.xaml 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <UserControl x:Class="CyberX8_MainPages.Views.DataHistoryView"
  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:local="clr-namespace:CyberX8_MainPages.Views"
  7. mc:Ignorable="d"
  8. xmlns:wfi ="clr-namespace:System.Windows.Forms.Integration;assembly=WindowsFormsIntegration"
  9. xmlns:wf ="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
  10. xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
  11. xmlns:prism="http://prismlibrary.com/"
  12. prism:ViewModelLocator.AutoWireViewModel="True"
  13. xmlns:ctrls="clr-namespace:CyberX8_Themes.UserControls;assembly=CyberX8_Themes"
  14. d:DesignHeight="450" d:DesignWidth="800" x:Name="dataHistoryView">
  15. <i:Interaction.Triggers>
  16. <i:EventTrigger EventName="Loaded">
  17. <i:InvokeCommandAction Command="{Binding LoadCommand}" CommandParameter="{Binding ElementName=dataHistoryView}"/>
  18. </i:EventTrigger>
  19. <i:EventTrigger EventName="Unloaded">
  20. <i:InvokeCommandAction Command="{Binding UnLoadCommand}"/>
  21. </i:EventTrigger>
  22. </i:Interaction.Triggers>
  23. <Grid>
  24. <Grid.ColumnDefinitions>
  25. <ColumnDefinition Width="auto"/>
  26. <ColumnDefinition />
  27. </Grid.ColumnDefinitions>
  28. <Expander ExpandDirection="Left">
  29. <StackPanel>
  30. <StackPanel>
  31. <TextBlock Text="Start Time:" Width="70" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" Margin="5,0,0,0"/>
  32. <wfi:WindowsFormsHost Margin="5,0,0,0" FontSize="14" FontFamily="Arial" Width="170" Height="40" HorizontalAlignment="Left">
  33. <wf:DateTimePicker x:Name="wfTimeFrom" Value="2011-8-1" CustomFormat="yyyy/MM/dd HH:mm:ss" Format="Custom"></wf:DateTimePicker>
  34. </wfi:WindowsFormsHost>
  35. <TextBlock Text="End Time:" Width="70" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" Margin="5,0,0,0"/>
  36. <wfi:WindowsFormsHost Margin="5,0,0,0" FontSize="14" FontFamily="Arial" Width="170" Height="22" HorizontalAlignment="Left">
  37. <wf:DateTimePicker x:Name="wfTimeTo" Value="2013-8-1" CustomFormat="yyyy/MM/dd HH:mm:ss" Format="Custom"></wf:DateTimePicker>
  38. </wfi:WindowsFormsHost>
  39. <StackPanel Orientation="Horizontal">
  40. <Button Content="Search" Command="{Binding StartCommand}" Width="80" Height="20" HorizontalAlignment="Left" Margin="5,10,0,0" IsEnabled="{Binding ElementName=TimeDataCheckBox,Path=IsChecked,Converter={StaticResource BoolToBool}}"/>
  41. <Button Content="Clear" Command="{Binding ClearCommand}" Width="80" Height="20" HorizontalAlignment="Left" Margin="5,10,0,0"/>
  42. </StackPanel>
  43. </StackPanel>
  44. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Content}" Padding="5,1">
  45. <TreeView x:Name="ParameterTreeView" ItemsSource="{Binding ParameterNodes}" Canvas.Top="100" Height="450" VirtualizingStackPanel.IsVirtualizing="True" VirtualizingStackPanel.VirtualizationMode="Recycling">
  46. <TreeView.ItemTemplate>
  47. <HierarchicalDataTemplate ItemsSource="{Binding ChildNodes}">
  48. <StackPanel Orientation="Horizontal">
  49. <CheckBox IsChecked="{Binding Selected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" >
  50. <i:Interaction.Triggers>
  51. <i:EventTrigger EventName="Click">
  52. <i:InvokeCommandAction Command="{Binding DataContext.ParameterCheckCommand, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=TreeView}}" CommandParameter="{Binding }"/>
  53. </i:EventTrigger>
  54. </i:Interaction.Triggers>
  55. </CheckBox>
  56. <TextBlock Text="{Binding Name}" />
  57. </StackPanel>
  58. </HierarchicalDataTemplate>
  59. </TreeView.ItemTemplate>
  60. </TreeView>
  61. </Border>
  62. <ListBox ItemsSource="{Binding KeyDataObservableCollection}" Margin="20,0,0,0" FontSize="20" Height="200" VerticalAlignment="Bottom">
  63. <ListBox.ItemTemplate>
  64. <DataTemplate>
  65. <StackPanel Orientation="Horizontal">
  66. <TextBlock Text="{Binding Key}" Width="300"/>
  67. <Button Width="42" FontSize="11" Height="20" Background="{Binding Color,UpdateSourceTrigger=PropertyChanged}" Click="OnChangeLineColor" Tag="{Binding UniqueId}"/>
  68. </StackPanel>
  69. </DataTemplate>
  70. </ListBox.ItemTemplate>
  71. </ListBox>
  72. <!--<DataGrid Style="{x:Null}" Grid.Row="1" x:Name="dataGrid_DataList" AutoGenerateColumns="False" Background="#FFD6D6D6"
  73. ItemsSource="{Binding KeyDataObservableCollection, Mode=TwoWay}" SelectionUnit="FullRow" CanUserResizeRows="False" CanUserSortColumns="False" CanUserResizeColumns="False" CanUserReorderColumns="False" CanUserDeleteRows="True" CanUserAddRows="False" Focusable="False" HorizontalGridLinesBrush="Gray" VerticalGridLinesBrush="Gray" HeadersVisibility="Column" Margin="0,5,0,0" Height="200">
  74. <DataGrid.Columns>
  75. <DataGridTextColumn Width="Auto" Binding="{Binding Key,Mode=TwoWay}" CanUserSort="False" IsReadOnly="True">
  76. <DataGridTextColumn.CellStyle>
  77. <Style TargetType="DataGridCell">
  78. <Setter Property="ToolTip" Value="{Binding Key}" />
  79. </Style>
  80. </DataGridTextColumn.CellStyle>
  81. <DataGridTextColumn.HeaderTemplate >
  82. <DataTemplate>
  83. <TextBlock Text="Name"/>
  84. </DataTemplate>
  85. </DataGridTextColumn.HeaderTemplate>
  86. </DataGridTextColumn>
  87. <DataGridTemplateColumn Width="Auto" CanUserSort="True">
  88. <DataGridTemplateColumn.CellTemplate>
  89. <DataTemplate>
  90. <Button Focusable="False" Width="42" FontSize="11" Height="20" Tag="{Binding UniqueId}" Background="{Binding Color,UpdateSourceTrigger=PropertyChanged}" Click="OnChangeLineColor"/>
  91. </DataTemplate>
  92. </DataGridTemplateColumn.CellTemplate>
  93. <DataGridTemplateColumn.HeaderTemplate >
  94. <DataTemplate>
  95. <TextBlock Text="Color" />
  96. </DataTemplate>
  97. </DataGridTemplateColumn.HeaderTemplate>
  98. </DataGridTemplateColumn>
  99. </DataGrid.Columns>
  100. </DataGrid>-->
  101. </StackPanel>
  102. </Expander>
  103. <Grid Grid.Column="1">
  104. <Grid.RowDefinitions>
  105. <RowDefinition Height="60"/>
  106. <RowDefinition/>
  107. </Grid.RowDefinitions>
  108. <!--<Border BorderThickness="1" BorderBrush="Black" Margin="50,5,20,5">-->
  109. <StackPanel Orientation="Horizontal">
  110. <CheckBox HorizontalAlignment="Center" FontSize="20" Padding="3,-5,0,0" Margin="100,25,0,0" Content="AutoX Zoom" x:Name="AutoXCheckBox"/>
  111. <CheckBox HorizontalAlignment="Center" FontSize="20" Padding="3,-5,0,0" Margin="100,25,0,0" Content="AutoY Zoom" x:Name="AutoYCheckBox"/>
  112. <CheckBox HorizontalAlignment="Center" FontSize="20" Padding="3,-5,0,0" Margin="100,25,0,0" Content="查看实时数据" x:Name="TimeDataCheckBox">
  113. <i:Interaction.Triggers>
  114. <i:EventTrigger EventName="Checked">
  115. <i:InvokeCommandAction Command="{Binding StartRealTimeCommand}" CommandParameter="{Binding ElementName=TimeDataCheckBox}"/>
  116. </i:EventTrigger>
  117. <i:EventTrigger EventName="Unchecked">
  118. <i:InvokeCommandAction Command="{Binding StopRealTimeCommand}"/>
  119. </i:EventTrigger>
  120. </i:Interaction.Triggers>
  121. </CheckBox>
  122. </StackPanel>
  123. <!--</Border>-->
  124. <ctrls:DrawGraphicsControl x:Name="MyDrawGraphicsControl" Grid.Row="1" IsHorizontalNavigationEnabled="{Binding ElementName=AutoXCheckBox,Path=IsChecked}" IsVerticalNavigationEnabled="{Binding ElementName=AutoYCheckBox,Path=IsChecked}" WavePlotOriginX="{Binding ElementName=MinXTextBox,Path=Text}" WavePlotOriginWidth="{Binding ElementName=MaxXTextBox,Path=Text}" WavePlotOriginY="{Binding ElementName=MinYTextBox,Path=Text}" WavePlotOriginHeight="{Binding ElementName=MaxYTextBox,Path=Text,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" IsHorizontalDateTimeAxis="True" Background="{DynamicResource DataGrid_BG_First}" Margin="5"/>
  125. </Grid>
  126. </Grid>
  127. </UserControl>