Chamber.xaml 24 KB

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