Chamber.xaml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. <UserControl x:Class="CyberX8_Themes.UserControls.Chamber"
  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_Themes.UserControls"
  7. mc:Ignorable="d"
  8. d:DesignHeight="300" d:DesignWidth="300" x:Name="chamber">
  9. <UserControl.Resources>
  10. <Storyboard x:Key="SlitValve_Open">
  11. <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Height)" >
  12. <EasingDoubleKeyFrame KeyTime="0" Value="75"/>
  13. <EasingDoubleKeyFrame KeyTime="0:0:1" Value="42"/>
  14. </DoubleAnimationUsingKeyFrames>
  15. </Storyboard>
  16. <Storyboard x:Key="SlitValve_Close">
  17. <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Height)" >
  18. <EasingDoubleKeyFrame KeyTime="0" Value="42"/>
  19. <EasingDoubleKeyFrame KeyTime="0:0:1" Value="75"/>
  20. </DoubleAnimationUsingKeyFrames>
  21. </Storyboard>
  22. <Style TargetType="{x:Type Rectangle}" x:Key="SlitValve_Animation" >
  23. <Style.Triggers>
  24. <DataTrigger Binding="{Binding ElementName=chamber,Path=IsOpenSlitDoor}" Value="true">
  25. <DataTrigger.EnterActions>
  26. <BeginStoryboard Storyboard="{StaticResource SlitValve_Open}"/>
  27. </DataTrigger.EnterActions>
  28. <DataTrigger.ExitActions>
  29. <BeginStoryboard Storyboard="{StaticResource SlitValve_Close}"/>
  30. </DataTrigger.ExitActions>
  31. </DataTrigger>
  32. </Style.Triggers>
  33. </Style>
  34. <LinearGradientBrush StartPoint="0,0.501" EndPoint="1,0.501" x:Key="rfcolor">
  35. <LinearGradientBrush.GradientStops>
  36. <GradientStop Color="#FFFFDD76" Offset="0" />
  37. <GradientStop Color="sc#1, 0.8019137, 0.520800948, 0.106530145" Offset="0.25" />
  38. <GradientStop Color="#FFCC9932" Offset="1" />
  39. </LinearGradientBrush.GradientStops>
  40. </LinearGradientBrush>
  41. </UserControl.Resources>
  42. <Canvas >
  43. <Grid Width="240" Height="190" Canvas.Top="80">
  44. <Grid.RowDefinitions>
  45. <RowDefinition Height="160"/>
  46. <RowDefinition />
  47. </Grid.RowDefinitions>
  48. <Path Data="M0.5,0.5 L33.5,0.5 33.5,17.5 206.5,17.5 206.5,0.5 239.5,0.5 239.5,149.5 0.5,149.5 z" Stroke="#FF747474" Margin="0,10,0,0">
  49. <Path.Fill>
  50. <LinearGradientBrush EndPoint="1,1" StartPoint="0,0">
  51. <GradientStop Color="#FF8F8F8F" Offset="0"/>
  52. <GradientStop Color="#FF9B9B9B" Offset="1"/>
  53. <GradientStop Color="#FEF1ECEC" Offset="0.15"/>
  54. <GradientStop Color="#FEC0C0C0" Offset="0.38"/>
  55. <GradientStop Color="#FEB4B4B4" Offset="0.5"/>
  56. <GradientStop Color="#FEE5E5E5" Offset="0.7"/>
  57. <GradientStop Color="#FFBABABA" Offset="0.85"/>
  58. <GradientStop Color="#FFE5E5E5" Offset="0.9"/>
  59. </LinearGradientBrush>
  60. </Path.Fill>
  61. </Path>
  62. <Rectangle Stroke="#FF747474" Margin="8,18">
  63. <Rectangle.Fill>
  64. <LinearGradientBrush EndPoint="0.243,1" StartPoint="0.757,0">
  65. <GradientStop Color="#FFE0DEDE" Offset="0"/>
  66. <GradientStop Color="#FFE2E2E2" Offset="1"/>
  67. <GradientStop Color="#FEFFFFFF" Offset="0.55"/>
  68. <GradientStop Color="#FFEFEFEF" Offset="0.75"/>
  69. </LinearGradientBrush>
  70. </Rectangle.Fill>
  71. </Rectangle>
  72. <Rectangle x:Name="BG_Status" Margin="9,19" Visibility="{Binding BiasRfPowerOnChamberVisibility}" Cursor="Hand">
  73. <Rectangle.ContextMenu >
  74. <ContextMenu>
  75. <MenuItem Header="Create Wafer" Click="CreateWafer_Click" IsChecked="{Binding IsHasWafer}" IsEnabled="{Binding IsHasWafer,Converter={StaticResource BoolToBool}}"/>
  76. <MenuItem Header="Delete Wafer" Click="DeleteWafer_Click" IsChecked="{Binding IsHasWafer,Converter={StaticResource BoolToBool}}" IsEnabled="{Binding IsHasWafer}"/>
  77. </ContextMenu>
  78. </Rectangle.ContextMenu>
  79. <Rectangle.Style>
  80. <Style>
  81. <Setter Property="Rectangle.Fill" Value="WhiteSmoke"/>
  82. <Style.Triggers>
  83. <DataTrigger Binding="{Binding ElementName=chamber,Path=IsBRFOn}" Value="True">
  84. <Setter Property="Rectangle.Fill" Value="#FFFF9292"/>
  85. </DataTrigger>
  86. </Style.Triggers>
  87. </Style>
  88. </Rectangle.Style>
  89. </Rectangle>
  90. <Rectangle Stroke="#FF747474" Height="11" VerticalAlignment="Bottom" Margin="12,0,12,8">
  91. <Rectangle.Fill>
  92. <LinearGradientBrush EndPoint="0.243,1" StartPoint="0.757,0">
  93. <GradientStop Color="#FFE0DEDE" Offset="0"/>
  94. <GradientStop Color="#FFE2E2E2" Offset="1"/>
  95. <GradientStop Color="#FEFFFFFF" Offset="0.55"/>
  96. <GradientStop Color="#FFEFEFEF" Offset="0.75"/>
  97. </LinearGradientBrush>
  98. </Rectangle.Fill>
  99. </Rectangle>
  100. <Grid x:Name="Cover" Width="180" Height="18" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="30,2,0,0" RenderTransformOrigin="1,0.4444">
  101. <Grid.RenderTransform>
  102. <TransformGroup>
  103. <ScaleTransform/>
  104. <SkewTransform/>
  105. <RotateTransform/>
  106. <TranslateTransform/>
  107. </TransformGroup>
  108. </Grid.RenderTransform>
  109. <Grid.Resources>
  110. <Storyboard x:Key="CoverOpen">
  111. <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[2].(RotateTransform.Angle)">
  112. <EasingDoubleKeyFrame KeyTime="0" Value="0"/>
  113. <EasingDoubleKeyFrame KeyTime="0:0:0.5" Value="20"/>
  114. </DoubleAnimationUsingKeyFrames>
  115. </Storyboard>
  116. <Storyboard x:Key="CoverClose">
  117. <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(TransformGroup.Children)[2].(RotateTransform.Angle)">
  118. <EasingDoubleKeyFrame KeyTime="0" Value="20"/>
  119. <EasingDoubleKeyFrame KeyTime="0:0:0.5" Value="0"/>
  120. </DoubleAnimationUsingKeyFrames>
  121. </Storyboard>
  122. </Grid.Resources>
  123. <Grid.Style>
  124. <Style>
  125. <Style.Triggers>
  126. <DataTrigger Binding="{Binding ElementName=chamber,Path=IsLidOpen}" Value="true">
  127. <DataTrigger.EnterActions>
  128. <BeginStoryboard Storyboard="{StaticResource CoverOpen}"/>
  129. </DataTrigger.EnterActions>
  130. <DataTrigger.ExitActions>
  131. <BeginStoryboard Storyboard="{StaticResource CoverClose}"/>
  132. </DataTrigger.ExitActions>
  133. </DataTrigger>
  134. </Style.Triggers>
  135. </Style>
  136. </Grid.Style>
  137. <Rectangle Grid.Row="0" HorizontalAlignment="Center" VerticalAlignment="Bottom" Fill="{DynamicResource Lid_BG}" Stroke="{DynamicResource Lid_BD}" Width="172" Height="12"/>
  138. <Rectangle Grid.Row="0" HorizontalAlignment="Center" VerticalAlignment="Top" Fill="{DynamicResource Lid_BG}" Stroke="{DynamicResource Lid_BD}" Width="180" Height="8"/>
  139. <Line X1="35" Y1="-80" X2="120" Y2="-90" Stroke="#B87333" StrokeThickness="5"/>
  140. <Line X1="35" Y1="-60" X2="145" Y2="-70" Stroke="#B87333" StrokeThickness="5"/>
  141. <Line X1="35" Y1="-40" X2="145" Y2="-50" Stroke="#B87333" StrokeThickness="5"/>
  142. <Line X1="35" Y1="-20" X2="145" Y2="-30" Stroke="#B87333" StrokeThickness="5"/>
  143. <Rectangle Stroke="DimGray" Fill="WhiteSmoke" Margin="130,-101,42,0" Width="8" VerticalAlignment="Top" Height="102" />
  144. <Rectangle Stroke="DimGray" Fill="WhiteSmoke" Margin="42,-101,130,0" Width="8" VerticalAlignment="Top" Height="102" />
  145. <Rectangle Fill="DimGray" Margin="42,-108,42,0" VerticalAlignment="Top" Height="8" />
  146. <Rectangle Fill="White" Margin="50,-101,50,0" Width="80" Height="118" />
  147. <Rectangle x:Name="BG_Status1" Margin="50,-101,50,0" Width="80" Height="118" Visibility="{Binding RfPowerOnChamberVisibility}" >
  148. <Rectangle.Style>
  149. <Style>
  150. <Setter Property="Rectangle.Fill" Value="WhiteSmoke"/>
  151. <Style.Triggers>
  152. <DataTrigger Binding="{Binding ElementName=chamber,Path=IsSRFOn}" Value="True">
  153. <Setter Property="Rectangle.Fill" Value="#FFFF9292"/>
  154. </DataTrigger>
  155. </Style.Triggers>
  156. </Style>
  157. </Rectangle.Style>
  158. </Rectangle>
  159. <Rectangle Stroke="#FF000000" Width="80" Height="10" Margin="0,8,0,0" StrokeThickness="1" StrokeDashArray="4 2" SnapsToDevicePixels="True"/>
  160. <Rectangle Stroke="#FF000000" Width="80" Height="9" Margin="0,-10,0,0" StrokeThickness="1" StrokeDashArray="4 2" SnapsToDevicePixels="True"/>
  161. <Line X1="35" Y1="-40" X2="145" Y2="-30" Stroke="#B87333" StrokeThickness="5"/>
  162. <Line X1="35" Y1="-60" X2="145" Y2="-50" Stroke="#B87333" StrokeThickness="5"/>
  163. <Line X1="35" Y1="-80" X2="145" Y2="-70" Stroke="#B87333" StrokeThickness="5"/>
  164. </Grid>
  165. <Grid Grid.RowSpan="2" Width="160" Height="167" VerticalAlignment="Bottom" Margin="0,0,0,2">
  166. <Rectangle Height="12" Stroke="Gray" VerticalAlignment="Top" Width="150" Margin="0,98,0,0">
  167. <Rectangle.Fill>
  168. <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
  169. <GradientStop Color="#FFABABAB" Offset="0"/>
  170. <GradientStop Color="#FFDADADA" Offset="1"/>
  171. </LinearGradientBrush>
  172. </Rectangle.Fill>
  173. </Rectangle>
  174. <Rectangle Height="12" Margin="0,109,0,0" Stroke="Gray" VerticalAlignment="Top" Width="160">
  175. <Rectangle.Fill>
  176. <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
  177. <GradientStop Color="#FFABABAB" Offset="0"/>
  178. <GradientStop Color="#FFDADADA" Offset="1"/>
  179. </LinearGradientBrush>
  180. </Rectangle.Fill>
  181. </Rectangle>
  182. <!--4寸 guide pin-->
  183. <Grid x:Name="Bottom_LiftPin" Height="75" VerticalAlignment="Bottom" Margin="0,0,0,0" >
  184. <Grid.Resources>
  185. <Storyboard x:Key="BottomPinUp">
  186. <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" >
  187. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,0"/>
  188. <EasingThicknessKeyFrame KeyTime="0:0:0.5" Value="0,0,0,15"/>
  189. </ThicknessAnimationUsingKeyFrames>
  190. </Storyboard>
  191. <Storyboard x:Key="BottomPinDown">
  192. <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" >
  193. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,15"/>
  194. <EasingThicknessKeyFrame KeyTime="0:0:0.5" Value="0,0,0,0"/>
  195. </ThicknessAnimationUsingKeyFrames>
  196. </Storyboard>
  197. </Grid.Resources>
  198. <Grid.Style>
  199. <Style>
  200. <Style.Triggers>
  201. <DataTrigger Binding="{Binding IsLowerPinUp}" Value="true">
  202. <DataTrigger.EnterActions>
  203. <BeginStoryboard Storyboard="{StaticResource BottomPinUp}"/>
  204. </DataTrigger.EnterActions>
  205. <DataTrigger.ExitActions>
  206. <BeginStoryboard Storyboard="{StaticResource BottomPinDown}"/>
  207. </DataTrigger.ExitActions>
  208. </DataTrigger>
  209. </Style.Triggers>
  210. </Style>
  211. </Grid.Style>
  212. <!--<Rectangle HorizontalAlignment="Left" Fill="{DynamicResource Lid_BG1}" Stroke="{DynamicResource Lid_BD}" Width="8" Margin="10,6,0,4"/>-->
  213. <!--<Rectangle HorizontalAlignment="Right" Fill="{DynamicResource Lid_BG1}" Stroke="{DynamicResource Lid_BD}" Width="8" Margin="0,6,10,4"/>-->
  214. <!--<Rectangle Stroke="{DynamicResource Lid_BD}" Fill="{DynamicResource Lid_BG1}" StrokeThickness="1" VerticalAlignment="Bottom" Height="8" Margin="5,0"/>-->
  215. </Grid>
  216. <!--3寸 guide pin-->
  217. <Grid x:Name="Middle_LiftPin" Width="120" Height="63" VerticalAlignment="Bottom" Margin="0,0,0,12" >
  218. <Grid.Resources>
  219. <Storyboard x:Key="MidPinUp">
  220. <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" >
  221. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,12"/>
  222. <EasingThicknessKeyFrame KeyTime="0:0:0.5" Value="0,0,0,27"/>
  223. </ThicknessAnimationUsingKeyFrames>
  224. </Storyboard>
  225. <Storyboard x:Key="MidPinDown">
  226. <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" >
  227. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,27"/>
  228. <EasingThicknessKeyFrame KeyTime="0:0:0.5" Value="0,0,0,12"/>
  229. </ThicknessAnimationUsingKeyFrames>
  230. </Storyboard>
  231. </Grid.Resources>
  232. <Grid.Style>
  233. <Style>
  234. <Style.Triggers>
  235. <DataTrigger Binding="{Binding IsUpperPinUp}" Value="true">
  236. <DataTrigger.EnterActions>
  237. <BeginStoryboard Storyboard="{StaticResource MidPinUp}"/>
  238. </DataTrigger.EnterActions>
  239. <DataTrigger.ExitActions>
  240. <BeginStoryboard Storyboard="{StaticResource MidPinDown}"/>
  241. </DataTrigger.ExitActions>
  242. </DataTrigger>
  243. </Style.Triggers>
  244. </Style>
  245. </Grid.Style>
  246. <!--<Rectangle HorizontalAlignment="Left" Fill="{DynamicResource Lid_BG2}" Stroke="{DynamicResource Lid_BD}" Width="8" Margin="10,6,0,4"/>
  247. <Rectangle HorizontalAlignment="Right" Fill="{DynamicResource Lid_BG2}" Stroke="{DynamicResource Lid_BD}" Width="8" Margin="0,6,10,4"/>-->
  248. <!--<Rectangle Stroke="{DynamicResource Lid_BD}" Fill="{DynamicResource Lid_BG2}" StrokeThickness="1" VerticalAlignment="Bottom" Height="8" Margin="5,0"/>-->
  249. </Grid>
  250. <!--lift pin-->
  251. <Grid x:Name="Top_LiftPin" Height="51" VerticalAlignment="Bottom" Margin="0,0,0,28" >
  252. <Grid.Resources>
  253. <Storyboard x:Key="TopPinUp">
  254. <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" >
  255. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,28"/>
  256. <EasingThicknessKeyFrame KeyTime="0:0:0.5" Value="0,0,0,54"/>
  257. </ThicknessAnimationUsingKeyFrames>
  258. </Storyboard>
  259. <Storyboard x:Key="TopPinDown">
  260. <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" >
  261. <EasingThicknessKeyFrame KeyTime="0" Value="0,0,0,54"/>
  262. <EasingThicknessKeyFrame KeyTime="0:0:0.5" Value="0,0,0,28"/>
  263. </ThicknessAnimationUsingKeyFrames>
  264. </Storyboard>
  265. </Grid.Resources>
  266. <Grid.Style>
  267. <Style>
  268. <Style.Triggers>
  269. <DataTrigger Binding="{Binding ElementName=chamber,Path=IsLiftPinUp}" Value="true">
  270. <DataTrigger.EnterActions>
  271. <BeginStoryboard Storyboard="{StaticResource TopPinUp}"/>
  272. </DataTrigger.EnterActions>
  273. <DataTrigger.ExitActions>
  274. <BeginStoryboard Storyboard="{StaticResource TopPinDown}"/>
  275. </DataTrigger.ExitActions>
  276. </DataTrigger>
  277. </Style.Triggers>
  278. </Style>
  279. </Grid.Style>
  280. <Rectangle HorizontalAlignment="Left" Fill="{DynamicResource Lid_BG3}" Stroke="{DynamicResource Lid_BD}" Width="8" Margin="48,10,0,4"/>
  281. <Rectangle HorizontalAlignment="Right" Fill="{DynamicResource Lid_BG3}" Stroke="{DynamicResource Lid_BD}" Width="8" Margin="0,10,48,4"/>
  282. <Rectangle Stroke="{DynamicResource Lid_BD}" Fill="{DynamicResource Lid_BG3}" StrokeThickness="1" VerticalAlignment="Bottom" Height="8" Margin="5,0" Width="64" />
  283. <Rectangle HorizontalAlignment="Center" Margin="-100,0" Width="{Binding WaferLength}" Height="10" VerticalAlignment="Top"/>
  284. <TextBlock Text="{Binding ElementName=chamber,Path=WaferID}" Margin="0,-20,0,0" TextAlignment="Center"></TextBlock>
  285. <Border BorderThickness="1" BorderBrush="DarkGray" CornerRadius="4" VerticalAlignment="Top" Height="10" Margin="0,0,0,0" Width="140" Visibility="{Binding ElementName=chamber,Path=IsHasWafer,Converter={StaticResource bool2VisibilityConverter}}">
  286. <Border.Background>
  287. <RadialGradientBrush >
  288. <GradientStop Color="AliceBlue" Offset="0" />
  289. <!--<GradientStop Color="Silver" Offset="0.5" />-->
  290. <GradientStop Color="LightGreen" Offset="1" />
  291. </RadialGradientBrush>
  292. </Border.Background>
  293. </Border>
  294. </Grid>
  295. <Canvas Visibility="{Binding ElementName=chamber,Path=IsHasHeater,Converter={StaticResource bool2VisibilityConverter}}" Margin="29.5,100,0,0">
  296. <Rectangle HorizontalAlignment="Left" Fill="{DynamicResource Lid_BG3}" Stroke="Black" Width="100" Height="10"/>
  297. <Rectangle HorizontalAlignment="Left" Fill="{DynamicResource Lid_BG3}" Stroke="Black" Width="100" Height="10" Canvas.Top="10"/>
  298. <Rectangle HorizontalAlignment="Left" Fill="{DynamicResource Lid_BG3}" Stroke="Black" Width="30" Height="30" Canvas.Top="20" Canvas.Left="36"/>
  299. </Canvas>
  300. <!--左边slit door-->
  301. <Grid x:Name="Slit_valve" Margin="-41,-10,191,29" >
  302. <Rectangle x:Name="SlitValve_Top" Fill="DimGray" Width="8" VerticalAlignment="Top" Height="75" />
  303. <Rectangle x:Name="SlitValve_Bottom" Fill="DimGray" Width="8" VerticalAlignment="Bottom" Height="75" />
  304. </Grid>
  305. <!--slit door右边-->
  306. <Grid Margin="190,-10,-40,29" Cursor="Hand">
  307. <Grid.ContextMenu>
  308. <ContextMenu >
  309. <MenuItem Header="Open Door" Click="OpenDoor_Click" IsChecked="{Binding IsSlitDoorClosed,Converter={StaticResource BoolToBool}}" IsEnabled="{Binding IsSlitDoorClosed}"/>
  310. <MenuItem Header="Close Door" Click="CloseDoor_Click" IsChecked="{Binding IsSlitDoorClosed}" IsEnabled="{Binding IsSlitDoorClosed,Converter={StaticResource BoolToBool}}"/>
  311. </ContextMenu>
  312. </Grid.ContextMenu>
  313. <Rectangle Fill="DimGray" Style="{StaticResource SlitValve_Animation}" Width="8" VerticalAlignment="Top" Height="75" />
  314. <Rectangle Fill="DimGray" Style="{StaticResource SlitValve_Animation}" Width="8" VerticalAlignment="Bottom" Height="75" />
  315. </Grid>
  316. </Grid>
  317. </Grid>
  318. </Canvas>
  319. </UserControl>