ChamberWithHeater.xaml 21 KB

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