ProcessHistoryView.xaml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. <UserControl x:Class="Venus_MainPages.Views.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:prism="http://prismlibrary.com/"
  7. xmlns:local="clr-namespace:Venus_MainPages.Views"
  8. xmlns:wfi ="clr-namespace:System.Windows.Forms.Integration;assembly=WindowsFormsIntegration"
  9. xmlns:forms ="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
  10. prism:ViewModelLocator.AutoWireViewModel="True"
  11. xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
  12. xmlns:ctrls="clr-namespace:Venus_Themes.UserControls;assembly=Venus_Themes"
  13. mc:Ignorable="d"
  14. d:DesignHeight="450" d:DesignWidth="1800"
  15. x:Name="processHistoryView">
  16. <i:Interaction.Triggers>
  17. <i:EventTrigger EventName="Loaded">
  18. <i:InvokeCommandAction Command="{Binding LoadCommandPD}" CommandParameter="{Binding ElementName=processHistoryView}"/>
  19. </i:EventTrigger>
  20. </i:Interaction.Triggers>
  21. <UserControl.Resources>
  22. <Style TargetType="{x:Type DataGridColumnHeader}">
  23. <Setter Property="SnapsToDevicePixels" Value="True"/>
  24. <Setter Property="HorizontalContentAlignment" Value="Center"/>
  25. <Setter Property="BorderBrush" Value="{DynamicResource DataGrid_Header_BD}"/>
  26. <Setter Property="BorderThickness" Value="0,0,1,0"/>
  27. <Setter Property="Padding" Value="5,1"/>
  28. <Setter Property="Background" Value="{DynamicResource Table_BG_Title}"/>
  29. <Setter Property="Foreground" Value="{DynamicResource FG_Black}"/>
  30. <Setter Property="FontFamily" Value="Arial"/>
  31. <Setter Property="MinHeight" Value="24"/>
  32. <Setter Property="Template">
  33. <Setter.Value>
  34. <ControlTemplate TargetType="{x:Type DataGridColumnHeader}">
  35. <Border BorderThickness="{TemplateBinding BorderThickness}" BorderBrush="{TemplateBinding BorderBrush}" Background="{TemplateBinding Background}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" Cursor="Hand">
  36. <Grid>
  37. <Path x:Name="Arrow" Visibility="Collapsed" Data="M0,0 L1,0 0.5,1 z" Stretch="Fill" Width="8" Height="4" Fill="{DynamicResource DataGrid_ArrowBG}" Margin="0,2,0,0" HorizontalAlignment="Center" VerticalAlignment="Top" RenderTransformOrigin="0.5,0.4" />
  38. <ContentPresenter Margin="{TemplateBinding Padding}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}">
  39. <ContentPresenter.Effect>
  40. <DropShadowEffect BlurRadius="0" ShadowDepth="1" Direction="315"/>
  41. </ContentPresenter.Effect>
  42. </ContentPresenter>
  43. <Thumb x:Name="PART_RightHeaderGripper" Style="{StaticResource ColumnHeaderGripperStyle}" HorizontalAlignment="Right"/>
  44. </Grid>
  45. </Border>
  46. <ControlTemplate.Triggers>
  47. <Trigger Property="SortDirection" Value="Ascending">
  48. <Setter TargetName="Arrow" Property="Visibility" Value="Visible" />
  49. <Setter TargetName="Arrow" Property="RenderTransform">
  50. <Setter.Value>
  51. <RotateTransform Angle="180" />
  52. </Setter.Value>
  53. </Setter>
  54. <Setter Property="Background" Value="{DynamicResource DataGrid_Header_BG_MouseOver}"/>
  55. </Trigger>
  56. <Trigger Property="SortDirection" Value="Descending">
  57. <Setter TargetName="Arrow" Property="Visibility" Value="Visible" />
  58. <Setter Property="Background" Value="{DynamicResource DataGrid_Header_BG_MouseOver}"/>
  59. </Trigger>
  60. <MultiTrigger>
  61. <MultiTrigger.Conditions>
  62. <Condition Property="IsMouseOver" Value="True" />
  63. <Condition Property="SortDirection" Value="{x:Null}" />
  64. </MultiTrigger.Conditions>
  65. <Setter Property="Background" Value="{DynamicResource DataGrid_Header_BG_MouseOver}"/>
  66. </MultiTrigger>
  67. </ControlTemplate.Triggers>
  68. </ControlTemplate>
  69. </Setter.Value>
  70. </Setter>
  71. </Style>
  72. </UserControl.Resources>
  73. <Grid>
  74. <Grid.RowDefinitions>
  75. <RowDefinition Height="Auto"></RowDefinition>
  76. <RowDefinition Height="2*" ></RowDefinition>
  77. <RowDefinition Height="5" ></RowDefinition>
  78. <RowDefinition Height="4*" ></RowDefinition>
  79. </Grid.RowDefinitions>
  80. <Grid Grid.Row="0" Grid.Column="0">
  81. <Grid.RowDefinitions>
  82. <RowDefinition Height="40"/>
  83. </Grid.RowDefinitions>
  84. <Grid.ColumnDefinitions>
  85. <ColumnDefinition Width="70"/>
  86. <ColumnDefinition Width="*"/>
  87. <ColumnDefinition Width="70"/>
  88. <ColumnDefinition Width="*"/>
  89. <ColumnDefinition Width="70"/>
  90. <ColumnDefinition Width="*"/>
  91. <ColumnDefinition Width="100"/>
  92. </Grid.ColumnDefinitions>
  93. <Border BorderBrush="{DynamicResource Table_BD}" BorderThickness="1" Background="{DynamicResource Table_BG_Title}" Padding="5,1" Height="40">
  94. <TextBlock Text="Start" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBlock>
  95. </Border>
  96. <Border Grid.Column="1" Background="#FFDAE5F1" BorderThickness="0,1,1,1" Padding="5,1">
  97. <wfi:WindowsFormsHost Margin="5,0,0,0" FontSize="14" FontFamily="Arial" Width="170" Height="22" VerticalAlignment="Center">
  98. <forms:DateTimePicker x:Name="wfTimeFrom" Value="2023-5-3" CustomFormat="yyyy/MM/dd HH:mm:ss" Format="Custom"></forms:DateTimePicker>
  99. </wfi:WindowsFormsHost>
  100. <!--<StackPanel Orientation="Horizontal">
  101. <DatePicker SelectedDate="{Binding starttime,UpdateSourceTrigger=PropertyChanged}"></DatePicker>
  102. -->
  103. <!--<TextBlock Text="{Binding starttime,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}" Width="100"/>-->
  104. <!--
  105. </StackPanel>-->
  106. </Border>
  107. <Border Grid.Column="2" BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,1,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  108. <TextBlock Text="End" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBlock>
  109. </Border>
  110. <Border Grid.Column="3" BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,1,1,1" Background="{DynamicResource Table_BG_Content}" Padding="5,1">
  111. <wfi:WindowsFormsHost Margin="5,0,0,0" FontSize="14" FontFamily="Arial" Width="170" Height="22" VerticalAlignment="Center">
  112. <forms:DateTimePicker x:Name="wfTimeTo" Value="2023-5-30" CustomFormat="yyyy/MM/dd HH:mm:ss" Format="Custom"></forms:DateTimePicker>
  113. </wfi:WindowsFormsHost>
  114. <!--<toolkit:DateTimePicker Format="Custom" FontSize="14" Name="dateEnd"
  115. FormatString="yyyy/MM/dd HH:mm:ss"
  116. TimeFormat="Custom"
  117. TimeFormatString="HH:mm:ss"
  118. AutoCloseCalendar="True"
  119. Grid.Row="0" VerticalAlignment="Top"
  120. Value="{Binding Path=EndDateTime, Mode=TwoWay}" Height="30" Width="172" />-->
  121. </Border>
  122. <Border Grid.Row="0" Grid.Column="4" BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,1,1,1" Background="{DynamicResource Table_BG_Title}" Padding="5,1">
  123. <TextBlock Text="Recipe" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBlock>
  124. </Border>
  125. <Border Grid.Row="0" Grid.Column="5" BorderBrush="{DynamicResource Table_BD}" BorderThickness="0,1,1,1" Background="{DynamicResource Table_BG_Content}" Padding="5,1">
  126. <Grid HorizontalAlignment="Center">
  127. <!--<Grid.ColumnDefinitions>
  128. <ColumnDefinition Width="2*" />
  129. <ColumnDefinition Width="2*" />
  130. </Grid.ColumnDefinitions>-->
  131. <!--<TextBox Text="{Binding RecipeName}" Grid.Column="0" ></TextBox>-->
  132. <ComboBox Width="400" ItemsSource="{Binding CheboxRecipes, Mode=TwoWay}" SelectedValue="{Binding RecipeName ,Mode=TwoWay}" DisplayMemberPath="BoxName" SelectedValuePath="BoxName">
  133. </ComboBox>
  134. </Grid>
  135. </Border>
  136. <Button Margin="5,0,0,0" Grid.Column="6" Content="Search" Width="80" Height="30" Command="{Binding SearchRecipeCommand}">
  137. </Button>
  138. </Grid>
  139. <Grid Grid.Row="1">
  140. <Grid.ColumnDefinitions>
  141. <ColumnDefinition Width="543*"/>
  142. <ColumnDefinition Width="Auto"/>
  143. <ColumnDefinition Width="10*"/>
  144. <ColumnDefinition Width="26*"/>
  145. <ColumnDefinition Width="358*"/>
  146. <ColumnDefinition Width="423*"/>
  147. <ColumnDefinition Width="143*"/>
  148. <ColumnDefinition Width="240*"/>
  149. <ColumnDefinition Width="19*"/>
  150. <ColumnDefinition Width="37*"/>
  151. </Grid.ColumnDefinitions>
  152. <Grid.RowDefinitions>
  153. <RowDefinition Height="25"/>
  154. <RowDefinition/>
  155. </Grid.RowDefinitions>
  156. <Button Grid.Row="0" Content="导出列表" FontSize="10" Height="18" Margin="0,5,12,0" x:Name="ButtonExportList" VerticalAlignment="Top" IsEnabled="False" HorizontalAlignment="Right" Width="106" Grid.ColumnSpan="3" Grid.Column="7" Click="buttonLotListExport_Click"/>
  157. <DataGrid Grid.Row="1" ItemsSource="{Binding Recipes}" AutoGenerateColumns="False" CanUserAddRows="False" Name="dataGrid_RecipeList" SelectionChanged="DataGrid_SelectionChanged"
  158. CanUserResizeRows="False" CanUserResizeColumns="True" FontFamily="Arial" Margin="0,5,0,0" Grid.ColumnSpan="10" >
  159. <DataGrid.Columns>
  160. <DataGridTemplateColumn Header="checked" Width="100">
  161. <DataGridTemplateColumn.CellTemplate>
  162. <DataTemplate>
  163. <CheckBox IsChecked="{Binding Selected,Mode=TwoWay}" VerticalAlignment="Center" HorizontalAlignment="Center" />
  164. </DataTemplate>
  165. </DataGridTemplateColumn.CellTemplate>
  166. </DataGridTemplateColumn>
  167. <DataGridTemplateColumn Header="Lot ID" Width="320">
  168. <DataGridTemplateColumn.CellTemplate>
  169. <DataTemplate>
  170. <TextBlock Text="{Binding LotID}" Margin="5,0" FontFamily="Arial" FontSize="14" Background="White" Foreground="White" HorizontalAlignment="Left" VerticalAlignment="Center" />
  171. </DataTemplate>
  172. </DataGridTemplateColumn.CellTemplate>
  173. </DataGridTemplateColumn>
  174. <DataGridTemplateColumn Header="Slot ID" Width="320">
  175. <DataGridTemplateColumn.CellTemplate>
  176. <DataTemplate>
  177. <TextBlock Text="{Binding SlotID}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  178. </DataTemplate>
  179. </DataGridTemplateColumn.CellTemplate>
  180. </DataGridTemplateColumn>
  181. <DataGridTemplateColumn Header="Start" Width="200">
  182. <DataGridTemplateColumn.CellTemplate>
  183. <DataTemplate>
  184. <TextBlock Text="{Binding StartTime}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  185. </DataTemplate>
  186. </DataGridTemplateColumn.CellTemplate>
  187. </DataGridTemplateColumn>
  188. <DataGridTemplateColumn Header="End" Width="200">
  189. <DataGridTemplateColumn.CellTemplate>
  190. <DataTemplate>
  191. <TextBlock Text="{Binding EndTime}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  192. </DataTemplate>
  193. </DataGridTemplateColumn.CellTemplate>
  194. </DataGridTemplateColumn>
  195. <DataGridTemplateColumn Header="Chamber" Width="80">
  196. <DataGridTemplateColumn.CellTemplate>
  197. <DataTemplate>
  198. <TextBlock Text="{Binding Chamber}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  199. </DataTemplate>
  200. </DataGridTemplateColumn.CellTemplate>
  201. </DataGridTemplateColumn>
  202. <!--<DataGridTemplateColumn Header="Wafer ID" Width="320">
  203. <DataGridTemplateColumn.CellTemplate>
  204. <DataTemplate>
  205. <TextBlock Text="{Binding RecipeRunGuid}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  206. </DataTemplate>
  207. </DataGridTemplateColumn.CellTemplate>
  208. </DataGridTemplateColumn>-->
  209. <DataGridTemplateColumn Header="Recipe" Width="300">
  210. <DataGridTemplateColumn.CellTemplate>
  211. <DataTemplate>
  212. <TextBlock Text="{Binding Recipe}" Margin="5,0" FontFamily="Arial" FontSize="20" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  213. </DataTemplate>
  214. </DataGridTemplateColumn.CellTemplate>
  215. </DataGridTemplateColumn>
  216. <DataGridTemplateColumn Header="Status" Width="*">
  217. <DataGridTemplateColumn.CellTemplate>
  218. <DataTemplate>
  219. <TextBlock Text="{Binding Status}" Margin="5,0" FontFamily="Arial" FontSize="14" Foreground="{DynamicResource FG_Black}" HorizontalAlignment="Left" VerticalAlignment="Center" />
  220. </DataTemplate>
  221. </DataGridTemplateColumn.CellTemplate>
  222. </DataGridTemplateColumn>
  223. </DataGrid.Columns>
  224. </DataGrid>
  225. </Grid>
  226. <GridSplitter Grid.Row="2" Background="LightBlue" HorizontalAlignment="Stretch" VerticalAlignment="Center" Height="5" Margin="0">
  227. </GridSplitter>
  228. <Grid Grid.Row="2" Margin="0,0,0,5" Grid.RowSpan="2" >
  229. <Grid.RowDefinitions>
  230. <RowDefinition Height="25"></RowDefinition>
  231. <RowDefinition Height="*"></RowDefinition>
  232. </Grid.RowDefinitions>
  233. <Button Grid.Row="0" Content="导出数据" FontSize="10" Height="18" Margin="0,5,12,0" x:Name="ButtonExportData" IsEnabled="False" VerticalAlignment="Top" HorizontalAlignment="Right" Width="106" Click="buttonLotDetailsExport_Click" />
  234. <Grid Grid.Row="1" Margin="10,5,10,5">
  235. <Grid.ColumnDefinitions>
  236. <ColumnDefinition Width="20*"/>
  237. <ColumnDefinition Width="256*"/>
  238. <ColumnDefinition Width="20*"/>
  239. <ColumnDefinition Width="12*"/>
  240. <ColumnDefinition Width="1454*"/>
  241. <ColumnDefinition Width="19*"/>
  242. </Grid.ColumnDefinitions>
  243. <Grid Grid.Column="1" Grid.ColumnSpan="2" Margin="0,0,19,0">
  244. <StackPanel>
  245. <TreeView x:Name="ParameterTreeView" ItemsSource="{Binding ParameterNodes}" Canvas.Top="100" Height="400" >
  246. <TreeView.ItemTemplate>
  247. <HierarchicalDataTemplate ItemsSource="{Binding ChildNodes}">
  248. <StackPanel Orientation="Horizontal">
  249. <CheckBox IsChecked="{Binding Selected, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" >
  250. <i:Interaction.Triggers>
  251. <i:EventTrigger EventName="Click">
  252. <i:InvokeCommandAction Command="{Binding DataContext.PdParameterCheckCommand, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=TreeView}}" CommandParameter="{Binding }"/>
  253. </i:EventTrigger>
  254. </i:Interaction.Triggers>
  255. </CheckBox>
  256. <TextBlock Text="{Binding Name}" />
  257. </StackPanel>
  258. </HierarchicalDataTemplate>
  259. </TreeView.ItemTemplate>
  260. </TreeView>
  261. <ListBox ItemsSource="{Binding PdKeyDataCollection}" Margin="20,0,0,0" FontSize="14" Height="auto" VerticalAlignment="Bottom">
  262. <ListBox.ItemTemplate>
  263. <DataTemplate>
  264. <StackPanel Orientation="Horizontal">
  265. <TextBlock Text="{Binding Key}" Width="223"/>
  266. <Ellipse Fill="{Binding Color}" Width="15" Height="15" Margin="10,0,0,0"/>
  267. </StackPanel>
  268. </DataTemplate>
  269. </ListBox.ItemTemplate>
  270. </ListBox>
  271. </StackPanel>
  272. </Grid>
  273. <!--<DataGrid x:Name="dataGrid_DataList" AutoGenerateColumns="False" Background="#FFD6D6D6"
  274. ItemsSource="{Binding RenderableSeries, Mode=TwoWay}" SelectionMode="Extended" SelectionUnit="FullRow" CanUserResizeRows="False" CanUserSortColumns="False" CanUserResizeColumns="False" CanUserReorderColumns="False" CanUserDeleteRows="True" CanUserAddRows="True" Focusable="False" HorizontalGridLinesBrush="Gray" VerticalGridLinesBrush="Gray" HeadersVisibility="Column" Margin="0,5,0,0" Grid.ColumnSpan="3">
  275. <DataGrid.Columns>
  276. <DataGridTemplateColumn Width="35">
  277. <DataGridTemplateColumn.CellTemplate>
  278. <DataTemplate>
  279. <CheckBox IsChecked="{Binding IsVisible,Mode=TwoWay}" VerticalAlignment="Center" HorizontalAlignment="Center" Tag="{Binding UniqueId}" Checked="OnChangeDrawingItemVisibility" Unchecked="OnChangeDrawingItemVisibility"/>
  280. </DataTemplate>
  281. </DataGridTemplateColumn.CellTemplate>
  282. </DataGridTemplateColumn>
  283. <DataGridTextColumn Width="20*" Binding="{Binding DisplayName,Mode=TwoWay}" CanUserSort="False" IsReadOnly="True">
  284. <DataGridTextColumn.CellStyle>
  285. <Style TargetType="DataGridCell">
  286. <Setter Property="ToolTip" Value="{Binding DisplayName}" />
  287. </Style>
  288. </DataGridTextColumn.CellStyle>
  289. <DataGridTextColumn.HeaderTemplate >
  290. <DataTemplate >
  291. <TextBlock Text="Data" />
  292. </DataTemplate>
  293. </DataGridTextColumn.HeaderTemplate>
  294. </DataGridTextColumn>
  295. <DataGridTemplateColumn Width="60" CanUserSort="True">
  296. <DataGridTemplateColumn.CellTemplate>
  297. <DataTemplate>
  298. <Button Focusable="False" Width="42" FontSize="11" Height="20" Tag="{Binding UniqueId}" Background="{Binding Stroke,Mode=TwoWay,Converter={StaticResource colorConverter}}" Click="OnChangeLineColor"/>
  299. </DataTemplate>
  300. </DataGridTemplateColumn.CellTemplate>
  301. <DataGridTemplateColumn.HeaderTemplate >
  302. <DataTemplate>
  303. <TextBlock Text="Color" />
  304. </DataTemplate>
  305. </DataGridTemplateColumn.HeaderTemplate>
  306. </DataGridTemplateColumn>
  307. <DataGridTextColumn Width="50" Binding="{Binding LineThickness,Mode=TwoWay}" CanUserSort="False" IsReadOnly="False" >
  308. <DataGridTextColumn.HeaderTemplate >
  309. <DataTemplate>
  310. <TextBlock Text="Width" />
  311. </DataTemplate>
  312. </DataGridTextColumn.HeaderTemplate>
  313. </DataGridTextColumn>
  314. </DataGrid.Columns>
  315. </DataGrid>-->
  316. <ctrls:DrawGraphicsControl Grid.Column="3" x:Name="MyDrawGraphicsControl" 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" HorizontalAlignment="Left" Width="1477" Margin="11,10,0,5" Grid.ColumnSpan="3"/>
  317. </Grid>
  318. </Grid>
  319. </Grid>
  320. </UserControl>