EFEM2LPJetAB.xaml 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295
  1. <uc:EFEMBase x:Class="EfemUI.Controls.EFEM2LPJetAB"
  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:uc="clr-namespace:Aitex.Sorter.UI.Controls;assembly=Aitex.Sorter.UI"
  7. xmlns:equipment="clr-namespace:MECF.Framework.Common.Equipment;assembly=MECF.Framework.Common"
  8. xmlns:controls="clr-namespace:EfemUI.Controls" xmlns:system="clr-namespace:System;assembly=mscorlib"
  9. mc:Ignorable="d"
  10. d:DesignHeight="300" d:DesignWidth="300">
  11. <Viewbox>
  12. <Grid x:Name="root">
  13. <!--底面背景-->
  14. <controls:RobotBg2LP Margin="67,0,191,208" RenderTransformOrigin="0.5,0.5" Height="437" VerticalAlignment="Bottom">
  15. </controls:RobotBg2LP>
  16. <!--PMA-->
  17. <uc:LoadLock IsEnableTextMenu="{Binding IsEnableTextMenu}" Width="110" Height="110" Margin="245,-89,468,624" WaferTransferOptionCommand="{Binding WaferTransferOptionCommand}" Wafer="{Binding Loadlock1Wafer}" Station="LL1" Visibility="{Binding PMAEnable,Converter={StaticResource boolVisibilityConverter}}"/>
  18. <Label Content="PMA" Margin="277,-89,464,671" Visibility="{Binding PMAEnable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="White" FontWeight="Bold"/>
  19. <!--PMB-->
  20. <uc:LoadLock IsEnableTextMenu="{Binding IsEnableTextMenu}" Width="110" Height="110" Margin="389,-89,324,624" WaferTransferOptionCommand="{Binding WaferTransferOptionCommand}" Wafer="{Binding Loadlock2Wafer}" Station="LL2" Visibility="{Binding PMBEnable,Converter={StaticResource boolVisibilityConverter}}"/>
  21. <Label Content="PMB" Margin="422,-89,332,702" Visibility="{Binding PMBEnable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="White" FontWeight="Bold"/>
  22. <!--Aligner1-->
  23. <Label Content="Aligner1" Margin="582,233,171,360" Visibility="{Binding Aligner1Enable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="SlateGray" FontWeight="Bold"/>
  24. <controls:Chamber IsEnableTextMenu="{Binding IsEnableTextMenu}" Visibility="{Binding Aligner1Enable,Converter={StaticResource boolVisibilityConverter}}" Width="95" Height="95" Margin="562,136,151,399" WaferTransferOptionCommand="{Binding WaferTransferOptionCommand}" Wafer="{Binding Aligner1Wafer}" Station="Aligner1" Disable="False"/>
  25. <!--Aligner2-->
  26. <Label Content="Aligner2" Margin="584,356,168,239" Visibility="{Binding Aligner2Enable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="SlateGray" FontWeight="Bold"/>
  27. <controls:Chamber IsEnableTextMenu="{Binding IsEnableTextMenu}" Visibility="{Binding Aligner2Enable,Converter={StaticResource boolVisibilityConverter}}" Width="95" Height="95" Margin="562,254,151,281" WaferTransferOptionCommand="{Binding WaferTransferOptionCommand}" Wafer="{Binding Aligner2Wafer}" Station="Aligner2" Disable="False"/>
  28. <!--Buffer-->
  29. <Label Content="Buffer" Margin="589,14,174,597" Visibility="{Binding BufferEnable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="SlateGray" FontWeight="Bold"/>
  30. <controls:Buffer Visibility="{Binding BufferEnable,Converter={StaticResource boolVisibilityConverter}}" Width="110" Height="110" Margin="564,42,149,493"/>
  31. <!--LP1-->
  32. <Image Visibility="{Binding LP1Enable,Converter={StaticResource boolVisibilityConverter}}" Source="/EfemUI;component/Resources/images/lpbg.png" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="245,364,0,0" RenderTransformOrigin="0.5,0.5" Width="112">
  33. <Image.RenderTransform>
  34. <TransformGroup>
  35. <ScaleTransform/>
  36. <SkewTransform/>
  37. <RotateTransform Angle="0"/>
  38. <TranslateTransform/>
  39. </TransformGroup>
  40. </Image.RenderTransform>
  41. </Image>
  42. <Image Visibility="{Binding LP1Enable,Converter={StaticResource boolVisibilityConverter}}" Source="/EfemUI;component/Resources/images/FoupWhite.png" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="256,372,0,0" RenderTransformOrigin="0.5,0.5" Width="92">
  43. <Image.RenderTransform>
  44. <TransformGroup>
  45. <ScaleTransform/>
  46. <SkewTransform/>
  47. <RotateTransform Angle="0"/>
  48. <TranslateTransform/>
  49. </TransformGroup>
  50. </Image.RenderTransform>
  51. </Image>
  52. <Label Content="LP1" Margin="285,445,409,6" Foreground="SlateGray" Visibility="{Binding LP1Enable,Converter={StaticResource boolVisibilityConverter}}" FontWeight="Bold" FontSize="15"/>
  53. <!--LP2-->
  54. <Image Visibility="{Binding LP2Enable,Converter={StaticResource boolVisibilityConverter}}" Source="/EfemUI;component/Resources/images/lpbg.png" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="394,364,0,0" RenderTransformOrigin="0.5,0.5" Width="112">
  55. <Image.RenderTransform>
  56. <TransformGroup>
  57. <ScaleTransform/>
  58. <SkewTransform/>
  59. <RotateTransform Angle="0"/>
  60. <TranslateTransform/>
  61. </TransformGroup>
  62. </Image.RenderTransform>
  63. </Image>
  64. <Image Visibility="{Binding LP2Enable,Converter={StaticResource boolVisibilityConverter}}" Source="/EfemUI;component/Resources/images/FoupWhite.png" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="404,372,0,0" RenderTransformOrigin="0.5,0.5" Width="92">
  65. <Image.RenderTransform>
  66. <TransformGroup>
  67. <ScaleTransform/>
  68. <SkewTransform/>
  69. <RotateTransform Angle="0"/>
  70. <TranslateTransform/>
  71. </TransformGroup>
  72. </Image.RenderTransform>
  73. </Image>
  74. <Label Content="LP2" Margin="433,445,327,145" Foreground="SlateGray" Visibility="{Binding LP2Enable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" FontWeight="Bold"/>
  75. <!--CoolingBuffer1-->
  76. <Label Content="Cooling1" Margin="96,237,633,364" Visibility="{Binding CoolingBuffer1Enable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="SlateGray" FontWeight="Bold"/>
  77. <controls:Chamber IsEnableTextMenu="{Binding IsEnableTextMenu}" Visibility="{Binding CoolingBuffer1Enable,Converter={StaticResource boolVisibilityConverter}}" Width="95" Height="95" Margin="83,145,645,405" WaferTransferOptionCommand="{Binding WaferTransferOptionCommand}" Wafer="{Binding CoolingBuffer1Wafer}" Station="CoolingBuffer1" Disable="False"/>
  78. <!--CoolingBuffer2-->
  79. <Label Content="Cooling2" Margin="96,356,617,235" Visibility="{Binding CoolingBuffer2Enable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="SlateGray" FontWeight="Bold"/>
  80. <controls:Chamber IsEnableTextMenu="{Binding IsEnableTextMenu}" Visibility="{Binding CoolingBuffer2Enable,Converter={StaticResource boolVisibilityConverter}}" Width="95" Height="95" Margin="75,254,638,281" WaferTransferOptionCommand="{Binding WaferTransferOptionCommand}" Wafer="{Binding CoolingBuffer2Wafer}" Station="CoolingBuffer2" Disable="False"/>
  81. <!--Flipper-->
  82. <Label Content="Flipper" Margin="104,12,650,589" Visibility="{Binding FlipperEnable,Converter={StaticResource boolVisibilityConverter}}" FontSize="15" Foreground="SlateGray" FontWeight="Bold"/>
  83. <Canvas Canvas.Left="300" Visibility="{Binding FlipperEnable,Converter={StaticResource boolVisibilityConverter}}" Margin="82,40,645,493">
  84. <Rectangle Width="70" Height="10" Canvas.Left="15" Panel.ZIndex="4">
  85. <Rectangle.Fill>
  86. <LinearGradientBrush StartPoint="0,.5" EndPoint="1,.5">
  87. <GradientStop Color="Gray" Offset="0"></GradientStop>
  88. <GradientStop Color="White" Offset=".5"></GradientStop>
  89. <GradientStop Color="Gray" Offset="1"></GradientStop>
  90. </LinearGradientBrush>
  91. </Rectangle.Fill>
  92. </Rectangle>
  93. <Grid Width="97" Height="112" HorizontalAlignment="Left" VerticalAlignment="Top" Canvas.Left="-8" Canvas.Top="-10">
  94. <Viewport3D Margin="13,0,-7,-2" RenderTransformOrigin="0.5,0.5">
  95. <Viewport3D.RenderTransform>
  96. <TransformGroup>
  97. <ScaleTransform/>
  98. <SkewTransform/>
  99. <RotateTransform Angle="-0.321"/>
  100. <TranslateTransform/>
  101. </TransformGroup>
  102. </Viewport3D.RenderTransform>
  103. <Viewport3D.Camera>
  104. <!-- Position属性指定3D空间中摄像机的位置,LookDirection属性为摄像机方向 -->
  105. <PerspectiveCamera Position="0 0 270" LookDirection="0 0 -1" />
  106. </Viewport3D.Camera>
  107. <Viewport3D.Children>
  108. <ContainerUIElement3D>
  109. <Viewport2DVisual3D>
  110. <Viewport2DVisual3D.Geometry>
  111. <!-- Positions属性表示绘制对象的点集合,TriangleIndices属性表示对象的正反面(WPF通过逆时针环绕表示正面),TextureCoordinates属性表示2D纹理映射到3D对象 -->
  112. <!-- 一般通过3D建模工具推导得出 -->
  113. <MeshGeometry3D Positions="-100 100 0 -100 -100 0 100 -100 0 100 100 0" TriangleIndices="0 1 2 0 2 3" TextureCoordinates="0 0 0 1 1 1 1 0"/>
  114. </Viewport2DVisual3D.Geometry>
  115. <Viewport2DVisual3D.Material>
  116. <DiffuseMaterial Viewport2DVisual3D.IsVisualHostMaterial="True"/>
  117. </Viewport2DVisual3D.Material>
  118. <Viewport2DVisual3D.Visual>
  119. <!-- 放置正面自定义用户控件 -->
  120. <Canvas Width="53" Height="59">
  121. <Rectangle Canvas.Left="50" Height="50" Width="8" RadiusX="5" RadiusY="5">
  122. <Rectangle.Fill>
  123. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  124. <GradientStop Color="Gray" Offset="0"></GradientStop>
  125. <GradientStop Color="White" Offset=".5"></GradientStop>
  126. <GradientStop Color="Gray" Offset="1"></GradientStop>
  127. </LinearGradientBrush>
  128. </Rectangle.Fill>
  129. </Rectangle>
  130. <Rectangle Canvas.Left="41" Height="50" Width="8" RadiusX="5" RadiusY="5">
  131. <Rectangle.Fill>
  132. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  133. <GradientStop Color="Gray" Offset="0"></GradientStop>
  134. <GradientStop Color="White" Offset=".5"></GradientStop>
  135. <GradientStop Color="Gray" Offset="1"></GradientStop>
  136. </LinearGradientBrush>
  137. </Rectangle.Fill>
  138. </Rectangle>
  139. <Rectangle Canvas.Left="77" Canvas.Top="15" Height="90" Width="10" RadiusX="5" RadiusY="5" >
  140. <Rectangle.Fill>
  141. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  142. <GradientStop Color="Gray" Offset="0"></GradientStop>
  143. <GradientStop Color="White" Offset=".5"></GradientStop>
  144. <GradientStop Color="Gray" Offset="1"></GradientStop>
  145. </LinearGradientBrush>
  146. </Rectangle.Fill>
  147. <Rectangle.RenderTransform>
  148. <RotateTransform Angle="45"/>
  149. </Rectangle.RenderTransform>
  150. </Rectangle>
  151. <Rectangle Canvas.Left="15" Canvas.Top="22" Height="90" Width="10" RadiusX="5" RadiusY="5">
  152. <Rectangle.Fill>
  153. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  154. <GradientStop Color="Gray" Offset="0"></GradientStop>
  155. <GradientStop Color="White" Offset=".5"></GradientStop>
  156. <GradientStop Color="Gray" Offset="1"></GradientStop>
  157. </LinearGradientBrush>
  158. </Rectangle.Fill>
  159. <Rectangle.RenderTransform>
  160. <RotateTransform Angle="-45"/>
  161. </Rectangle.RenderTransform>
  162. </Rectangle>
  163. <!--Wafer-->
  164. <Ellipse Visibility="{Binding FlipperWafer.Status , Converter={StaticResource waferVisibilityConverter}}" Stretch="Fill" StrokeThickness="2" StrokeLineJoin="Round" Stroke="#FF00641D" Width="60" Height="60" Canvas.Left="20" Canvas.Top="18" Panel.ZIndex="-1">
  165. <Ellipse.Fill>
  166. <MultiBinding Converter="{StaticResource waferColorConverter}">
  167. <Binding Path="FlipperWafer.Status" />
  168. <Binding Path="FlipperWafer.ProcessState" />
  169. <Binding Path="FlipperWafer.IsDestination" />
  170. <Binding Path="FlipperWafer.IsSource" />
  171. <Binding Path="FlipperWafer.SubstE90Status" />
  172. </MultiBinding>
  173. </Ellipse.Fill>
  174. </Ellipse>
  175. <TextBlock Canvas.Left="24" Canvas.Top="40" FontSize="10" TextAlignment="Center" Width="55" Height="20" Panel.ZIndex="-1">
  176. <TextBlock.Text>
  177. <MultiBinding Converter="{StaticResource waferConverter}">
  178. <Binding Path="FlipperWafer.Status" />
  179. <Binding Path="WaferIDDisplayMode" />
  180. <Binding Path="FlipperWafer.WaferOrigin" />
  181. <Binding Path="FlipperWafer.LaserMarker" />
  182. <Binding Path="FlipperWafer.T7Code" />
  183. </MultiBinding>
  184. </TextBlock.Text>
  185. </TextBlock>
  186. </Canvas>
  187. </Viewport2DVisual3D.Visual>
  188. </Viewport2DVisual3D>
  189. <Viewport2DVisual3D>
  190. <Viewport2DVisual3D.Geometry>
  191. <MeshGeometry3D Positions="100 100 0 100 -100 0 -100 -100 0 -100 100 0" TriangleIndices="0 1 2 0 2 3" TextureCoordinates="0 0 0 1 1 1 1 0"/>
  192. </Viewport2DVisual3D.Geometry>
  193. <Viewport2DVisual3D.Material>
  194. <DiffuseMaterial Viewport2DVisual3D.IsVisualHostMaterial="True"/>
  195. </Viewport2DVisual3D.Material>
  196. <Viewport2DVisual3D.Visual>
  197. <!-- 放置反面自定义用户控件 -->
  198. <Canvas Width="100" Height="100">
  199. <Rectangle Canvas.Left="50" Height="50" Width="8" RadiusX="5" RadiusY="5" Panel.ZIndex="2">
  200. <Rectangle.Fill>
  201. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  202. <GradientStop Color="Gray" Offset="0"></GradientStop>
  203. <GradientStop Color="White" Offset=".5"></GradientStop>
  204. <GradientStop Color="Gray" Offset="1"></GradientStop>
  205. </LinearGradientBrush>
  206. </Rectangle.Fill>
  207. </Rectangle>
  208. <Rectangle Canvas.Left="41" Height="50" Width="8" RadiusX="5" RadiusY="5" Panel.ZIndex="2">
  209. <Rectangle.Fill>
  210. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  211. <GradientStop Color="Gray" Offset="0"></GradientStop>
  212. <GradientStop Color="White" Offset=".5"></GradientStop>
  213. <GradientStop Color="Gray" Offset="1"></GradientStop>
  214. </LinearGradientBrush>
  215. </Rectangle.Fill>
  216. </Rectangle>
  217. <Rectangle Canvas.Left="77" Canvas.Top="15" Height="90" Width="10" RadiusX="5" RadiusY="5" >
  218. <Rectangle.Fill>
  219. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  220. <GradientStop Color="Gray" Offset="0"></GradientStop>
  221. <GradientStop Color="White" Offset=".5"></GradientStop>
  222. <GradientStop Color="Gray" Offset="1"></GradientStop>
  223. </LinearGradientBrush>
  224. </Rectangle.Fill>
  225. <Rectangle.RenderTransform>
  226. <RotateTransform Angle="45"/>
  227. </Rectangle.RenderTransform>
  228. </Rectangle>
  229. <Rectangle Canvas.Left="15" Canvas.Top="22" Height="90" Width="10" RadiusX="5" RadiusY="5">
  230. <Rectangle.Fill>
  231. <LinearGradientBrush StartPoint=".5,0" EndPoint=".5,1">
  232. <GradientStop Color="Gray" Offset="0"></GradientStop>
  233. <GradientStop Color="White" Offset=".5"></GradientStop>
  234. <GradientStop Color="Gray" Offset="1"></GradientStop>
  235. </LinearGradientBrush>
  236. </Rectangle.Fill>
  237. <Rectangle.RenderTransform>
  238. <RotateTransform Angle="-45"/>
  239. </Rectangle.RenderTransform>
  240. </Rectangle>
  241. <!--Wafer-->
  242. <Ellipse Visibility="{Binding FlipperWafer.Status , Converter={StaticResource waferVisibilityConverter}}" Stretch="Fill" StrokeThickness="2" StrokeLineJoin="Round" Stroke="#FF00641D" Width="60" Height="60" Canvas.Left="20" Canvas.Top="18" Panel.ZIndex="-1">
  243. <Ellipse.Fill>
  244. <MultiBinding Converter="{StaticResource waferColorConverter}">
  245. <Binding Path="FlipperWafer.Status" />
  246. <Binding Path="FlipperWafer.ProcessState" />
  247. <Binding Path="FlipperWafer.IsDestination" />
  248. <Binding Path="FlipperWafer.IsSource" />
  249. <Binding Path="FlipperWafer.SubstE90Status" />
  250. </MultiBinding>
  251. </Ellipse.Fill>
  252. </Ellipse>
  253. <TextBlock Canvas.Left="24" Canvas.Top="40" FontSize="10" TextAlignment="Center" Width="55" Height="20" Panel.ZIndex="-1">
  254. <TextBlock.Text>
  255. <MultiBinding Converter="{StaticResource waferConverter}">
  256. <Binding Path="FlipperWafer.Status" />
  257. <Binding Path="WaferIDDisplayMode" />
  258. <Binding Path="FlipperWafer.WaferOrigin" />
  259. <Binding Path="FlipperWafer.LaserMarker" />
  260. <Binding Path="FlipperWafer.T7Code" />
  261. </MultiBinding>
  262. </TextBlock.Text>
  263. </TextBlock>
  264. </Canvas>
  265. </Viewport2DVisual3D.Visual>
  266. </Viewport2DVisual3D>
  267. <ContainerUIElement3D.Transform>
  268. <RotateTransform3D>
  269. <RotateTransform3D.Rotation>
  270. <!-- 设置旋转轴为对齐坐标系统的Y轴 -->
  271. <AxisAngleRotation3D x:Name="aar" Angle="0" Axis="0 1 0"/>
  272. </RotateTransform3D.Rotation>
  273. </RotateTransform3D>
  274. </ContainerUIElement3D.Transform>
  275. </ContainerUIElement3D>
  276. <ModelVisual3D>
  277. <ModelVisual3D.Content>
  278. <!-- 设置指定方向传播的平行光线填充场景 -->
  279. <DirectionalLight Color="Transparent"/>
  280. </ModelVisual3D.Content>
  281. </ModelVisual3D>
  282. </Viewport3D.Children>
  283. </Viewport3D>
  284. </Grid>
  285. </Canvas>
  286. <!--Robot-->
  287. <controls:AtmRobot IsEnableTextMenu="{Binding IsEnableTextMenu}" Wafer1="{Binding RobotWafer1}" Wafer2="{Binding RobotWafer2}" Command="{Binding DeviceOperationCommand}" RobotBladeTarget="{Binding RobotBladeTarget}" RobotBlade2Target="{Binding RobotBlade2Target}" MoveInfo="{Binding RobotMoveInfo}" StationPosition="{Binding StationPosition}" ShowDock="False" Margin="316,-231,12,76" />
  288. </Grid>
  289. </Viewbox>
  290. </uc:EFEMBase>