Compare commits
246 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| c475f7dc12 | |||
| 0151cd8f9e | |||
| 75e3729216 | |||
| 959fb2e44f | |||
| 59e3ae5841 | |||
| 941e7837be | |||
| 58de5d4077 | |||
| b6beef668d | |||
| 680505af10 | |||
| b0bfa67d2a | |||
| 29d8c1e29b | |||
| e5d4f223f8 | |||
| 3cfc7276c9 | |||
| 0c0233b27e | |||
| 4e8925515d | |||
| 3b552b2f4e | |||
| 3fae33404b | |||
| 0d4d853834 | |||
| 37fcbe8240 | |||
| 4393f282b7 | |||
| 6844a8c77c | |||
| 659405c52f | |||
| 6905a8d6dc | |||
| d8ba23894e | |||
| aba1572f95 | |||
| fdb0ed598b | |||
| 4cb3518346 | |||
| 56b8ee88d3 | |||
| d0439f2b05 | |||
| 07d8145d57 | |||
| 997e8c380d | |||
| 8d363b8b06 | |||
| d49c231541 | |||
| 8d82058e49 | |||
| d6a9cac6b4 | |||
| 4ce898c25c | |||
| 6f59cddd80 | |||
| c8b018f6df | |||
| e287e827c4 | |||
| 68e9a9201d | |||
| 0eaebd5aad | |||
| 8946bf3a00 | |||
| aeb0be0590 | |||
| a15acb6528 | |||
| e7e9d26b75 | |||
| d9de23daca | |||
| ad5c9331ba | |||
| b67330b509 | |||
| ca66108145 | |||
| 379ccc7519 | |||
| b751c27773 | |||
| 14e1c254f0 | |||
| 6f08e5f520 | |||
| 7d8933cc39 | |||
| 2179996bff | |||
| 316bcc89ea | |||
| 17f41f1563 | |||
| 6a17b88283 | |||
| ce151e5db7 | |||
| b303fe2615 | |||
| 6f248ec645 | |||
| 3e0d43c1d8 | |||
| 70b1822446 | |||
| 17d6ced974 | |||
| db145af965 | |||
| 037fdb41b6 | |||
| f89fe7fefd | |||
| 6ecbd7f545 | |||
| 734f480f67 | |||
| 87fa5cc6dd | |||
| 5b00409abe | |||
| 0f3b91e847 | |||
| 3befbecd3c | |||
| b6d2cc434c | |||
| 800a589285 | |||
| 2618d3f14c | |||
| bb32a4e500 | |||
| 6d266819db | |||
| 3ce8965206 | |||
| d924f4c107 | |||
| b141bda34d | |||
| ecb599c5c1 | |||
| 957a012de5 | |||
| 12277387b6 | |||
| ac92d1b4df | |||
| 5fe84aa6fd | |||
| b3ec57fb79 | |||
| c5f8e1f3fd | |||
| 202a63329b | |||
| 8cdc527943 | |||
| 61bb35fda2 | |||
| ee70e8f4c2 | |||
| 4d0e700d50 | |||
| 4432893794 | |||
| 9fa98d78a5 | |||
| e1d166375a | |||
| 4e669bc577 | |||
| 73a1caf1d0 | |||
| 322497121d | |||
| 468270cbab | |||
| 71ce283bad | |||
| 576d547a85 | |||
| a79316f290 | |||
| 51ee7a0c92 | |||
| 237eeb8871 | |||
| abe1b3a430 | |||
| 7e205a6424 | |||
| a7d7c66e2b | |||
| 7bb35e4694 | |||
| 65e72391d8 | |||
| 32e4d6d76b | |||
| 59b9354551 | |||
| 7315166ca7 | |||
| b9875ba243 | |||
| f7bcdff766 | |||
| 47b98c6392 | |||
| a0f5585391 | |||
| a6457ece76 | |||
| e93c4e41a3 | |||
| abaf1ac3a8 | |||
| ed4fc25c5d | |||
| d1d48bf8a4 | |||
| 4e0d362b36 | |||
| 1afdc8551f | |||
| d17cd8d2d8 | |||
| cc11ab463f | |||
| d322dc192d | |||
| 24ab2e0ba8 | |||
| 8aec6c87b0 | |||
| 24fa5e089a | |||
| 29eae5517a | |||
| 1ce036a0f6 | |||
| dd5dd7c93c | |||
| 393559d41a | |||
| 45f6639dcd | |||
| de989f5762 | |||
| c33d6c1e77 | |||
| a1b2158404 | |||
| 05e94943e0 | |||
| 6bba5143f9 | |||
| 3957f66ec1 | |||
| 46f7e78efc | |||
| 02a8e3a274 | |||
| 00bbe3ad70 | |||
| f81970accc | |||
| 165ed71234 | |||
| 01b04e6a9d | |||
| 8a8ff33110 | |||
| 4ca3b4ee47 | |||
| 6b6031379b | |||
| 7e96fb2385 | |||
| 7ee4a2e552 | |||
| 105a12c497 | |||
| e0f380ed1d | |||
| a568c614fb | |||
| 6dc5fe5a12 | |||
| a1db5945df | |||
| fba8b377f9 | |||
| 401b171c4e | |||
| 3285d72817 | |||
| 17229ab9bc | |||
| c3abca3cee | |||
| 2e0f2eab1b | |||
| 9c60ef020f | |||
| 58c62ebd5c | |||
| ab525c7431 | |||
| 613b9fa725 | |||
| e4e20b9f91 | |||
| ca6a468cda | |||
| 24ddd7d245 | |||
| f9fd0f0168 | |||
| eac7b0999a | |||
| a464e0dc3b | |||
| 401af44bb5 | |||
| 1599515d58 | |||
| 0be1695246 | |||
| a79725783f | |||
| f13a51e8a1 | |||
| b77ed406ae | |||
| bb650afe9c | |||
| 1d87ac5c47 | |||
| fc3053df66 | |||
| 588ef08b17 | |||
| ebdaeece85 | |||
| 1605f81090 | |||
| a10703fe94 | |||
| a0575cbbac | |||
| 8180ffaeaa | |||
| 848783078c | |||
| 45f0245f9f | |||
| a81a7f8d9e | |||
| ca0210cf09 | |||
| 622912dec3 | |||
| 8ed35a5c46 | |||
| a2bbcfed95 | |||
| 0667da3692 | |||
| 5ff39c9d1c | |||
| 60a666c1c1 | |||
| df47692e8e | |||
| 5f2d03cbcb | |||
| 5255fad7fc | |||
| 41903872b1 | |||
| beb3ce841b | |||
| 4a2da4ac41 | |||
| 869b459c3b | |||
| aa84b2c8ab | |||
| 555d2d029f | |||
| 749fb2d949 | |||
| 5b3e73290c | |||
| 854519b706 | |||
| d8179b47ee | |||
| f68e141449 | |||
| 011c94cc6b | |||
| 64da46c0a4 | |||
| aab81c6af7 | |||
| 46be644285 | |||
| 5fe75b78e5 | |||
| eafe6184eb | |||
| 0e35e41c4a | |||
| 64e3fd83de | |||
| e5e74a6afd | |||
| 28deac8501 | |||
| 367a8c9fc3 | |||
| 0717546ad0 | |||
| 3bf1a87688 | |||
| 6d82b6efee | |||
| 94102172dd | |||
| 82426db72a | |||
| 20fd722dee | |||
| c83b3e6bea | |||
| a45613ff39 | |||
| 84690ddf32 | |||
| 844cb3cfe6 | |||
| ee84a57194 | |||
| e26d68b0f3 | |||
| 2e9071569a | |||
| 5f03a36df2 | |||
| ac9c347bc0 | |||
| 9784c75766 | |||
| 8af69e553d | |||
| 3128f89f63 | |||
| 56884c34f2 | |||
| 332b17e55e | |||
| 4aaf1d084e | |||
| 4bcbe8d290 | |||
| 0107fc022b |
@@ -1,4 +1,5 @@
|
|||||||
Imports EgtUILib
|
Imports System.Windows.Forms.Integration
|
||||||
|
Imports EgtUILib
|
||||||
|
|
||||||
Friend Module CamAuto
|
Friend Module CamAuto
|
||||||
|
|
||||||
@@ -155,6 +156,30 @@ Friend Module CamAuto
|
|||||||
Return bOk
|
Return bOk
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
Friend Function ResetAllBRidges() As Boolean
|
||||||
|
Dim bOk As Boolean = True
|
||||||
|
Dim nMachGroup As Integer = EgtGetCurrMachGroup()
|
||||||
|
Dim nBridgesGroup As Integer = EgtGetFirstNameInGroup(nMachGroup, "Bridges")
|
||||||
|
bOk = EgtErase(nBridgesGroup)
|
||||||
|
Return bOk
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Friend Function ResetAllRawPart() As Boolean
|
||||||
|
Dim nPhase As Integer = 1
|
||||||
|
Dim nOtherRaw As Integer = EgtGetFirstRawPart()
|
||||||
|
While nOtherRaw <> GDB_ID.NULL
|
||||||
|
' se il pezzo non appartiene alla prima fase allora viene eliminato
|
||||||
|
If Not EgtVerifyRawPartPhase(nOtherRaw, nPhase) Then
|
||||||
|
Dim NextRaw As Integer = EgtGetNextRawPart(nOtherRaw)
|
||||||
|
EgtRemoveRawPart(nOtherRaw)
|
||||||
|
nOtherRaw = NextRaw
|
||||||
|
Else
|
||||||
|
nOtherRaw = EgtGetNextRawPart(nOtherRaw)
|
||||||
|
End If
|
||||||
|
End While
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
' verifico che il contorno passato non sia stato separato
|
' verifico che il contorno passato non sia stato separato
|
||||||
Friend Function VerifyOutLoopIsClosed(nIdLayerOutLoop As Integer)
|
Friend Function VerifyOutLoopIsClosed(nIdLayerOutLoop As Integer)
|
||||||
Dim nIdMy As Integer = EgtGetFirstInGroup(nIdLayerOutLoop)
|
Dim nIdMy As Integer = EgtGetFirstInGroup(nIdLayerOutLoop)
|
||||||
|
|||||||
@@ -27,6 +27,14 @@
|
|||||||
<EgtWPFLib:EgtTextBox Name="ValueTxBx" Grid.Column="1" Grid.Row="1"
|
<EgtWPFLib:EgtTextBox Name="ValueTxBx" Grid.Column="1" Grid.Row="1"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
|
<ComboBox Name="ValueCmBx" Grid.Column="1" Grid.Row="1">
|
||||||
|
<ComboBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<TextBlock Text="{Binding}" FontSize="20" />
|
||||||
|
</DataTemplate>
|
||||||
|
</ComboBox.ItemTemplate>
|
||||||
|
</ComboBox>
|
||||||
|
|
||||||
<Grid Name="ButtonsGrid" Grid.Column="1" Grid.Row="3" Grid.RowSpan="1">
|
<Grid Name="ButtonsGrid" Grid.Column="1" Grid.Row="3" Grid.RowSpan="1">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="0.5*"/>
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
Imports System.IO
|
Imports System.IO
|
||||||
Imports EgtUILib
|
Imports EgtUILib
|
||||||
Imports EgtWPFLib
|
Imports EgtWPFLib
|
||||||
|
Imports System.Collections.ObjectModel
|
||||||
|
|
||||||
Public Class EditValueWD
|
Public Class EditValueWD
|
||||||
|
|
||||||
@@ -8,29 +9,77 @@ Public Class EditValueWD
|
|||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Private m_sMsg As String = "Value"
|
Private m_sMsg As String = "Value"
|
||||||
Private m_sValue As String = ""
|
Private m_sValue As String = ""
|
||||||
|
Private m_sList As ObservableCollection(Of String)
|
||||||
|
Private m_IsText As Boolean = True
|
||||||
|
|
||||||
|
' avvia la visualizzazione della textbox
|
||||||
Sub New(Owner As Window, Optional sMsg As String = "")
|
Sub New(Owner As Window, Optional sMsg As String = "")
|
||||||
Me.Owner = Owner
|
Me.Owner = Owner
|
||||||
m_sMsg = sMsg
|
m_sMsg = sMsg
|
||||||
|
m_IsText = True
|
||||||
InitializeComponent()
|
InitializeComponent()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Function SetVal( dVal As Double) As Boolean
|
Friend Function SetVal(dVal As Double, Optional ByVal bLen As Boolean = False) As Boolean
|
||||||
|
If bLen Then
|
||||||
|
m_sValue = LenToString(dVal, 3)
|
||||||
|
Else
|
||||||
m_sValue = DoubleToString(dVal, 3)
|
m_sValue = DoubleToString(dVal, 3)
|
||||||
|
End If
|
||||||
ValueTxBx.Text = m_sValue
|
ValueTxBx.Text = m_sValue
|
||||||
Return true
|
Return True
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
Friend Function GetVal() As Double
|
' avvia la visualizzazione della combobox
|
||||||
|
Sub New(Owner As Window, sList As ObservableCollection(Of String), Optional sMsg As String = "")
|
||||||
|
Me.Owner = Owner
|
||||||
|
m_sMsg = sMsg
|
||||||
|
m_IsText = False
|
||||||
|
InitializeComponent()
|
||||||
|
m_sList = sList
|
||||||
|
SetComboBox(m_sList)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Friend Function GetVal(Optional ByVal bLen As Boolean = False) As Double
|
||||||
Dim dVal As Double = 0
|
Dim dVal As Double = 0
|
||||||
|
If bLen Then
|
||||||
|
StringToLen(m_sValue, dVal)
|
||||||
|
Else
|
||||||
StringToDouble(m_sValue, dVal)
|
StringToDouble(m_sValue, dVal)
|
||||||
|
End If
|
||||||
Return dVal
|
Return dVal
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
Friend Function SetComboBox(sList As ObservableCollection(Of String)) As Boolean
|
||||||
|
ValueCmBx.ItemsSource = sList
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Friend Function SetItemComboBox(sItem As String) As Boolean
|
||||||
|
For Each MyItem As String In ValueCmBx.ItemsSource
|
||||||
|
If MyItem = sItem Then
|
||||||
|
ValueCmBx.SelectedItem = MyItem
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Friend Function GetItemComboBox() As String
|
||||||
|
Dim sVal As String = ValueCmBx.SelectedItem
|
||||||
|
Return sVal
|
||||||
|
End Function
|
||||||
|
|
||||||
Private Sub EditValueWD_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
Private Sub EditValueWD_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
Me.Top = Owner.Top + Owner.Height / 2 - Me.Height / 2
|
Me.Top = Owner.Top + Owner.Height / 2 - Me.Height / 2
|
||||||
Me.Left = Owner.Left + Owner.Width / 2 - Me.Width / 2
|
Me.Left = Owner.Left + Owner.Width / 2 - Me.Width / 2
|
||||||
ValueTxbl.Text = m_sMsg
|
ValueTxbl.Text = m_sMsg
|
||||||
|
If m_IsText Then
|
||||||
|
ValueCmBx.Visibility = Visibility.Collapsed
|
||||||
|
ValueTxBx.Visibility = Visibility.Visible
|
||||||
|
Else
|
||||||
|
ValueCmBx.Visibility = Visibility.Visible
|
||||||
|
ValueTxBx.Visibility = Visibility.Collapsed
|
||||||
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub EditValueWD_Rendered(sender As Object, e As EventArgs) Handles Me.ContentRendered
|
Private Sub EditValueWD_Rendered(sender As Object, e As EventArgs) Handles Me.ContentRendered
|
||||||
|
|||||||
@@ -120,7 +120,7 @@
|
|||||||
<ColumnDefinition Width="Auto"/>
|
<ColumnDefinition Width="Auto"/>
|
||||||
<ColumnDefinition Width="Auto"/>
|
<ColumnDefinition Width="Auto"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<EgtWPFLib:EgtTextBox Name="RotationAngleTxBx" Width="50"
|
<EgtWPFLib:EgtTextBox Name="RotationAngleTxBx" Width="50" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
<TextBlock Grid.Column="1" FontSize="30" Margin="2,-5,0,0"
|
<TextBlock Grid.Column="1" FontSize="30" Margin="2,-5,0,0"
|
||||||
Text="°"/>
|
Text="°"/>
|
||||||
@@ -132,8 +132,15 @@
|
|||||||
VerticalAlignment="Center" />
|
VerticalAlignment="Center" />
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
|
<!--Gestione sfridi-->
|
||||||
|
<Button Name="RemovePartBtn" Grid.ColumnSpan="2" Grid.Row="6"
|
||||||
|
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
||||||
|
|
||||||
<Button Name="RemovePartBtn" Grid.ColumnSpan="3" Grid.Row="6"
|
<Button Name="ScrapsBtn" Grid.Column="3" Grid.Row="6"
|
||||||
|
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
||||||
|
|
||||||
|
<!--Gestione scarico pezzi-->
|
||||||
|
<Button Name="UnloadPartsBtn" Grid.ColumnSpan="2" Grid.Row="7"
|
||||||
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
||||||
|
|
||||||
<Grid Grid.Row="7" Grid.ColumnSpan="3">
|
<Grid Grid.Row="7" Grid.ColumnSpan="3">
|
||||||
@@ -155,8 +162,10 @@
|
|||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="10*"/>
|
<ColumnDefinition Width="10*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
<!-- Inserimento della pausa durante il movimento sulla tavola di scarico-->
|
||||||
|
<Button Name="PauseBtn" Grid.Column="1" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Image Source="{DynamicResource Pausa-ON_OFFImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
Imports EgtUILib
|
Imports System.Windows.Forms.Integration
|
||||||
|
Imports EgtUILib
|
||||||
|
|
||||||
Public Class MoveRawPartPage
|
Public Class MoveRawPartPage
|
||||||
' Riferimento alla MainWindow
|
' Riferimento alla MainWindow
|
||||||
@@ -11,8 +12,12 @@ Public Class MoveRawPartPage
|
|||||||
Private m_nAuxTabId As Integer = GDB_ID.NULL
|
Private m_nAuxTabId As Integer = GDB_ID.NULL
|
||||||
' Fase corrente
|
' Fase corrente
|
||||||
Private m_nCurrPhase As Integer = 0
|
Private m_nCurrPhase As Integer = 0
|
||||||
|
' Disposizione corrente
|
||||||
|
Private m_nCurrDisposition As Integer = GDB_ID.NULL
|
||||||
' Premuto Prev
|
' Premuto Prev
|
||||||
Private m_bPrev As Boolean = False
|
Private m_bPrev As Boolean = False
|
||||||
|
' Pemuto Next
|
||||||
|
Private m_bToNext As Boolean = False
|
||||||
' Dati movimento
|
' Dati movimento
|
||||||
Private m_dStep As Double = 0
|
Private m_dStep As Double = 0
|
||||||
Private m_dRotation As Double = 0
|
Private m_dRotation As Double = 0
|
||||||
@@ -27,20 +32,28 @@ Public Class MoveRawPartPage
|
|||||||
Private m_bRemovedRaw As Boolean = False ' flag per rimozione manuale pezzi
|
Private m_bRemovedRaw As Boolean = False ' flag per rimozione manuale pezzi
|
||||||
Private m_RawMoveDataList As New List(Of RawMoveData) ' dati di movimento
|
Private m_RawMoveDataList As New List(Of RawMoveData) ' dati di movimento
|
||||||
Private m_bRawWithCups As Boolean = False ' flag per pezzo corrente con ventose
|
Private m_bRawWithCups As Boolean = False ' flag per pezzo corrente con ventose
|
||||||
|
' Visibilità comando Scrap
|
||||||
|
Private m_ScrapsVisibility As Visibility = Visibility.Visible
|
||||||
Private m_CurrRawOnVacuum As Integer = GDB_ID.NULL
|
Private m_CurrRawOnVacuum As Integer = GDB_ID.NULL
|
||||||
|
|
||||||
|
' definisce se è stata inserito uno scarico
|
||||||
|
Private m_IsCurrPhaseUnloaded As Boolean = False
|
||||||
|
|
||||||
Private Sub MoveRawPartPage_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
Private Sub MoveRawPartPage_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
' Assegno testi
|
' Assegno testi
|
||||||
RemovePartBtn.Content = EgtMsg(MSG_MOVERAWPAGEUC + 1) 'Rimuovi
|
RemovePartBtn.Content = EgtMsg(MSG_MOVERAWPAGEUC + 1) 'Rimuovi
|
||||||
ModifyBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 17) 'Modifica
|
ModifyBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 17) 'Modifica
|
||||||
ResetBtn.Content = EgtMsg(MSG_NESTPAGEUC + 6) 'Reset
|
ResetBtn.Content = EgtMsg(MSG_NESTPAGEUC + 6) 'Reset
|
||||||
|
ScrapsBtn.Content = "Add Scraps"
|
||||||
|
UnloadPartsBtn.Content = "Move part"
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub MoveRawPartPage_Loaded(sender As Object, e As EventArgs) Handles Me.Loaded
|
Private Sub MoveRawPartPage_Loaded(sender As Object, e As EventArgs) Handles Me.Loaded
|
||||||
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
||||||
m_SplitPage = m_MainWindow.m_CadCutPageUC.m_SplitPage
|
m_SplitPage = m_MainWindow.m_CadCutPageUC.m_SplitPage
|
||||||
m_bActive = True
|
m_bActive = True
|
||||||
|
' resetto l'inidice del pezzo da mnovimentare
|
||||||
|
m_CurrRawOnVacuum = GDB_ID.NULL
|
||||||
' Leggo tipo movimento grezzi
|
' Leggo tipo movimento grezzi
|
||||||
m_bByHand = (GetVacuumType() = 0 Or
|
m_bByHand = (GetVacuumType() = 0 Or
|
||||||
Not m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.AUTO_MANIP) Or
|
Not m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.AUTO_MANIP) Or
|
||||||
@@ -52,48 +65,73 @@ Public Class MoveRawPartPage
|
|||||||
End If
|
End If
|
||||||
' Deseleziono tutto
|
' Deseleziono tutto
|
||||||
EgtDeselectAll()
|
EgtDeselectAll()
|
||||||
' Recupero i tagli allungati prima definiti
|
' resetto variabili di navigazione nelle fasi
|
||||||
|
m_bPrev = False
|
||||||
|
m_bToNext = False
|
||||||
|
|
||||||
|
'---------------------------- CREATE NEW PHASE ----------------------------
|
||||||
|
' Recupero i tagli ABILITATI prima definiti
|
||||||
Dim Cuts(0) As Integer
|
Dim Cuts(0) As Integer
|
||||||
m_SplitPage.GetEnabledCuts(Cuts)
|
m_SplitPage.GetEnabledCuts(Cuts)
|
||||||
' Fase precedente
|
' Fase precedente
|
||||||
Dim nPrevPhase As Integer = EgtGetCurrPhase()
|
Dim nPrevPhase As Integer = EgtGetCurrPhase()
|
||||||
If Not m_SplitPage.m_bShow Then
|
|
||||||
' Creo nuova fase, eseguo spezzatura grezzi e vi sposto le lavorazioni
|
' Creo nuova fase, eseguo spezzatura grezzi e vi sposto le lavorazioni
|
||||||
Dim vNewRaws As New List(Of Integer)
|
Dim vNewRaws As New List(Of Integer)
|
||||||
|
If Not m_SplitPage.m_bShow Then
|
||||||
SplitRawParts(nPrevPhase, Cuts, vNewRaws)
|
SplitRawParts(nPrevPhase, Cuts, vNewRaws)
|
||||||
|
m_IsCurrPhaseUnloaded = False
|
||||||
Else
|
Else
|
||||||
EgtSetCurrPhase(nPrevPhase + 1)
|
nPrevPhase = nPrevPhase + 1
|
||||||
|
EgtSetCurrPhase(nPrevPhase)
|
||||||
HideAllMachinings()
|
HideAllMachinings()
|
||||||
|
' verifico se la fase corrente è di tipo scarico frontale
|
||||||
|
m_nCurrDisposition = EgtGetPhaseDisposition(nPrevPhase)
|
||||||
|
If IsDispUnloadOnAuxTab(m_nCurrDisposition) Then
|
||||||
|
m_SplitPage.m_bOnAuxTab = True
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
m_nCurrPhase = EgtGetCurrPhase()
|
m_nCurrPhase = EgtGetCurrPhase()
|
||||||
' Se movimento pezzi finale, sistemazioni per tavolo ausiliario
|
'---------------------------- CREATE NEW PHASE ----------------------------
|
||||||
If m_SplitPage.m_bOnAuxTab Then
|
|
||||||
m_nAuxTabId = EgtGetTableId(AUX_TAB)
|
'---------------------------- SCRAPS ----------------------------
|
||||||
' Visualizzo tavolo ausiliario
|
' gestione visualizzazione del comando "Scraps"
|
||||||
Dim bOldEnMod As Boolean = EgtGetEnableModified()
|
Dim ScrapsVisibility As Visibility = Visibility.Collapsed
|
||||||
If bOldEnMod Then EgtDisableModified()
|
' verifico se licenza abilitat: m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.SCRAPS)
|
||||||
EgtSetStatus(m_nAuxTabId, GDB_ST.ON_)
|
If GetPrivateProfileInt(S_SCRAPS, K_ENABLESCRAPS, 0, m_MainWindow.GetIniFile()) <> 0 Then
|
||||||
If bOldEnMod Then EgtEnableModified()
|
' leggo il direttorio in cui cercare il database delle lastre
|
||||||
' Se definizione movimenti
|
Dim PhotDir As String = String.Empty
|
||||||
If Not m_SplitPage.m_bShow Then
|
GetPrivateProfileString(S_SCRAPS, K_PHOTODIR, "", PhotDir, m_MainWindow.GetIniFile())
|
||||||
' Area tavolo ausiliario
|
' verifico che esista il file "OmagPHOTOVb.sqlite" nel direttorio inidicato
|
||||||
Dim b3AuxTab As New BBox3d
|
If System.IO.File.Exists(PhotDir.Trim & "\OmagPHOTODb.sqlite") Then
|
||||||
EgtGetBBoxGlob(EgtGetFirstNameInGroup(m_nAuxTabId, "A1"), GDB_BB.STANDARD, b3AuxTab)
|
ScrapsVisibility = Visibility.Visible
|
||||||
' Area tavolo principale
|
|
||||||
Dim b3Tab As New BBox3d
|
|
||||||
EgtGetTableArea(1, b3Tab)
|
|
||||||
' Imposto offset su tavolo principale per includere anche il secondario
|
|
||||||
Dim dOffsXP As Double = Math.Max(b3AuxTab.Max().x - b3Tab.Max().x, 0)
|
|
||||||
Dim dOffsYP As Double = Math.Max(b3AuxTab.Max().y - b3Tab.Max().y, 0)
|
|
||||||
Dim dOffsXM As Double = Math.Max(b3Tab.Min().x - b3AuxTab.Min().x, 0)
|
|
||||||
Dim dOffsYM As Double = Math.Max(b3Tab.Min().y - b3AuxTab.Min().y, 0)
|
|
||||||
EgtSetTableAreaOffset(dOffsXP, dOffsYP, dOffsXM, dOffsYM)
|
|
||||||
End If
|
End If
|
||||||
EgtZoom(ZM.ALL)
|
End If
|
||||||
' altrimenti, aggiorno visualizzazione
|
' verifico che siano stati generati dei nuovi grezzi
|
||||||
|
If vNewRaws.Count = 0 Then
|
||||||
|
ScrapsVisibility = Visibility.Collapsed
|
||||||
|
End If
|
||||||
|
' aggiorno la grafica
|
||||||
|
m_ScrapsVisibility = ScrapsVisibility
|
||||||
|
If m_ScrapsVisibility <> Visibility.Visible Then
|
||||||
|
Grid.SetColumnSpan(RemovePartBtn, 3)
|
||||||
Else
|
Else
|
||||||
EgtDraw()
|
Grid.SetColumnSpan(RemovePartBtn, 2)
|
||||||
End If
|
End If
|
||||||
|
'---------------------------- SCRAPS ----------------------------
|
||||||
|
|
||||||
|
'---------------------------- AUX TABLE ----------------------------
|
||||||
|
' Se movimento pezzi finale, sistemazioni per tavolo ausiliario
|
||||||
|
If m_SplitPage.m_bOnAuxTab And m_SplitPage.m_bEnableOnAuxTab Then
|
||||||
|
' assegnazione delle info tavola ausiliaria alla dispozione corrente (Spostato nella funzione Refresh)
|
||||||
|
SetAuxTabInCurrDisposition()
|
||||||
|
UnloadPartsBtn.Content = "Go to MOVE part"
|
||||||
|
' altrimenti, aggiorno visualizzazione
|
||||||
|
ElseIf Not m_SplitPage.m_bOnAuxTab And m_SplitPage.m_bEnableOnAuxTab Then
|
||||||
|
EgtDraw()
|
||||||
|
UnloadPartsBtn.Content = "Go to UNLOAD part"
|
||||||
|
End If
|
||||||
|
'---------------------------- AUX TABLE ----------------------------
|
||||||
|
|
||||||
' Carico i parametri di movimento
|
' Carico i parametri di movimento
|
||||||
m_dStep = GetPrivateProfileDouble(S_RAWMOVE, K_RAWSTEP, 50, m_MainWindow.GetIniFile())
|
m_dStep = GetPrivateProfileDouble(S_RAWMOVE, K_RAWSTEP, 50, m_MainWindow.GetIniFile())
|
||||||
' Ricavo la lunghezza del baffo di taglio
|
' Ricavo la lunghezza del baffo di taglio
|
||||||
@@ -149,6 +187,33 @@ Public Class MoveRawPartPage
|
|||||||
GetMoveInfoInDisposition(nDispId, m_RawMoveDataList)
|
GetMoveInfoInDisposition(nDispId, m_RawMoveDataList)
|
||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' aggiorno il messaggio del comando per gestire gli sfridi
|
||||||
|
VerifyIsNewScrap(m_CurrRawOnVacuum)
|
||||||
|
' aggiorno la visibilità dei comandi
|
||||||
|
RefreshVisibility()
|
||||||
|
' salvo l'idice della fase corrente
|
||||||
|
m_nCurrDisposition = EgtGetPhaseDisposition(m_nCurrPhase)
|
||||||
|
' Abilitazione bottone modifica
|
||||||
|
ModifyBtn.IsEnabled = m_SplitPage.m_bShow
|
||||||
|
' gestione abilitazione altri bottoni
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' Gestione di visualizzazione dei comandi per il movimento dei pezzi
|
||||||
|
Private Sub RefreshVisibility()
|
||||||
|
' Aggiorno visulizzazione comando per passare alla pagina di scarico
|
||||||
|
If Not m_SplitPage.m_bEnableOnAuxTab Then
|
||||||
|
UnloadPartsBtn.Visibility = Visibility.Hidden
|
||||||
|
Else
|
||||||
|
UnloadPartsBtn.Visibility = Visibility.Visible
|
||||||
|
If m_SplitPage.m_bOnAuxTab Then
|
||||||
|
UnloadPartsBtn.Content = "Go to MOVE part"
|
||||||
|
' altrimenti, aggiorno visualizzazione
|
||||||
|
Else
|
||||||
|
UnloadPartsBtn.Content = "Go to UNLOAD part"
|
||||||
|
End If
|
||||||
|
End If
|
||||||
' Aggiorno interfaccia per taglio perpendicolare
|
' Aggiorno interfaccia per taglio perpendicolare
|
||||||
If m_bByHand Then
|
If m_bByHand Then
|
||||||
UpBtn.Visibility = Windows.Visibility.Visible
|
UpBtn.Visibility = Windows.Visibility.Visible
|
||||||
@@ -164,7 +229,9 @@ Public Class MoveRawPartPage
|
|||||||
TopRBtn.Visibility = Windows.Visibility.Hidden
|
TopRBtn.Visibility = Windows.Visibility.Hidden
|
||||||
BottomLBtn.Visibility = Windows.Visibility.Hidden
|
BottomLBtn.Visibility = Windows.Visibility.Hidden
|
||||||
BottomRBtn.Visibility = Windows.Visibility.Hidden
|
BottomRBtn.Visibility = Windows.Visibility.Hidden
|
||||||
|
PauseBtn.Visibility = Windows.Visibility.Hidden
|
||||||
ResetBtn.Visibility = Windows.Visibility.Hidden
|
ResetBtn.Visibility = Windows.Visibility.Hidden
|
||||||
|
ScrapsBtn.Visibility = m_ScrapsVisibility
|
||||||
' altrimenti per movimento con ventose
|
' altrimenti per movimento con ventose
|
||||||
ElseIf Not m_SplitPage.m_bOnAuxTab Then
|
ElseIf Not m_SplitPage.m_bOnAuxTab Then
|
||||||
UpBtn.Visibility = Windows.Visibility.Visible
|
UpBtn.Visibility = Windows.Visibility.Visible
|
||||||
@@ -180,7 +247,9 @@ Public Class MoveRawPartPage
|
|||||||
TopRBtn.Visibility = Windows.Visibility.Hidden
|
TopRBtn.Visibility = Windows.Visibility.Hidden
|
||||||
BottomLBtn.Visibility = Windows.Visibility.Hidden
|
BottomLBtn.Visibility = Windows.Visibility.Hidden
|
||||||
BottomRBtn.Visibility = Windows.Visibility.Hidden
|
BottomRBtn.Visibility = Windows.Visibility.Hidden
|
||||||
|
PauseBtn.Visibility = Windows.Visibility.Hidden
|
||||||
ResetBtn.Visibility = Windows.Visibility.Hidden
|
ResetBtn.Visibility = Windows.Visibility.Hidden
|
||||||
|
ScrapsBtn.Visibility = m_ScrapsVisibility
|
||||||
' altrimenti per movimento finale dei pezzi
|
' altrimenti per movimento finale dei pezzi
|
||||||
Else
|
Else
|
||||||
UpBtn.Visibility = Windows.Visibility.Hidden
|
UpBtn.Visibility = Windows.Visibility.Hidden
|
||||||
@@ -196,12 +265,37 @@ Public Class MoveRawPartPage
|
|||||||
TopRBtn.Visibility = Windows.Visibility.Visible
|
TopRBtn.Visibility = Windows.Visibility.Visible
|
||||||
BottomLBtn.Visibility = Windows.Visibility.Visible
|
BottomLBtn.Visibility = Windows.Visibility.Visible
|
||||||
BottomRBtn.Visibility = Windows.Visibility.Visible
|
BottomRBtn.Visibility = Windows.Visibility.Visible
|
||||||
|
PauseBtn.Visibility = Windows.Visibility.Visible
|
||||||
ResetBtn.Visibility = Windows.Visibility.Visible
|
ResetBtn.Visibility = Windows.Visibility.Visible
|
||||||
|
ScrapsBtn.Visibility = Windows.Visibility.Hidden
|
||||||
End If
|
End If
|
||||||
' Abilitazione bottone modifica
|
End Sub
|
||||||
ModifyBtn.IsEnabled = m_SplitPage.m_bShow
|
|
||||||
' gestione abilitazione altri bottoni
|
Private Sub SetAuxTabInCurrDisposition()
|
||||||
EnableButtons()
|
' Se movimento pezzi finale, sistemazioni per tavolo ausiliario
|
||||||
|
m_nAuxTabId = EgtGetTableId(AUX_TAB)
|
||||||
|
' Visualizzo tavolo ausiliario
|
||||||
|
Dim bOldEnMod As Boolean = EgtGetEnableModified()
|
||||||
|
If bOldEnMod Then EgtDisableModified()
|
||||||
|
EgtSetStatus(m_nAuxTabId, GDB_ST.ON_)
|
||||||
|
If bOldEnMod Then EgtEnableModified()
|
||||||
|
' Se definizione movimenti
|
||||||
|
If Not m_SplitPage.m_bShow Then
|
||||||
|
' Area tavolo ausiliario
|
||||||
|
Dim b3AuxTab As New BBox3d
|
||||||
|
EgtGetBBoxGlob(EgtGetFirstNameInGroup(m_nAuxTabId, "A1"), GDB_BB.STANDARD, b3AuxTab)
|
||||||
|
' Area tavolo principale
|
||||||
|
Dim b3Tab As New BBox3d
|
||||||
|
EgtGetTableArea(1, b3Tab)
|
||||||
|
' Imposto offset su tavolo principale per includere anche il secondario
|
||||||
|
Dim dOffsXP As Double = Math.Max(b3AuxTab.Max().x - b3Tab.Max().x, 0)
|
||||||
|
Dim dOffsYP As Double = Math.Max(b3AuxTab.Max().y - b3Tab.Max().y, 0)
|
||||||
|
Dim dOffsXM As Double = Math.Max(b3Tab.Min().x - b3AuxTab.Min().x, 0)
|
||||||
|
Dim dOffsYM As Double = Math.Max(b3Tab.Min().y - b3AuxTab.Min().y, 0)
|
||||||
|
EgtSetTableAreaOffset(dOffsXP, dOffsYP, dOffsXM, dOffsYM)
|
||||||
|
End If
|
||||||
|
EgtZoom(ZM.ALL)
|
||||||
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub OnMyMouseDownScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseDownScene
|
Private Sub OnMyMouseDownScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseDownScene
|
||||||
@@ -232,10 +326,12 @@ Public Class MoveRawPartPage
|
|||||||
If nParentId = nRawGroupId Then
|
If nParentId = nRawGroupId Then
|
||||||
Dim nStat As Integer = GDB_ST.ON_
|
Dim nStat As Integer = GDB_ST.ON_
|
||||||
EgtGetStatus(nId, nStat)
|
EgtGetStatus(nId, nStat)
|
||||||
|
' aggiorno il messaggio del bottone "Scrap" a seconda che il grezzo sia già uno scrap
|
||||||
|
VerifyIsNewScrap(nId)
|
||||||
' Se il pezzo corrente è selezionato allora lo disattivo -> deposito del pezzo
|
' Se il pezzo corrente è selezionato allora lo disattivo -> deposito del pezzo
|
||||||
If nStat = GDB_ST.SEL Then
|
If nStat = GDB_ST.SEL Then
|
||||||
EgtSetStatus(nId, GDB_ST.ON_)
|
EgtSetStatus(nId, GDB_ST.ON_)
|
||||||
' prima di rilasciare il pezzo verifico che non vada in collisione con altri pezzi sulla tavola
|
' prima di rilasciare il pezzo verifico che non vada in collisione con altri pezzi sulla tavola (evito il controllo se ultima fase)
|
||||||
If VerifyCollisionWithOtherRawPart(nId) Then
|
If VerifyCollisionWithOtherRawPart(nId) Then
|
||||||
' mantengo la selezione del pezzo
|
' mantengo la selezione del pezzo
|
||||||
EgtSetStatus(nId, GDB_ST.SEL)
|
EgtSetStatus(nId, GDB_ST.SEL)
|
||||||
@@ -271,9 +367,9 @@ Public Class MoveRawPartPage
|
|||||||
MaxDoublePlugger = GetPrivateProfileDouble(S_MACH_RAWMOVE, K_MACH_WEIGHT_DOUBLEPLUGGER, MaxDoublePlugger, m_MainWindow.GetMachIniFile())
|
MaxDoublePlugger = GetPrivateProfileDouble(S_MACH_RAWMOVE, K_MACH_WEIGHT_DOUBLEPLUGGER, MaxDoublePlugger, m_MainWindow.GetMachIniFile())
|
||||||
Dim AverageDensity As Double = 2700
|
Dim AverageDensity As Double = 2700
|
||||||
AverageDensity = GetPrivateProfileDouble(S_MATERIALS, K_AVERAGEDENSITY, AverageDensity, m_MainWindow.GetMachIniFile())
|
AverageDensity = GetPrivateProfileDouble(S_MATERIALS, K_AVERAGEDENSITY, AverageDensity, m_MainWindow.GetMachIniFile())
|
||||||
VacuumCups.GetWeightInformation(AverageDensity, MaxSinglePlugger, MaxDoublePlugger)
|
VacuumCups.SetWeightInformation(AverageDensity, MaxSinglePlugger, MaxDoublePlugger)
|
||||||
VacuumCups.GetRotationForExtraStrokeY(GetPrivateProfileInt(S_MACH_RAWMOVE, K_MACH_ROTATEVACUUMFOREXTRASTROKEY, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
VacuumCups.SetRotationForExtraStrokeY(GetPrivateProfileInt(S_MACH_RAWMOVE, K_MACH_ROTATEVACUUMFOREXTRASTROKEY, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
VacuumCups.GetRotationForExtraStrokeX(GetPrivateProfileInt(S_MACH_RAWMOVE, K_MACH_ROTATEVACUUMFOREXTRASTROKEX, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
VacuumCups.SetRotationForExtraStrokeX(GetPrivateProfileInt(S_MACH_RAWMOVE, K_MACH_ROTATEVACUUMFOREXTRASTROKEX, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
If PutVacuumCupsOnRaw(nId, rmData) Then
|
If PutVacuumCupsOnRaw(nId, rmData) Then
|
||||||
' Visualizzo le ventose
|
' Visualizzo le ventose
|
||||||
EgtSetStatus(GetVacuumId(), GDB_ST.ON_)
|
EgtSetStatus(GetVacuumId(), GDB_ST.ON_)
|
||||||
@@ -316,6 +412,8 @@ Public Class MoveRawPartPage
|
|||||||
|
|
||||||
' Veririfica che il grezzo non entri in colliosione con altri pezzi
|
' Veririfica che il grezzo non entri in colliosione con altri pezzi
|
||||||
Private Function VerifyCollisionWithOtherRawPart(nIdOnVacumm As Integer) As Boolean
|
Private Function VerifyCollisionWithOtherRawPart(nIdOnVacumm As Integer) As Boolean
|
||||||
|
' se movimento su tavola di scarico non eseguo il controllo (evito di segnalre errori per pezzi ricavati interni al grezzo...)
|
||||||
|
If m_SplitPage.m_bOnAuxTab Then Return False
|
||||||
If nIdOnVacumm = GDB_ID.NULL Then Return False
|
If nIdOnVacumm = GDB_ID.NULL Then Return False
|
||||||
' Creo gruppo temporaneo in cui generare le superfici per la veririfica di collisione
|
' Creo gruppo temporaneo in cui generare le superfici per la veririfica di collisione
|
||||||
Dim m_nTempId As Integer = EgtCreateGroup(GDB_ID.ROOT)
|
Dim m_nTempId As Integer = EgtCreateGroup(GDB_ID.ROOT)
|
||||||
@@ -347,6 +445,27 @@ Public Class MoveRawPartPage
|
|||||||
Return False
|
Return False
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
Private Function VerifyIsNewScrap(nMyId As Integer) As Boolean
|
||||||
|
Dim nVal As Integer = 0
|
||||||
|
If EgtGetInfo(nMyId, K_ISNEWSCRAPS, nVal) Then
|
||||||
|
If nVal = 1 Or nVal = 2 Then
|
||||||
|
' 1 → è stato definito come nuovo grezzo oppure, 2 → è stato definito come nuovo grezzo ed è stato inserito nel DB delle lastre
|
||||||
|
ScrapsBtn.Content = "Remove Scrap"
|
||||||
|
ScrapsBtn.IsEnabled = True And Not m_SplitPage.m_bShow
|
||||||
|
Return True
|
||||||
|
ElseIf nVal = 3 Then
|
||||||
|
' non è possibile rimuovere il grezzo in questa fase
|
||||||
|
ScrapsBtn.Content = "Defined as Scrap"
|
||||||
|
ScrapsBtn.IsEnabled = False
|
||||||
|
Return True
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' non è un nuovo grezzo
|
||||||
|
ScrapsBtn.Content = "Add Scrap"
|
||||||
|
ScrapsBtn.IsEnabled = True And Not m_SplitPage.m_bShow
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
#Region "Move Up/Down/Left/Right"
|
#Region "Move Up/Down/Left/Right"
|
||||||
|
|
||||||
Private Sub UpBtn_Click(sender As Object, e As RoutedEventArgs) Handles UpBtn.Click
|
Private Sub UpBtn_Click(sender As Object, e As RoutedEventArgs) Handles UpBtn.Click
|
||||||
@@ -679,6 +798,56 @@ Public Class MoveRawPartPage
|
|||||||
EgtDraw()
|
EgtDraw()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ScrapsBtn_Click(Sender As Object, e As RoutedEventArgs) Handles ScrapsBtn.Click
|
||||||
|
Dim nRawId As Integer = EgtGetFirstSelectedObj()
|
||||||
|
While nRawId <> GDB_ID.NULL
|
||||||
|
' verifico che il grezzo non contenga dei pezzi (altrimenti non risulta selezionabile)
|
||||||
|
Dim nPartInRaw As Integer = EgtGetFirstPartInRawPart(nRawId)
|
||||||
|
If nPartInRaw = GDB_ID.NULL Then
|
||||||
|
If Not VerifyIsNewScrap(nRawId) Then
|
||||||
|
EgtSetInfo(nRawId, K_ISNEWSCRAPS, "1")
|
||||||
|
Else
|
||||||
|
EgtRemoveInfo(nRawId, K_ISNEWSCRAPS)
|
||||||
|
End If
|
||||||
|
' aggiorno il contenuto del bottone
|
||||||
|
VerifyIsNewScrap(nRawId)
|
||||||
|
Else
|
||||||
|
' coumico che il grezzo contiene un pezzo e quindi non può essere definito come grezzo
|
||||||
|
m_CurrProjPage.ClearMessage()
|
||||||
|
m_CurrProjPage.SetErrorMessage("Part inside raw!")
|
||||||
|
End If
|
||||||
|
' passo al grezzo succesivo (NON dovrebbero esserci altri grezzi selezionabili contemporaneamente!)
|
||||||
|
nRawId = EgtGetNextSelectedObj()
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' Passo dalla pagina di movimento dei pezzi alla pagina di scarico
|
||||||
|
Private Sub UnloadPartBtn_Click() Handles UnloadPartsBtn.Click
|
||||||
|
' forzo lo stato di scarico frontale oppure di movimento
|
||||||
|
m_SplitPage.m_bOnAuxTab = Not m_SplitPage.m_bOnAuxTab
|
||||||
|
|
||||||
|
' se rientro nella fase di spostamenti allora nascondo la tavola di scarico
|
||||||
|
If Not m_SplitPage.m_bOnAuxTab Then
|
||||||
|
' se ci sono pezzi sulla tavola di scarico non posso nasconderla
|
||||||
|
Dim LclLstOfUnldPart As New List(Of Integer)
|
||||||
|
If Not PartOnAuxTab(LclLstOfUnldPart, m_nCurrPhase) Then
|
||||||
|
EgtDisableModified()
|
||||||
|
' nascondo la tavola di scarico
|
||||||
|
EgtSetStatus(m_nAuxTabId, GDB_ST.OFF)
|
||||||
|
' Nascondo eventuali pezzi in parcheggio
|
||||||
|
HideParkedParts()
|
||||||
|
EgtEnableModified()
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
' Assegnazione delle info tavola ausiliaria alla dispozione corrente
|
||||||
|
SetAuxTabInCurrDisposition()
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Mantengo la fase che è stata creata e passo a gestire solo la visualizzazione dei bottoni
|
||||||
|
RefreshVisibility()
|
||||||
|
EgtZoom(ZM.ALL, True)
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub StepMoveTxBx_EgtClosed(sender As Object, e As EventArgs) Handles StepMoveTxBx.EgtClosed
|
Private Sub StepMoveTxBx_EgtClosed(sender As Object, e As EventArgs) Handles StepMoveTxBx.EgtClosed
|
||||||
Dim dStep As Double
|
Dim dStep As Double
|
||||||
If StringToLen(StepMoveTxBx.Text, dStep) Then
|
If StringToLen(StepMoveTxBx.Text, dStep) Then
|
||||||
@@ -721,7 +890,7 @@ Public Class MoveRawPartPage
|
|||||||
If Not EgtGetInfo(nRefId, "Pos", ptRef) Then Return
|
If Not EgtGetInfo(nRefId, "Pos", ptRef) Then Return
|
||||||
Dim sCorn As String = ""
|
Dim sCorn As String = ""
|
||||||
EgtGetInfo(nRefId, "COR", sCorn)
|
EgtGetInfo(nRefId, "COR", sCorn)
|
||||||
Select sCorn
|
Select Case sCorn
|
||||||
Case "TL"
|
Case "TL"
|
||||||
nCorn = MCH_CR.TL
|
nCorn = MCH_CR.TL
|
||||||
Case "TR"
|
Case "TR"
|
||||||
@@ -736,14 +905,18 @@ Public Class MoveRawPartPage
|
|||||||
EgtGetRawPartCenter(nRawId, ptRawCen)
|
EgtGetRawPartCenter(nRawId, ptRawCen)
|
||||||
' Sposto il grezzo in battuta sul corner
|
' Sposto il grezzo in battuta sul corner
|
||||||
Dim dAngRaw As Double = 0
|
Dim dAngRaw As Double = 0
|
||||||
|
Dim dNewAngRot As Double = 0
|
||||||
|
|
||||||
Dim AngRotList As New List(Of Double)
|
Dim AngRotList As New List(Of Double)
|
||||||
|
|
||||||
' ricavo l'angolo di posizionamento del grezzo/pezzo sulla tavola
|
' ricavo l'angolo di posizionamento del grezzo/pezzo sulla tavola
|
||||||
If Not DispositionRawOnTable(nRawId, dAngRaw, AngRotList) Then Return
|
If Not DispositionRawOnTable(nRawId, dAngRaw, AngRotList) Then Return
|
||||||
|
Dim bb3dRaw As New BBox3d
|
||||||
|
EgtGetRawPartBBox(nRawId, bb3dRaw)
|
||||||
|
Dim ForceToRotate As Boolean = bb3dRaw.DimX < bb3dRaw.DimY
|
||||||
|
|
||||||
' provo a verificare di poter depositare il pezzo (senza applicare delle rotazioni)
|
' provo a verificare di poter depositare il pezzo (senza applicare delle rotazioni)
|
||||||
If Not EgtMoveToCornerRawPart(nRawId, ptRef, nCorn) Then
|
If Not EgtMoveToCornerRawPart(nRawId, ptRef, nCorn) Or ForceToRotate Then
|
||||||
' se sono impostati degli step di rotazione
|
' se sono impostati degli step di rotazione
|
||||||
If AngRotList.Count > 0 Then
|
If AngRotList.Count > 0 Then
|
||||||
Dim bOkRotate As Boolean = False
|
Dim bOkRotate As Boolean = False
|
||||||
@@ -763,12 +936,26 @@ Public Class MoveRawPartPage
|
|||||||
Next
|
Next
|
||||||
If Not bOkRotate Then Return
|
If Not bOkRotate Then Return
|
||||||
Else
|
Else
|
||||||
If EgtRotateRawPart(nRawId, Vector3d.Z_AX(), -dAngRaw) Then
|
' sposto il pezzo in centro tavola → perchè tutti i movimenti sono fatti ruotando il pezzo in centro tavola!
|
||||||
|
Dim b3Area As New BBox3d
|
||||||
|
EgtGetTableArea(1, b3Area)
|
||||||
|
Dim b3RawTemp As New BBox3d
|
||||||
|
EgtGetRawPartBBox(nRawId, b3RawTemp)
|
||||||
|
' ricavo il riferimento dell'angolo in basso a sinstra del grezzo rispetto alla tavola
|
||||||
|
Dim ptCorner As Point3d = New Point3d(b3Area.DimX / 2, b3Area.DimY / 2, 0) - New Vector3d(b3RawTemp.DimX / 2, b3RawTemp.DimY / 2, 0)
|
||||||
|
' sposto il pezzo in questa posizione
|
||||||
|
EgtMoveToCornerRawPart(nRawId, ptCorner, MCH_CR.BL)
|
||||||
|
' riprovo il movimento
|
||||||
|
dNewAngRot = GetPrefRotAng(dAngRaw)
|
||||||
|
'dNewAngRot = DeltaAngC
|
||||||
|
If EgtRotateRawPart(nRawId, Vector3d.Z_AX(), dNewAngRot) Then
|
||||||
If Not EgtMoveToCornerRawPart(nRawId, ptRef, nCorn) Then
|
If Not EgtMoveToCornerRawPart(nRawId, ptRef, nCorn) Then
|
||||||
' riposiziono il pezzo come era prima
|
' riposiziono il pezzo come era prima
|
||||||
EgtRotateRawPart(nRawId, Vector3d.Z_AX(), dAngRaw)
|
EgtRotateRawPart(nRawId, Vector3d.Z_AX(), -dAngRaw)
|
||||||
|
EgtDraw()
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
|
dAngRaw = dNewAngRot
|
||||||
Else
|
Else
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
@@ -794,17 +981,18 @@ Public Class MoveRawPartPage
|
|||||||
End If
|
End If
|
||||||
nOtherRaw = EgtGetNextRawPart(nOtherRaw)
|
nOtherRaw = EgtGetNextRawPart(nOtherRaw)
|
||||||
End While
|
End While
|
||||||
|
|
||||||
' Determino il movimento effettuato
|
' Determino il movimento effettuato
|
||||||
Dim ptNewRawCen As Point3d
|
Dim ptNewRawCen As Point3d
|
||||||
EgtGetRawPartCenter(nRawId, ptNewRawCen)
|
EgtGetRawPartCenter(nRawId, ptNewRawCen)
|
||||||
' Se tutto bene, aggiorno lista movimenti
|
' Se tutto bene, aggiorno lista movimenti
|
||||||
If bRawOk Then
|
If bRawOk Then
|
||||||
AddRawMoveData(nRawId, ptNewRawCen - ptRawCen, m_RawMoveDataList)
|
AddRawMoveData(nRawId, ptNewRawCen - ptRawCen, m_RawMoveDataList)
|
||||||
If dAngRaw <> 0 Then AddRawMoveData(nRawId, -dAngRaw, m_RawMoveDataList)
|
If dAngRaw <> 0 Then AddRawMoveData(nRawId, dAngRaw, m_RawMoveDataList)
|
||||||
' altrimenti annullo il movimento
|
' altrimenti annullo il movimento
|
||||||
Else
|
Else
|
||||||
EgtMoveRawPart(nRawId, ptRawCen - ptNewRawCen)
|
EgtMoveRawPart(nRawId, ptRawCen - ptNewRawCen)
|
||||||
EgtRotateRawPart(nRawId, Vector3d.Z_AX(), dAngRaw)
|
EgtRotateRawPart(nRawId, Vector3d.Z_AX(), -dAngRaw)
|
||||||
m_CurrProjPage.SetWarningMessage(EgtMsg(MSG_MOVERAWPAGEUC + 3)) ' Posizione scelta già occupata
|
m_CurrProjPage.SetWarningMessage(EgtMsg(MSG_MOVERAWPAGEUC + 3)) ' Posizione scelta già occupata
|
||||||
End If
|
End If
|
||||||
' Disabilito pezzo e nascondo le ventose
|
' Disabilito pezzo e nascondo le ventose
|
||||||
@@ -877,6 +1065,137 @@ Public Class MoveRawPartPage
|
|||||||
Return True
|
Return True
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
' determino la migliore rotazione per portare il pezzo in orizzontale
|
||||||
|
Private Function GetPrefRotAng(ByVal dAngDeg As Double) As Double
|
||||||
|
Dim dNewAngDeg As Double = -dAngDeg
|
||||||
|
If dAngDeg > 90 And dAngDeg < 270 Then
|
||||||
|
dNewAngDeg = 180 - dAngDeg
|
||||||
|
End If
|
||||||
|
Return dNewAngDeg
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Private Sub PauseBtn_Click(sender As Object, e As RoutedEventArgs) Handles PauseBtn.Click
|
||||||
|
' verifico la presenza di eventuali pezzi sulla tavola di scarico
|
||||||
|
Dim LclLstOfUnldPart As New List(Of Integer)
|
||||||
|
PartOnAuxTab(LclLstOfUnldPart, m_nCurrPhase)
|
||||||
|
If Not InsertPauseInCurrPhase() Then Return
|
||||||
|
AddNewPhase()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' restituisce la lista dei pezzi che sono sulla tavola di scarico nella fase indicata
|
||||||
|
Private Function PartOnAuxTab(ByRef ListOfUnloadedPatr As List(Of Integer), nPhase As Integer) As Boolean
|
||||||
|
m_IsCurrPhaseUnloaded = False
|
||||||
|
' Area tavolo ausiliario
|
||||||
|
Dim b3AuxTab As New BBox3d
|
||||||
|
EgtGetBBoxGlob(EgtGetFirstNameInGroup(m_nAuxTabId, "A1"), GDB_BB.STANDARD, b3AuxTab)
|
||||||
|
' Area pezzi
|
||||||
|
Dim nOtherRaw As Integer = EgtGetFirstRawPart()
|
||||||
|
While nOtherRaw <> GDB_ID.NULL
|
||||||
|
If EgtVerifyRawPartPhase(nOtherRaw, nPhase) Then
|
||||||
|
Dim b3OtherRaw As New BBox3d
|
||||||
|
' EgtGetRawPartBBox(nOtherRaw, b3OtherRaw)
|
||||||
|
EgtGetBBoxGlob(nOtherRaw, GDB_BB.STANDARD, b3OtherRaw)
|
||||||
|
' se il centro del pezzo è sulla tavola di scarico
|
||||||
|
If b3OtherRaw.Center.y < b3AuxTab.Max().y Then
|
||||||
|
m_IsCurrPhaseUnloaded = True
|
||||||
|
ListOfUnloadedPatr.Add(nOtherRaw)
|
||||||
|
' salvo l'info che indica che il pezzo deve essere scaricato
|
||||||
|
EgtSetInfo(nOtherRaw, "Unloaded", 1)
|
||||||
|
'Exit While
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
nOtherRaw = EgtGetNextRawPart(nOtherRaw)
|
||||||
|
End While
|
||||||
|
Return m_IsCurrPhaseUnloaded
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' inserisce una pausa nella fase corrente
|
||||||
|
Private Function InsertPauseInCurrPhase() As Boolean
|
||||||
|
' verifico che ci sia almeno un elemto selezionato (dati di aggancio pezzo)
|
||||||
|
If m_RawMoveDataList.Count = 0 Then Return False
|
||||||
|
' verifico che sia stato inseito almeno uno spostamento, altrimenti lo rimuovo
|
||||||
|
Dim Index As Integer = 0
|
||||||
|
For Index = m_RawMoveDataList.Count - 1 To 0 Step -1
|
||||||
|
If Math.Abs(m_RawMoveDataList(Index).m_vtRawMove.x) < EPS_SMALL AndAlso Math.Abs(m_RawMoveDataList(Index).m_vtRawMove.y) < EPS_SMALL Then
|
||||||
|
m_RawMoveDataList.RemoveAt(Index)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
' verifico che la lista non sia vuota
|
||||||
|
If m_RawMoveDataList.Count = 0 Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
' recupero disposizione fase corrente
|
||||||
|
Dim nDispId As Integer = EgtGetPhaseDisposition(m_nCurrPhase)
|
||||||
|
' imposto la pausa nella disposizione corrente
|
||||||
|
SetPause(nDispId)
|
||||||
|
' aggiungo al gruppo disposizione dei sottogruppi con i dati di movimento dei grezzi spostati
|
||||||
|
SaveMoveInfoInDisposition(nDispId, m_RawMoveDataList)
|
||||||
|
' imposto eventuale movimento pezzi su tavola ausiliaria
|
||||||
|
SaveMovePartsOnAuxTable(nDispId, m_IsCurrPhaseUnloaded)
|
||||||
|
' SaveMovePartsOnAuxTable(nDispId, m_SplitPage.m_bOnAuxTab)
|
||||||
|
'' Eseguo calcolo speciale dei movimenti: per tavola multicut
|
||||||
|
'SpecialApplyDisposition(nDispId, True, Not m_SplitPage.m_bOnAuxTab)
|
||||||
|
SaveRemoveByHandInDisposition(nDispId, False)
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' crea una nuvoa fase/disposizione, la rende corrente, ricalcolo i grezzi e le lavorazioni della nuova fase
|
||||||
|
Private Function AddNewPhase() As Boolean
|
||||||
|
' Creo nuova fase
|
||||||
|
Dim nNewPhase As Integer = EgtAddPhase()
|
||||||
|
' Carico i grezzi rimasti sulla tavola nella nuova fase
|
||||||
|
ChangePhaseRawPart(nNewPhase)
|
||||||
|
' Sposto le lavorazioni rimaste nella nuova fase
|
||||||
|
ChangeOperationPhase(nNewPhase)
|
||||||
|
|
||||||
|
Dim nCurrDisposition As Integer = EgtGetPhaseDisposition(nNewPhase)
|
||||||
|
'SetPause(nCurrDisposition)
|
||||||
|
m_nCurrDisposition = nCurrDisposition
|
||||||
|
' EgtSetStatus(nRawIdSlected, GDB_ST.OFF)
|
||||||
|
EgtSetStatus(GetVacuumId(), GDB_ST.OFF)
|
||||||
|
EgtSetCurrPhase(nNewPhase)
|
||||||
|
SetAuxTabInCurrDisposition()
|
||||||
|
' ripulisco la lista degli spostamenti
|
||||||
|
m_RawMoveDataList.Clear()
|
||||||
|
m_IsCurrPhaseUnloaded = False
|
||||||
|
' aggiorno la fase corrente
|
||||||
|
m_nCurrPhase = EgtGetCurrPhase()
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' Copio i grezzi rimasti sulla tavola nella fase successiva
|
||||||
|
Private Sub ChangePhaseRawPart(ByVal nNewPhase As Integer)
|
||||||
|
' recupero l'elenco dei pezzi che sono stati scaricati sulla tavola
|
||||||
|
Dim LocalLstOfUnldPart As New List(Of Integer)
|
||||||
|
PartOnAuxTab(LocalLstOfUnldPart, nNewPhase - 1)
|
||||||
|
' Eseguo eventuali spezzature dei grezzi e vi sposto i pezzi (i grezzi devono essere sempre copiati per Registrazione con rotazione)
|
||||||
|
Dim nRawId As Integer = EgtGetFirstRawPart()
|
||||||
|
While nRawId <> GDB_ID.NULL
|
||||||
|
' se il grezzo è presente nella fase precedente e non è quello selezionato allora procedo a creare una copia nella nuova fase
|
||||||
|
If EgtVerifyRawPartPhase(nRawId, nNewPhase - 1) Then
|
||||||
|
Dim bKeepRawPart As Boolean = True
|
||||||
|
For Each RawOnAuxTabData As RawMoveData In m_RawMoveDataList
|
||||||
|
If nRawId = RawOnAuxTabData.m_nId Then
|
||||||
|
' se il pezzo è stato scaricato allora non deve essere riportato nella fase successiva
|
||||||
|
For Each UnloadPart As Integer In LocalLstOfUnldPart
|
||||||
|
If nRawId = UnloadPart Then
|
||||||
|
' salvo l'info che indica che il pezzo deve essere scaricato
|
||||||
|
EgtSetInfo(nRawId, "Unloaded", 1)
|
||||||
|
bKeepRawPart = False
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
'bKeepRawPart = False
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
If bKeepRawPart Then EgtKeepRawPart(nRawId, nNewPhase - 1)
|
||||||
|
End If
|
||||||
|
' passo al successivo grezzo
|
||||||
|
nRawId = EgtGetNextRawPart(nRawId)
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub ResetBtn_Click(sender As Object, e As RoutedEventArgs) Handles ResetBtn.Click
|
Private Sub ResetBtn_Click(sender As Object, e As RoutedEventArgs) Handles ResetBtn.Click
|
||||||
' Recupero il primo grezzo selezionato
|
' Recupero il primo grezzo selezionato
|
||||||
Dim nRawId As Integer = EgtGetFirstSelectedObj()
|
Dim nRawId As Integer = EgtGetFirstSelectedObj()
|
||||||
@@ -890,6 +1209,8 @@ Public Class MoveRawPartPage
|
|||||||
EgtRotateRawPart(nRawId, Vector3d.Z_AX(), dAngRaw)
|
EgtRotateRawPart(nRawId, Vector3d.Z_AX(), dAngRaw)
|
||||||
AddRawMoveData(nRawId, vtMove, m_RawMoveDataList)
|
AddRawMoveData(nRawId, vtMove, m_RawMoveDataList)
|
||||||
RemoveRawMoveData(nRawId, m_RawMoveDataList)
|
RemoveRawMoveData(nRawId, m_RawMoveDataList)
|
||||||
|
' elimino l'info che indica che il pezzo è scaricato sulla tavola
|
||||||
|
EgtRemoveInfo(nRawId, "Unloaded")
|
||||||
' Disabilito pezzo e nascondo le ventose
|
' Disabilito pezzo e nascondo le ventose
|
||||||
EgtSetStatus(nRawId, GDB_ST.ON_)
|
EgtSetStatus(nRawId, GDB_ST.ON_)
|
||||||
EgtSetStatus(GetVacuumId(), GDB_ST.OFF)
|
EgtSetStatus(GetVacuumId(), GDB_ST.OFF)
|
||||||
@@ -912,7 +1233,38 @@ Public Class MoveRawPartPage
|
|||||||
EgtDeselectAll()
|
EgtDeselectAll()
|
||||||
' Torno alla fase precedente
|
' Torno alla fase precedente
|
||||||
m_bPrev = True
|
m_bPrev = True
|
||||||
' Passo alla pagina delle spezzature
|
' Passo alla pagina delle spezzature solo se non esiste prima una fased di deposito sulla tavola di scarico
|
||||||
|
|
||||||
|
Dim nPrevDispId As Integer = EgtGetPrevOperation(m_nCurrDisposition)
|
||||||
|
' verifico se la fasa precedente è di tipo scarico
|
||||||
|
If IsDispUnloadOnAuxTab(nPrevDispId) <> 0 Then
|
||||||
|
EgtSetCurrPhase(m_nCurrPhase - 1)
|
||||||
|
m_nCurrDisposition = nPrevDispId
|
||||||
|
m_nCurrPhase -= 1
|
||||||
|
m_bPrev = False
|
||||||
|
m_SplitPage.m_bShow = True
|
||||||
|
m_SplitPage.m_bOnAuxTab = True
|
||||||
|
' imposto la visibilità della tavola ausiliaria
|
||||||
|
SetAuxTabInCurrDisposition()
|
||||||
|
' carico le info di disposizione dei pezzi
|
||||||
|
m_RawMoveDataList.Clear()
|
||||||
|
m_bRemovedRaw = GetRemoveByHandInDisposition(m_nCurrDisposition)
|
||||||
|
GetMoveInfoInDisposition(m_nCurrDisposition, m_RawMoveDataList)
|
||||||
|
RefreshVisibility()
|
||||||
|
EgtDraw()
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
|
'If EgtGetOperationType(EgtGetPrevOperation(m_nCurrDisposition)) = MCH_OY.DISP AndAlso m_SplitPage.m_bOnAuxTab Then
|
||||||
|
' EgtSetCurrPhase(m_nCurrPhase - 1)
|
||||||
|
' m_nCurrDisposition = EgtGetPrevOperation(m_nCurrDisposition)
|
||||||
|
' m_nCurrPhase -= 1
|
||||||
|
' m_bPrev = False
|
||||||
|
' m_SplitPage.m_bShow = True
|
||||||
|
' EgtDraw()
|
||||||
|
' Return
|
||||||
|
'End If
|
||||||
|
|
||||||
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Remove(Me)
|
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Remove(Me)
|
||||||
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Add(m_SplitPage)
|
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Add(m_SplitPage)
|
||||||
m_MainWindow.m_CadCutPageUC.m_CadCutMode = CadCutPageUC.CadCutModes.Split
|
m_MainWindow.m_CadCutPageUC.m_CadCutMode = CadCutPageUC.CadCutModes.Split
|
||||||
@@ -928,6 +1280,53 @@ Public Class MoveRawPartPage
|
|||||||
' non cambio pagina
|
' non cambio pagina
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' ------- VISUALIZZAZIONE -------
|
||||||
|
If m_SplitPage.m_bShow Then
|
||||||
|
' verifico se la fase successiva è uno scarico frontale
|
||||||
|
If NextOperationIsUnloading(m_nCurrDisposition) Then
|
||||||
|
' imposto la nuova fase (che è stata modificata all'interno della funzione di controllo)
|
||||||
|
EgtSetCurrPhase(m_nCurrPhase)
|
||||||
|
' carico i dati di movimento dei pezzi nella fase corrente
|
||||||
|
m_RawMoveDataList.Clear()
|
||||||
|
m_bRemovedRaw = GetRemoveByHandInDisposition(m_nCurrDisposition)
|
||||||
|
GetMoveInfoInDisposition(m_nCurrDisposition, m_RawMoveDataList)
|
||||||
|
EgtDraw()
|
||||||
|
Return
|
||||||
|
ElseIf IsDispUnloadOnAuxTab(m_nCurrDisposition) <> 0 AndAlso Not NextOperationIsUnloading(m_nCurrDisposition) Then
|
||||||
|
' imposto la nuova fase, al termine della Sub verrà caricata la pagina Split nella fase indicata ora
|
||||||
|
m_bToNext = True
|
||||||
|
m_nCurrPhase += 1
|
||||||
|
EgtSetCurrPhase(m_nCurrPhase)
|
||||||
|
EgtDraw()
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
|
||||||
|
' ------- MODIFICA -------
|
||||||
|
If Not m_SplitPage.m_bShow Then
|
||||||
|
' se la tavola di scarico presente oppure ci sono pezzi sulla tavola di scarico
|
||||||
|
Dim LclLstOfUnldPart As New List(Of Integer)
|
||||||
|
If m_SplitPage.m_bOnAuxTab Or PartOnAuxTab(LclLstOfUnldPart, m_nCurrPhase) Then
|
||||||
|
' se ci sono pezzi sulla tavola di scarico prima di procedere inserisco una pausa e creo una nuoava fase
|
||||||
|
If m_IsCurrPhaseUnloaded AndAlso InsertPauseInCurrPhase() Then AddNewPhase()
|
||||||
|
' nascondo la tavola di scarico
|
||||||
|
EgtDisableModified()
|
||||||
|
EgtSetStatus(m_nAuxTabId, GDB_ST.OFF)
|
||||||
|
EgtEnableModified()
|
||||||
|
End If
|
||||||
|
m_bToNext = True
|
||||||
|
'' se la disposizione corrente è sulla tavola ausiliaria allora lo sarà anche quella successiva
|
||||||
|
'If IsDispUnloadOnAuxTab(m_nCurrDisposition) <> 0 Then
|
||||||
|
' EgtSetCurrPhase(m_nCurrPhase + 1)
|
||||||
|
' m_nCurrDisposition = EgtGetNextOperation(m_nCurrDisposition)
|
||||||
|
' m_nCurrPhase += 1
|
||||||
|
' m_bToNext = False
|
||||||
|
' m_SplitPage.m_bShow = True
|
||||||
|
' EgtDraw()
|
||||||
|
' EnableButtons()
|
||||||
|
' Return
|
||||||
|
'End If
|
||||||
|
End If
|
||||||
' resetto l'inidice del pezzo da mnovimentare
|
' resetto l'inidice del pezzo da mnovimentare
|
||||||
m_CurrRawOnVacuum = GDB_ID.NULL
|
m_CurrRawOnVacuum = GDB_ID.NULL
|
||||||
' Deseleziono tutto
|
' Deseleziono tutto
|
||||||
@@ -970,10 +1369,44 @@ Public Class MoveRawPartPage
|
|||||||
' disabilito bottone
|
' disabilito bottone
|
||||||
ModifyBtn.IsEnabled = False
|
ModifyBtn.IsEnabled = False
|
||||||
' gestione abilitazione altri bottoni
|
' gestione abilitazione altri bottoni
|
||||||
EnableButtons()
|
EnableButtons(MachiningList.Count > 0)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub EnableButtons()
|
' verifica se la disposizione indicata è uno scarico sulla tavola ausiliaria
|
||||||
|
Public Function IsDispUnloadOnAuxTab(nCurrDispId As Integer) As Integer
|
||||||
|
' verifico se la fase precedente è uno scarico su tavola ausiliaria
|
||||||
|
Dim bVal As Integer = 0
|
||||||
|
EgtGetInfo(nCurrDispId, "Pat", bVal)
|
||||||
|
Return bVal
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' restituisce e attiva la successiva disposizione se è uno scarico frontale
|
||||||
|
Public Function NextOperationIsUnloading(nCurrDispId As Integer) As Boolean
|
||||||
|
' recupero la primo operazione successiva
|
||||||
|
Dim nNextIdOperation As Integer = EgtGetNextOperation(nCurrDispId)
|
||||||
|
' a partire da questa cerco la prima disposizione disponibile
|
||||||
|
Dim nNextIdDips As Integer = GetNextDisposition(nNextIdOperation)
|
||||||
|
If nNextIdDips = nNextIdOperation And IsDispUnloadOnAuxTab(nNextIdOperation) Then
|
||||||
|
m_nCurrPhase += 1
|
||||||
|
m_nCurrDisposition = nNextIdOperation
|
||||||
|
Return True
|
||||||
|
End If
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' recupero la prima disposizione disponibile tra l'elenco delle operazioni presenti
|
||||||
|
Public Function GetNextDisposition(nCurrDisposId As Integer) As Integer
|
||||||
|
Dim nDispId As Integer = nCurrDisposId
|
||||||
|
While nDispId <> GDB_ID.NULL
|
||||||
|
If EgtGetOperationType(nDispId) = MCH_OY.DISP Then
|
||||||
|
Return nDispId
|
||||||
|
End If
|
||||||
|
nDispId = EgtGetNextOperation(nDispId)
|
||||||
|
End While
|
||||||
|
Return GDB_ID.NULL
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Private Sub EnableButtons(Optional bExistsMachining As Boolean = False)
|
||||||
UpBtn.IsEnabled = Not m_SplitPage.m_bShow
|
UpBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
LeftBtn.IsEnabled = Not m_SplitPage.m_bShow
|
LeftBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
RightBtn.IsEnabled = Not m_SplitPage.m_bShow
|
RightBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
@@ -987,11 +1420,38 @@ Public Class MoveRawPartPage
|
|||||||
TopRBtn.IsEnabled = Not m_SplitPage.m_bShow
|
TopRBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
BottomLBtn.IsEnabled = Not m_SplitPage.m_bShow
|
BottomLBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
BottomRBtn.IsEnabled = Not m_SplitPage.m_bShow
|
BottomRBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
|
PauseBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
ResetBtn.IsEnabled = Not m_SplitPage.m_bShow
|
ResetBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
|
UnloadPartsBtn.IsEnabled = Not m_SplitPage.m_bShow
|
||||||
|
If m_SplitPage.m_bShow Then
|
||||||
|
NextBtn.IsEnabled = (m_nCurrPhase < EgtGetPhaseCount())
|
||||||
|
Else
|
||||||
|
' Se esistono delle lavorazioni allora abilito il pulsante per procedere
|
||||||
|
If Not bExistsMachining Then
|
||||||
NextBtn.IsEnabled = Not m_SplitPage.m_bOnAuxTab
|
NextBtn.IsEnabled = Not m_SplitPage.m_bOnAuxTab
|
||||||
|
Else
|
||||||
|
NextBtn.IsEnabled = True
|
||||||
|
End If
|
||||||
|
|
||||||
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' esco dalla pagina di scarico
|
||||||
Private Sub MoveRawPartPage_Unloaded(sender As Object, e As EventArgs) Handles Me.Unloaded
|
Private Sub MoveRawPartPage_Unloaded(sender As Object, e As EventArgs) Handles Me.Unloaded
|
||||||
|
' verifico che la fase corrente non sia vuota
|
||||||
|
Dim nLastDispId As Integer = EgtGetPhaseDisposition(m_nCurrPhase)
|
||||||
|
|
||||||
|
'' se sono in visualizzazione allora non elimino essuna operazione
|
||||||
|
'If Not m_SplitPage.m_bShow Then
|
||||||
|
' If EgtIsOperationEmpty(nLastDispId) And Not m_SplitPage.m_bOnAuxTab And m_RawMoveDataList.Count = 0 Then
|
||||||
|
' EgtErase(nLastDispId)
|
||||||
|
' ElseIf EgtIsOperationEmpty(nLastDispId) And m_SplitPage.m_bOnAuxTab And m_RawMoveDataList.Count = 0 Then
|
||||||
|
' ' Dichiaro pagina non attiva
|
||||||
|
' m_bActive = False
|
||||||
|
' Return
|
||||||
|
' End If
|
||||||
|
'End If
|
||||||
|
|
||||||
' Se movimento con ventose
|
' Se movimento con ventose
|
||||||
If Not m_bByHand Then
|
If Not m_bByHand Then
|
||||||
' nascondo le ventose
|
' nascondo le ventose
|
||||||
@@ -1006,8 +1466,9 @@ Public Class MoveRawPartPage
|
|||||||
SaveMoveInfoInDisposition(nDispId, m_RawMoveDataList)
|
SaveMoveInfoInDisposition(nDispId, m_RawMoveDataList)
|
||||||
' imposto eventuale presenza rimozioni manuali
|
' imposto eventuale presenza rimozioni manuali
|
||||||
SaveRemoveByHandInDisposition(nDispId, m_bRemovedRaw)
|
SaveRemoveByHandInDisposition(nDispId, m_bRemovedRaw)
|
||||||
' imposto eventuale movimento pezzi su tavola ausiliaria
|
' imposto eventuale movimento pezzi su tavola ausiliaria (se è realmente avvenuto)
|
||||||
SaveMovePartsOnAuxTable( nDispId, m_SplitPage.m_bOnAuxTab)
|
'SaveMovePartsOnAuxTable(nDispId, m_SplitPage.m_bOnAuxTab)
|
||||||
|
SaveMovePartsOnAuxTable(nDispId, m_IsCurrPhaseUnloaded)
|
||||||
' Eseguo calcolo speciale dei movimenti
|
' Eseguo calcolo speciale dei movimenti
|
||||||
SpecialApplyDisposition(nDispId, True, Not m_SplitPage.m_bOnAuxTab)
|
SpecialApplyDisposition(nDispId, True, Not m_SplitPage.m_bOnAuxTab)
|
||||||
End If
|
End If
|
||||||
@@ -1023,13 +1484,18 @@ Public Class MoveRawPartPage
|
|||||||
SpecialApplyDisposition(nDispId, True)
|
SpecialApplyDisposition(nDispId, True)
|
||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' Nascondo eventuale tavola ausiliaria
|
' Nascondo eventuale tavola ausiliaria
|
||||||
If m_SplitPage.m_bOnAuxTab Then
|
If m_SplitPage.m_bOnAuxTab Then
|
||||||
EgtDisableModified()
|
EgtDisableModified()
|
||||||
EgtSetStatus(m_nAuxTabId, GDB_ST.OFF)
|
EgtSetStatus(m_nAuxTabId, GDB_ST.OFF)
|
||||||
EgtEnableModified()
|
EgtEnableModified()
|
||||||
EgtZoom(ZM.ALL, False)
|
' se sto uscendo dalla pagina delle spezzature
|
||||||
If Not m_bPrev Then
|
If Not m_bPrev And Not m_bToNext Then
|
||||||
|
Dim nDispId As Integer = EgtGetPhaseDisposition(m_nCurrPhase)
|
||||||
|
' se sto uscendo dalla pagina split (senza passare dal comando next)
|
||||||
|
Dim lclLstUnlPart As New List(Of Integer)
|
||||||
|
SaveMovePartsOnAuxTable(nDispId, PartOnAuxTab(lclLstUnlPart, m_nCurrPhase))
|
||||||
' Cancello eventuale manipolatore pezzi
|
' Cancello eventuale manipolatore pezzi
|
||||||
EgtDisableModified()
|
EgtDisableModified()
|
||||||
RemoveVacuumCups()
|
RemoveVacuumCups()
|
||||||
@@ -1046,10 +1512,30 @@ Public Class MoveRawPartPage
|
|||||||
m_bPrev = False
|
m_bPrev = False
|
||||||
m_SplitPage.m_bShow = True
|
m_SplitPage.m_bShow = True
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
Dim Ph As Integer = EgtGetCurrPhase()
|
||||||
|
' aggiorno il disegno
|
||||||
|
EgtZoom(ZM.ALL, False)
|
||||||
' Dichiaro pagina non attiva
|
' Dichiaro pagina non attiva
|
||||||
m_bActive = False
|
m_bActive = False
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' ----------------- TEST funzione per debug operazioni -----------------
|
||||||
|
Private Sub SaveMyFileTest(sFilename As String)
|
||||||
|
LoadCurrPhaseMachining()
|
||||||
|
' salvo il file corrente per poterlo studiare e capire cosa è successo nella rappresentazione dei grezzi
|
||||||
|
EgtSaveFile("C:\EgtData\OmagCUT\MyProjects\" & sFilename & ".nge", NGE.BIN)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub LoadCurrPhaseMachining()
|
||||||
|
Dim m_MachiningList As New List(Of SplitMach)
|
||||||
|
'm_SplitPage.ShowMachiningList()
|
||||||
|
'm_SplitPage.SaveOrderMachinig(m_nCurrPhase)
|
||||||
|
' Preparo la lista delle lavorazioni
|
||||||
|
CalculateSplitMachList(m_nCurrPhase, m_MachiningList)
|
||||||
|
Dim b As Boolean = False
|
||||||
|
End Sub
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -78,7 +78,7 @@
|
|||||||
<ColumnDefinition Width="Auto"/>
|
<ColumnDefinition Width="Auto"/>
|
||||||
<ColumnDefinition Width="Auto"/>
|
<ColumnDefinition Width="Auto"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<EgtWPFLib:EgtTextBox Name="RotationAngleTxBx" Width="50"
|
<EgtWPFLib:EgtTextBox Name="RotationAngleTxBx" Width="50" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
<TextBlock Grid.Column="1" FontSize="30" Margin="2,-5,0,0"
|
<TextBlock Grid.Column="1" FontSize="30" Margin="2,-5,0,0"
|
||||||
Text="°"/>
|
Text="°"/>
|
||||||
|
|||||||
@@ -62,6 +62,14 @@ Public Class NestPageUC
|
|||||||
Private m_bMaximizeMove As Boolean = False
|
Private m_bMaximizeMove As Boolean = False
|
||||||
Private m_dAngStep As Double = 0
|
Private m_dAngStep As Double = 0
|
||||||
Private m_bReducedCut As Boolean = False
|
Private m_bReducedCut As Boolean = False
|
||||||
|
|
||||||
|
Private m_bKeyCtrlPressed As Boolean = False
|
||||||
|
Private m_bKeyLeftShiftPressed As Boolean = False
|
||||||
|
Private m_dAngTotal As Double = 0
|
||||||
|
Private m_dStartAng As Double = 0
|
||||||
|
Private m_bStartRot As Boolean = False
|
||||||
|
Private m_bStartMove As Boolean = False
|
||||||
|
|
||||||
' Dati per tolleranza spessore Trf
|
' Dati per tolleranza spessore Trf
|
||||||
Private m_dTrfThickTolerance As Double = 0
|
Private m_dTrfThickTolerance As Double = 0
|
||||||
' Dati movimento registrazione grezzo
|
' Dati movimento registrazione grezzo
|
||||||
@@ -94,6 +102,7 @@ Public Class NestPageUC
|
|||||||
RemovePartBtn.ToolTip = EgtMsg(MSG_NESTPAGEUC + 3) 'Remove part - Elimina pezzo
|
RemovePartBtn.ToolTip = EgtMsg(MSG_NESTPAGEUC + 3) 'Remove part - Elimina pezzo
|
||||||
SelectAllBtn.ToolTip = EgtMsg(MSG_NESTPAGEUC + 4) 'Select All - Seleziona Tutto
|
SelectAllBtn.ToolTip = EgtMsg(MSG_NESTPAGEUC + 4) 'Select All - Seleziona Tutto
|
||||||
DeselectAllBtn.ToolTip = EgtMsg(MSG_NESTPAGEUC + 5) 'Deselect All - Deseleziona Tutto
|
DeselectAllBtn.ToolTip = EgtMsg(MSG_NESTPAGEUC + 5) 'Deselect All - Deseleziona Tutto
|
||||||
|
DragRettanleBtn.ToolTip = "Strech"
|
||||||
|
|
||||||
Dim nColumsIn_UG1 As Integer = 2
|
Dim nColumsIn_UG1 As Integer = 2
|
||||||
' gestisco la visualizzazione del comando PAN (per il drag dei rettangoli)
|
' gestisco la visualizzazione del comando PAN (per il drag dei rettangoli)
|
||||||
@@ -1053,7 +1062,9 @@ Public Class NestPageUC
|
|||||||
m_locPrev = e.Location
|
m_locPrev = e.Location
|
||||||
m_bDrag = m_bDrag AndAlso EgtUnProjectPoint(e.Location, m_ptPrev)
|
m_bDrag = m_bDrag AndAlso EgtUnProjectPoint(e.Location, m_ptPrev)
|
||||||
m_bDragToStart = m_bDrag
|
m_bDragToStart = m_bDrag
|
||||||
|
' attivo la modalità di traslazione e rotazione senza cltrollo collisioni (solo in fase di Drag)
|
||||||
m_bVerify = m_bDrag AndAlso (Keyboard.Modifiers And ModifierKeys.Shift) > 0
|
m_bVerify = m_bDrag AndAlso (Keyboard.Modifiers And ModifierKeys.Shift) > 0
|
||||||
|
m_bKeyLeftShiftPressed = m_bVerify
|
||||||
m_vtTotMove = Vector3d.NULL()
|
m_vtTotMove = Vector3d.NULL()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -1116,16 +1127,74 @@ Public Class NestPageUC
|
|||||||
m_bVerify = True
|
m_bVerify = True
|
||||||
m_bFromParking = True
|
m_bFromParking = True
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' Inizio esecuzione di drag
|
' Inizio esecuzione di drag
|
||||||
m_bDragging = True
|
m_bDragging = True
|
||||||
' Ricavo il punto corrente in coordinate mondo
|
' Ricavo il punto corrente in coordinate mondo
|
||||||
Dim ptCurr As Point3d
|
Dim ptCurr As Point3d
|
||||||
EgtUnProjectPoint(e.Location, ptCurr)
|
EgtUnProjectPoint(e.Location, ptCurr)
|
||||||
|
|
||||||
|
' la rotazione è attivabile solo se premuto il tasto Ctrl (e non sono in parheggio)
|
||||||
|
m_bKeyCtrlPressed = m_bDrag AndAlso (Keyboard.Modifiers And ModifierKeys.Control) > 0
|
||||||
|
|
||||||
|
'-------------Inizio ROTAZIONE ----------------
|
||||||
|
If m_bKeyCtrlPressed AndAlso (Not m_bFromParking OrElse m_bKeyLeftShiftPressed) Then
|
||||||
|
' Calcolo il centro di rotazione come centro del cluster
|
||||||
|
Dim ptCen As Point3d
|
||||||
|
If Not EgtGetPartPartClusterCenterGlob(nMoveId, ptCen) Then Return
|
||||||
|
' definisco il vettore dal centro del pezzo alla posizione del cursore
|
||||||
|
Dim vtCurr As Vector3d = ptCurr - ptCen
|
||||||
|
Dim dLen, dHAng, dVAng As Double
|
||||||
|
' recupero l'angolo orizzontale del vettore
|
||||||
|
vtCurr.ToSpherical(dLen, dHAng, dVAng)
|
||||||
|
If Not m_bStartRot Then
|
||||||
|
m_dAngTotal = 0
|
||||||
|
' notifico una rotazione
|
||||||
|
m_bStartRot = True
|
||||||
|
m_dStartAng = dVAng
|
||||||
|
End If
|
||||||
|
Dim dDeltaAng As Double = dVAng - m_dStartAng
|
||||||
|
' gestione del passaggio da 0° → 360° evitando mantenendo la visualizzazione fluida
|
||||||
|
If Math.Abs(dDeltaAng) > 90 Then
|
||||||
|
If m_dStartAng < 180 And dVAng > 180 Then
|
||||||
|
dDeltaAng = dVAng - 360 - m_dStartAng
|
||||||
|
ElseIf m_dStartAng > 180 And dVAng < 180 Then
|
||||||
|
dDeltaAng = dVAng - m_dStartAng + 360
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' Rotazione del pezzo attorno al suo centro
|
||||||
|
If Math.Abs(dDeltaAng) > EPS_ANG_SMALL Then
|
||||||
|
' se il tasto Shift è premuto (disabilitato il controllo collisioni durante il Drag)
|
||||||
|
If m_bKeyLeftShiftPressed Then
|
||||||
|
EgtRotate(nMoveId, ptCen, Vector3d.Z_AX(), dDeltaAng, GDB_RT.GLOB)
|
||||||
|
m_dAngTotal += dDeltaAng
|
||||||
|
Else
|
||||||
|
' esegue la rotazione fino ad incontrare un altro pezzo
|
||||||
|
RotatePartInsideBond(dDeltaAng, nMoveId)
|
||||||
|
m_CurrProjPage.ResetOrderMachiningFlag()
|
||||||
|
' Eventuale notifica al VeinMatching
|
||||||
|
Dim nId As Integer = EgtGetFirstSelectedObj()
|
||||||
|
While nId <> GDB_ID.NULL
|
||||||
|
VeinMatching.OnMovePartInRaw(nId)
|
||||||
|
nId = EgtGetNextSelectedObj()
|
||||||
|
End While
|
||||||
|
End If
|
||||||
|
m_dStartAng = dVAng
|
||||||
|
End If
|
||||||
|
'-------------Fine ROTAZIONE ----------------
|
||||||
|
|
||||||
|
Else
|
||||||
|
' -------------Inizio TRASLAZIONE ---------------
|
||||||
' Ricavo il vettore di movimento
|
' Ricavo il vettore di movimento
|
||||||
Dim vtMove As Vector3d = ptCurr - m_ptPrev
|
Dim vtMove As Vector3d = ptCurr - m_ptPrev
|
||||||
' Muovo i pezzi selezionati di quanto possibile
|
' Muovo i pezzi selezionati di quanto possibile
|
||||||
If vtMove.SqLen() > EPS_SMALL * EPS_SMALL Then
|
If vtMove.SqLen() > EPS_SMALL * EPS_SMALL Then
|
||||||
' Se movimento con sola verifica finale
|
' notifico una traslazione
|
||||||
|
If Not m_bStartMove Then
|
||||||
|
m_bStartMove = True
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Se movimento con sola verifica finale (disabilitato il controllo collisioni durante il Drag)
|
||||||
If m_bVerify Then
|
If m_bVerify Then
|
||||||
EgtMove(nMoveId, vtMove)
|
EgtMove(nMoveId, vtMove)
|
||||||
m_vtTotMove += vtMove
|
m_vtTotMove += vtMove
|
||||||
@@ -1159,8 +1228,13 @@ Public Class NestPageUC
|
|||||||
End If
|
End If
|
||||||
m_CurrProjPage.ResetOrderMachiningFlag()
|
m_CurrProjPage.ResetOrderMachiningFlag()
|
||||||
End If
|
End If
|
||||||
|
' -------------Fine TRASLAZIONE ---------------
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
' Eventuale notifica al VeinMatching
|
' Eventuale notifica al VeinMatching
|
||||||
|
If m_bStartMove OrElse m_bStartRot Then
|
||||||
If nMoveId = GDB_ID.SEL Then
|
If nMoveId = GDB_ID.SEL Then
|
||||||
Dim nId As Integer = EgtGetFirstSelectedObj()
|
Dim nId As Integer = EgtGetFirstSelectedObj()
|
||||||
While nId <> GDB_ID.NULL
|
While nId <> GDB_ID.NULL
|
||||||
@@ -1171,10 +1245,15 @@ Public Class NestPageUC
|
|||||||
VeinMatching.OnMovePartInRaw(nMoveId)
|
VeinMatching.OnMovePartInRaw(nMoveId)
|
||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' Aggiorno il punto precedente
|
' Aggiorno il punto precedente
|
||||||
m_ptPrev = ptCurr
|
m_ptPrev = ptCurr
|
||||||
' Terminata esecuzione di drag
|
' Terminata esecuzione di drag
|
||||||
m_bDragging = False
|
m_bDragging = False
|
||||||
|
'' elimino il ponticello associato: nella vilualizzazione il percorso di lavorazioni non si muove! in attesa di gestione
|
||||||
|
'DeleteBridgeAssociated(nMoveId)
|
||||||
|
' Resetto i ponticelli (per ora non sono in grado di muoverli assieme ai pezzi)
|
||||||
|
ResetAllBRidges()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub OnMyMouseUpScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseUpScene
|
Private Sub OnMyMouseUpScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseUpScene
|
||||||
@@ -1198,47 +1277,31 @@ Public Class NestPageUC
|
|||||||
|
|
||||||
' Se eseguito drag
|
' Se eseguito drag
|
||||||
If Not m_bDragToStart Then
|
If Not m_bDragToStart Then
|
||||||
' Se movimento con sola verifica finale
|
' Se movimento con sola verifica finale ----- TRASLAZIONE
|
||||||
If m_bVerify Then
|
If Not m_bStartRot And m_bStartMove Then
|
||||||
' Determino cosa verificare
|
VerifyMove()
|
||||||
Dim nMoveId = If(m_nIdToSel <> GDB_ID.NULL, m_nIdToSel, GDB_ID.SEL)
|
' Se movimento con sola verifica finale ----- TRASLAZIONE + ROTAZIONE
|
||||||
' Aggiorno regioni per nesting
|
ElseIf m_bStartRot And m_bStartMove Then
|
||||||
UpdateNestRegions()
|
If Not m_bFromParking Then
|
||||||
EnableReferenceRegion(False)
|
VerifyRot()
|
||||||
' Eseguo verifica
|
|
||||||
If VerifyTrfData(nMoveId) And EgtVerifyPart(nMoveId, m_bReducedCut) Then
|
|
||||||
m_CurrProjPage.ResetOrderMachiningFlag()
|
|
||||||
' Non superata riporto alla posizione iniziale
|
|
||||||
Else
|
Else
|
||||||
|
' forzo il reset delle info di rotazione
|
||||||
|
m_dStartAng = 0
|
||||||
|
m_dAngTotal = 0
|
||||||
|
m_bStartRot = False
|
||||||
|
End If
|
||||||
|
VerifyMove()
|
||||||
|
' verifico se la posizione finale della rotazione è corretta ----- ROTAZIONE
|
||||||
|
ElseIf m_bStartRot And Not m_bStartMove Then
|
||||||
If m_bFromParking Then
|
If m_bFromParking Then
|
||||||
m_CurrProjPage.ClearMessage()
|
VerifyMove()
|
||||||
PreRemoveOnePart(nMoveId)
|
' forzo il reset delle info di rotazione
|
||||||
VeinMatching.OnRemovePartFromRaw(nMoveId)
|
m_dStartAng = 0
|
||||||
|
m_dAngTotal = 0
|
||||||
|
m_bStartRot = False
|
||||||
Else
|
Else
|
||||||
EgtMove(nMoveId, -m_vtTotMove)
|
VerifyRot()
|
||||||
' Eventuale notifica al VeinMatching
|
|
||||||
If nMoveId = GDB_ID.SEL Then
|
|
||||||
Dim nId As Integer = EgtGetFirstSelectedObj()
|
|
||||||
While nId <> GDB_ID.NULL
|
|
||||||
VeinMatching.OnMovePartInRaw(nId)
|
|
||||||
nId = EgtGetNextSelectedObj()
|
|
||||||
End While
|
|
||||||
Else
|
|
||||||
VeinMatching.OnMovePartInRaw(nMoveId)
|
|
||||||
End If
|
End If
|
||||||
End If
|
|
||||||
'---------------------- COUNTER PART ----------------------
|
|
||||||
Dim sRefGroup As String = String.Empty
|
|
||||||
If EgtGetInfo(nMoveId, INFO_REFGROUP, sRefGroup) Then
|
|
||||||
' accendo il layer che contiene il contatore (spento in fase di Drag)
|
|
||||||
Dim nCounterLayer As Integer = EgtGetFirstNameInGroup(nMoveId, INFO_COUNTERLY)
|
|
||||||
EgtSetStatus(nCounterLayer, GDB_ST.ON_)
|
|
||||||
' aggiorno il layer che indica il numero di pezzi in parcheggio
|
|
||||||
CountPartInFamily(sRefGroup)
|
|
||||||
End If
|
|
||||||
'---------------------- COUNTER PART ----------------------
|
|
||||||
End If
|
|
||||||
m_bFromParking = False
|
|
||||||
' altrimenti caso con verifica durante il movimento
|
' altrimenti caso con verifica durante il movimento
|
||||||
Else
|
Else
|
||||||
' Basta reset alla fine
|
' Basta reset alla fine
|
||||||
@@ -1290,8 +1353,8 @@ Public Class NestPageUC
|
|||||||
VeinMatching.OnDeselectPart(m_nIdToDesel)
|
VeinMatching.OnDeselectPart(m_nIdToDesel)
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
|
||||||
' Reset
|
' Reset
|
||||||
|
GetFamilyGroupInPark()
|
||||||
m_bDrag = False
|
m_bDrag = False
|
||||||
m_nIdToSel = GDB_ID.NULL
|
m_nIdToSel = GDB_ID.NULL
|
||||||
m_nIdToDesel = GDB_ID.NULL
|
m_nIdToDesel = GDB_ID.NULL
|
||||||
@@ -1302,6 +1365,70 @@ Public Class NestPageUC
|
|||||||
EgtDraw()
|
EgtDraw()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub VerifyMove()
|
||||||
|
If m_bVerify Then
|
||||||
|
' Determino cosa verificare
|
||||||
|
Dim nMoveId = If(m_nIdToSel <> GDB_ID.NULL, m_nIdToSel, GDB_ID.SEL)
|
||||||
|
' Aggiorno regioni per nesting
|
||||||
|
UpdateNestRegions()
|
||||||
|
EnableReferenceRegion(False)
|
||||||
|
' Eseguo verifica
|
||||||
|
If VerifyTrfData(nMoveId) And EgtVerifyPart(nMoveId, m_bReducedCut) Then
|
||||||
|
m_CurrProjPage.ResetOrderMachiningFlag()
|
||||||
|
' Non superata riporto alla posizione iniziale
|
||||||
|
Else
|
||||||
|
If m_bFromParking Then
|
||||||
|
m_CurrProjPage.ClearMessage()
|
||||||
|
PreRemoveOnePart(nMoveId)
|
||||||
|
VeinMatching.OnRemovePartFromRaw(nMoveId)
|
||||||
|
Else
|
||||||
|
EgtMove(nMoveId, -m_vtTotMove)
|
||||||
|
' Eventuale notifica al VeinMatching
|
||||||
|
If nMoveId = GDB_ID.SEL Then
|
||||||
|
Dim nId As Integer = EgtGetFirstSelectedObj()
|
||||||
|
While nId <> GDB_ID.NULL
|
||||||
|
VeinMatching.OnMovePartInRaw(nId)
|
||||||
|
nId = EgtGetNextSelectedObj()
|
||||||
|
End While
|
||||||
|
Else
|
||||||
|
VeinMatching.OnMovePartInRaw(nMoveId)
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
'---------------------- COUNTER PART ----------------------
|
||||||
|
' solo se pezzo disposto in tavola
|
||||||
|
If m_bFromParking Then
|
||||||
|
Dim sRefGroup As String = String.Empty
|
||||||
|
If EgtGetInfo(nMoveId, INFO_REFGROUP, sRefGroup) Then
|
||||||
|
' accendo il layer che contiene il contatore (spento in fase di Drag)
|
||||||
|
Dim nCounterLayer As Integer = EgtGetFirstNameInGroup(nMoveId, INFO_COUNTERLY)
|
||||||
|
EgtSetStatus(nCounterLayer, GDB_ST.ON_)
|
||||||
|
' aggiorno il layer che indica il numero di pezzi in parcheggio
|
||||||
|
CountPartInFamily(sRefGroup)
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
'---------------------- COUNTER PART ----------------------
|
||||||
|
End If
|
||||||
|
m_bFromParking = False
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub VerifyRot()
|
||||||
|
' se comando Shift è stato attivato
|
||||||
|
If m_bKeyLeftShiftPressed Then
|
||||||
|
' Determino cosa verificare
|
||||||
|
Dim nMoveId = If(m_nIdToSel <> GDB_ID.NULL, m_nIdToSel, GDB_ID.SEL)
|
||||||
|
If Not EgtVerifyPart(nMoveId, m_bReducedCut) Then
|
||||||
|
Dim ptCen As Point3d
|
||||||
|
If Not EgtGetPartPartClusterCenterGlob(nMoveId, ptCen) Then Return
|
||||||
|
EgtRotate(nMoveId, ptCen, Vector3d.Z_AX(), -m_dAngTotal, GDB_RT.GLOB)
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' resetto i valori
|
||||||
|
m_dStartAng = 0
|
||||||
|
m_dAngTotal = 0
|
||||||
|
m_bStartRot = False
|
||||||
|
End Sub
|
||||||
|
|
||||||
Friend Function SelectPart(nPartId As Integer, bNotifyVM As Boolean) As Boolean
|
Friend Function SelectPart(nPartId As Integer, bNotifyVM As Boolean) As Boolean
|
||||||
EgtSetCurrentContext(m_CurrProjPage.CurrentProjectScene.GetCtx())
|
EgtSetCurrentContext(m_CurrProjPage.CurrentProjectScene.GetCtx())
|
||||||
' Determino se pezzo in tavola o in parcheggio
|
' Determino se pezzo in tavola o in parcheggio
|
||||||
@@ -1573,7 +1700,7 @@ Public Class NestPageUC
|
|||||||
If m_nPartPos <> PART_POS.IN_TABLE Then
|
If m_nPartPos <> PART_POS.IN_TABLE Then
|
||||||
Dim nId As Integer = EgtGetFirstSelectedObj()
|
Dim nId As Integer = EgtGetFirstSelectedObj()
|
||||||
While nId <> GDB_ID.NULL
|
While nId <> GDB_ID.NULL
|
||||||
' Se pezzo con rotazione libera
|
' Se pezzo con rotazione libera (in parcheggio)
|
||||||
If Not EgtExistsInfo(nId, INFO_PARTROT) Then
|
If Not EgtExistsInfo(nId, INFO_PARTROT) Then
|
||||||
' Calcolo il centro di rotazione come centro del pezzo
|
' Calcolo il centro di rotazione come centro del pezzo
|
||||||
Dim ptCen As Point3d
|
Dim ptCen As Point3d
|
||||||
@@ -1609,26 +1736,31 @@ Public Class NestPageUC
|
|||||||
Return True
|
Return True
|
||||||
' Altrimenti li ruoto tenendo conto delle collisioni
|
' Altrimenti li ruoto tenendo conto delle collisioni
|
||||||
Else
|
Else
|
||||||
|
Return RotatePartInsideBond(dAngRotDeg, GDB_ID.SEL)
|
||||||
|
End If
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' verifica che la rotazione sia ammessa
|
||||||
|
Private Function RotatePartInsideBond(dAngRotDeg As Double, nIdMove As Integer) As Boolean
|
||||||
' Verifico se ci sono dei pezzi bloccati in rotazione
|
' Verifico se ci sono dei pezzi bloccati in rotazione
|
||||||
Dim bLockedRot As Boolean = GetLockOnRotation(GDB_ID.SEL)
|
Dim bLockedRot As Boolean = GetLockOnRotation(nIdMove)
|
||||||
' Se tutti i pezzi possono ruotare
|
' Se tutti i pezzi possono ruotare
|
||||||
If Not bLockedRot Then
|
If Not bLockedRot Then
|
||||||
' Calcolo il centro di rotazione come centro del cluster
|
' Calcolo il centro di rotazione come centro del cluster
|
||||||
Dim ptCen As Point3d
|
Dim ptCen As Point3d
|
||||||
If Not EgtGetPartPartClusterCenterGlob(GDB_ID.SEL, ptCen) Then Return False
|
If Not EgtGetPartPartClusterCenterGlob(nIdMove, ptCen) Then Return False
|
||||||
' Aggiorno regioni per nesting
|
' Aggiorno regioni per nesting
|
||||||
UpdateNestRegions()
|
UpdateNestRegions()
|
||||||
EnableReferenceRegion(False)
|
EnableReferenceRegion(False)
|
||||||
' Verifico rotazione complessiva
|
' Verifico rotazione complessiva
|
||||||
EgtRotate(GDB_ID.SEL, ptCen, Vector3d.Z_AX(), dAngRotDeg, GDB_RT.GLOB)
|
EgtRotate(nIdMove, ptCen, Vector3d.Z_AX(), dAngRotDeg, GDB_RT.GLOB)
|
||||||
If EgtVerifyPart(GDB_ID.SEL, m_bReducedCut) Then Return True
|
If EgtVerifyPart(nIdMove, m_bReducedCut) Then Return True
|
||||||
' Provo rotazione parziale (dopo aver annullato la complessiva)
|
' Provo rotazione parziale (dopo aver annullato la complessiva)
|
||||||
EgtRotate(GDB_ID.SEL, ptCen, Vector3d.Z_AX(), -dAngRotDeg, GDB_RT.GLOB)
|
EgtRotate(nIdMove, ptCen, Vector3d.Z_AX(), -dAngRotDeg, GDB_RT.GLOB)
|
||||||
Return EgtRotatePart(GDB_ID.SEL, m_bReducedCut, ptCen, dAngRotDeg)
|
Return EgtRotatePart(nIdMove, m_bReducedCut, ptCen, dAngRotDeg)
|
||||||
Else
|
Else
|
||||||
Return False
|
Return False
|
||||||
End If
|
End If
|
||||||
End If
|
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
Private Sub UserRotateAllRawParts(dAngDeg As Double)
|
Private Sub UserRotateAllRawParts(dAngDeg As Double)
|
||||||
@@ -2310,6 +2442,11 @@ Public Class NestPageUC
|
|||||||
EgtZoom(ZM.ALL)
|
EgtZoom(ZM.ALL)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' ripulisco la lista dei pezzi in parcheggio
|
||||||
|
Friend Sub ResetListOfGruopInPark()
|
||||||
|
m_ListOfGroupInPark.Clear()
|
||||||
|
End Sub
|
||||||
|
|
||||||
Friend Function StoreOnePart(nId As Integer, Optional ByVal bForced As Boolean = False) As Boolean
|
Friend Function StoreOnePart(nId As Integer, Optional ByVal bForced As Boolean = False) As Boolean
|
||||||
' Se pezzo in grezzo, metto in parcheggio (sempre possibile)
|
' Se pezzo in grezzo, metto in parcheggio (sempre possibile)
|
||||||
If bForced OrElse
|
If bForced OrElse
|
||||||
@@ -2387,6 +2524,10 @@ Public Class NestPageUC
|
|||||||
Dim dEraseArea As Double = 0
|
Dim dEraseArea As Double = 0
|
||||||
nId = EgtGetFirstSelectedObj()
|
nId = EgtGetFirstSelectedObj()
|
||||||
While nId <> GDB_ID.NULL
|
While nId <> GDB_ID.NULL
|
||||||
|
'' elimino eventuali ponticelli associati al pezzo: nella vilualizzazione il percorso di lavorazioni non si muove! in attesa di gestione
|
||||||
|
'DeleteBridgeAssociated(nId)
|
||||||
|
' Resetto i ponticelli (per ora non sono in grado di muoverli assieme ai pezzi)
|
||||||
|
ResetAllBRidges()
|
||||||
' Recupero indice del successivo
|
' Recupero indice del successivo
|
||||||
Dim nNextId = EgtGetNextSelectedObj()
|
Dim nNextId = EgtGetNextSelectedObj()
|
||||||
' Se abilitata cancellazione in ogni caso o pezzo non da Csv
|
' Se abilitata cancellazione in ogni caso o pezzo non da Csv
|
||||||
@@ -2432,6 +2573,47 @@ Public Class NestPageUC
|
|||||||
EgtZoom(ZM.ALL)
|
EgtZoom(ZM.ALL)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub DeleteBridgeAssociated(nMyId As Integer)
|
||||||
|
' verifico se esistono dei ponticelli associati al pezzo indicato
|
||||||
|
' recuoero il gruppo di lavorazione corrente
|
||||||
|
Dim nIdCurrMachGroup As Integer = EgtGetCurrMachGroup()
|
||||||
|
' creo il gruppo per i ponticelli
|
||||||
|
Dim sNameGroup As String = BRIDGES
|
||||||
|
Dim nIdBridgesGroup As Integer = EgtGetFirstNameInGroup(nIdCurrMachGroup, sNameGroup)
|
||||||
|
If nIdBridgesGroup <> GDB_ID.NULL Then
|
||||||
|
' carico la prima entità del gruppo BRIDGES
|
||||||
|
Dim nIdBridgeLine As Integer = GDB_ID.NULL
|
||||||
|
nIdBridgeLine = EgtGetFirstNameInGroup(nIdBridgesGroup, BRIDGELINE)
|
||||||
|
' ciclo su tutte le entità
|
||||||
|
While nIdBridgeLine <> GDB_ID.NULL
|
||||||
|
Dim nNextBridgeLine As Integer = GDB_ID.NULL
|
||||||
|
Dim nIdPart As Integer = GDB_ID.NULL
|
||||||
|
If EgtGetInfo(nIdBridgeLine, "PartStart", nIdPart) Then
|
||||||
|
If nIdPart = nMyId Then
|
||||||
|
nNextBridgeLine = EgtGetNext(nIdBridgeLine)
|
||||||
|
' il ponticello deve essere eliminato
|
||||||
|
EgtErase(nIdBridgeLine)
|
||||||
|
nIdBridgeLine = nNextBridgeLine
|
||||||
|
' riparto dall'inizio del ciclo
|
||||||
|
Continue While
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
If EgtGetInfo(nIdBridgeLine, "PartEnd", nIdPart) Then
|
||||||
|
If nIdPart = nMyId Then
|
||||||
|
nNextBridgeLine = EgtGetNext(nIdBridgeLine)
|
||||||
|
' il ponticello deve essere eliminato
|
||||||
|
EgtErase(nIdBridgeLine)
|
||||||
|
nIdBridgeLine = nNextBridgeLine
|
||||||
|
' riparto dall'inizio del ciclo
|
||||||
|
Continue While
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' il BridgeLine corrente non contiene riferimeti al pezzo da eliminare
|
||||||
|
nIdBridgeLine = EgtGetNext(nIdBridgeLine)
|
||||||
|
End While
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub SelectAllBtn_Click(sender As Object, e As RoutedEventArgs) Handles SelectAllBtn.Click
|
Private Sub SelectAllBtn_Click(sender As Object, e As RoutedEventArgs) Handles SelectAllBtn.Click
|
||||||
EgtSetCurrentContext(m_CurrProjPage.CurrentProjectScene.GetCtx())
|
EgtSetCurrentContext(m_CurrProjPage.CurrentProjectScene.GetCtx())
|
||||||
' Numero dei pezzi in tavola
|
' Numero dei pezzi in tavola
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
Imports EgtUILib
|
Imports System.Windows.Forms.Integration
|
||||||
|
Imports EgtUILib
|
||||||
|
|
||||||
Public Module SplitAuto
|
Public Module SplitAuto
|
||||||
|
|
||||||
@@ -99,7 +100,8 @@ Public Module SplitAuto
|
|||||||
Mach.m_dEndFreeLen = FREELEN_INF + 1
|
Mach.m_dEndFreeLen = FREELEN_INF + 1
|
||||||
Dim nEntId, nSub As Integer
|
Dim nEntId, nSub As Integer
|
||||||
If EgtGetMachiningGeometry(0, nEntId, nSub) Then
|
If EgtGetMachiningGeometry(0, nEntId, nSub) Then
|
||||||
If EgtGetType( nEntId) = GDB_TY.CRV_ARC OrElse EgtGetType( nEntId) = GDB_TY.CRV_COMPO Then Mach.m_bIsLine = False
|
' EgtGetType( nEntId) = GDB_TY.CRV_ARC OrElse
|
||||||
|
If EgtGetType(nEntId) = GDB_TY.CRV_COMPO Then Mach.m_bIsLine = False
|
||||||
EgtGetInfo(nEntId, If(Not Mach.m_bInvert, INFO_PREVANG, INFO_NEXTANG), Mach.m_dPrevAng)
|
EgtGetInfo(nEntId, If(Not Mach.m_bInvert, INFO_PREVANG, INFO_NEXTANG), Mach.m_dPrevAng)
|
||||||
EgtGetInfo(nEntId, If(Not Mach.m_bInvert, INFO_NEXTANG, INFO_PREVANG), Mach.m_dNextAng)
|
EgtGetInfo(nEntId, If(Not Mach.m_bInvert, INFO_NEXTANG, INFO_PREVANG), Mach.m_dNextAng)
|
||||||
EgtGetInfo(nEntId, If(Not Mach.m_bInvert, INFO_START_FREELEN, INFO_END_FREELEN), Mach.m_dStartFreeLen)
|
EgtGetInfo(nEntId, If(Not Mach.m_bInvert, INFO_START_FREELEN, INFO_END_FREELEN), Mach.m_dStartFreeLen)
|
||||||
@@ -218,11 +220,11 @@ Public Module SplitAuto
|
|||||||
Next
|
Next
|
||||||
EgtSetColor(nDwnCutId, COL_MCH_DISABLED)
|
EgtSetColor(nDwnCutId, COL_MCH_DISABLED)
|
||||||
Dim bFreeStart As Boolean = (nInterf And FMI_TYPE.LI) <> FMI_TYPE.LI
|
Dim bFreeStart As Boolean = (nInterf And FMI_TYPE.LI) <> FMI_TYPE.LI
|
||||||
EgtSetColor(nPrcId, If(bFreeStart, COL_MCH_DISABLED, COL_MCH_DIS_INTERF))
|
EgtSetColor(nPrcId, If(bFreeStart, COL_MCH_DISABLED(), COL_MCH_DIS_INTERF()))
|
||||||
EgtSetColor(nDwnPrcId, If(bFreeStart, COL_MCH_DISABLED, COL_MCH_DIS_INTERF))
|
EgtSetColor(nDwnPrcId, If(bFreeStart, COL_MCH_DISABLED(), COL_MCH_DIS_INTERF()))
|
||||||
Dim bFreeEnd As Boolean = (nInterf And FMI_TYPE.LO) <> FMI_TYPE.LO
|
Dim bFreeEnd As Boolean = (nInterf And FMI_TYPE.LO) <> FMI_TYPE.LO
|
||||||
EgtSetColor(nPocId, If(bFreeEnd, COL_MCH_DISABLED, COL_MCH_DIS_INTERF))
|
EgtSetColor(nPocId, If(bFreeEnd, COL_MCH_DISABLED(), COL_MCH_DIS_INTERF()))
|
||||||
EgtSetColor(nDwnPocId, If(bFreeEnd, COL_MCH_DISABLED, COL_MCH_DIS_INTERF))
|
EgtSetColor(nDwnPocId, If(bFreeEnd, COL_MCH_DISABLED(), COL_MCH_DIS_INTERF()))
|
||||||
Else
|
Else
|
||||||
Dim colCut As Color3d
|
Dim colCut As Color3d
|
||||||
If bOnMach Then
|
If bOnMach Then
|
||||||
@@ -341,6 +343,7 @@ Public Module SplitAuto
|
|||||||
Dim ptOri As Point3d
|
Dim ptOri As Point3d
|
||||||
EgtGetTableRef(1, ptOri)
|
EgtGetTableRef(1, ptOri)
|
||||||
Dim vtOri As New Vector3d(ptOri.x, ptOri.y, ptOri.z)
|
Dim vtOri As New Vector3d(ptOri.x, ptOri.y, ptOri.z)
|
||||||
|
' ---------------------------------- GREZZI ----------------------------------
|
||||||
' Eseguo eventuali spezzature dei grezzi e vi sposto i pezzi (i grezzi devono essere sempre copiati per Registrazione con rotazione)
|
' Eseguo eventuali spezzature dei grezzi e vi sposto i pezzi (i grezzi devono essere sempre copiati per Registrazione con rotazione)
|
||||||
Dim nRawId As Integer = EgtGetFirstRawPart()
|
Dim nRawId As Integer = EgtGetFirstRawPart()
|
||||||
While nRawId <> GDB_ID.NULL
|
While nRawId <> GDB_ID.NULL
|
||||||
@@ -363,6 +366,13 @@ Public Module SplitAuto
|
|||||||
vNewRaws.Add(nNewRawId)
|
vNewRaws.Add(nNewRawId)
|
||||||
nNewRawId = EgtGetNextRawPart(nNewRawId)
|
nNewRawId = EgtGetNextRawPart(nNewRawId)
|
||||||
End While
|
End While
|
||||||
|
Else
|
||||||
|
' verifico che nella fase precedente è stato definito come sfrido, allora lo riassegno
|
||||||
|
Dim nVal As Integer = 0
|
||||||
|
EgtGetInfo(nRawId, K_ISNEWSCRAPS, nVal)
|
||||||
|
If nVal = 1 Or nVal = 2 Or nVal = 3 Then
|
||||||
|
EgtSetInfo(nRaw1Id, K_ISNEWSCRAPS, "3")
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
' Assegno ai nuovi grezzi eventuale texture del grezzo originale
|
' Assegno ai nuovi grezzi eventuale texture del grezzo originale
|
||||||
Dim nSolidId = EgtGetFirstNameInGroup(nRawId, NAME_RAW_SOLID)
|
Dim nSolidId = EgtGetFirstNameInGroup(nRawId, NAME_RAW_SOLID)
|
||||||
@@ -385,10 +395,19 @@ Public Module SplitAuto
|
|||||||
' passo al successivo grezzo
|
' passo al successivo grezzo
|
||||||
nRawId = EgtGetNextRawPart(nRawId)
|
nRawId = EgtGetNextRawPart(nRawId)
|
||||||
End While
|
End While
|
||||||
|
' ---------------------------------- GREZZI ----------------------------------
|
||||||
' Cancello preview dei tagli allungati dalla lavorazione
|
' Cancello preview dei tagli allungati dalla lavorazione
|
||||||
For Each nCut As Integer In vCuts
|
For Each nCut As Integer In vCuts
|
||||||
RemoveMachiningPreview(nCut)
|
RemoveMachiningPreview(nCut)
|
||||||
Next
|
Next
|
||||||
|
' ---------------------------------- LAVORAZIONI ----------------------------------
|
||||||
|
ChangeOperationPhase(nNewPhase)
|
||||||
|
' ---------------------------------- LAVORAZIONI ----------------------------------
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' Sposta le lavorzioni della fase precedente a quella indicata
|
||||||
|
Friend Sub ChangeOperationPhase_ERR(nNewPhase As Integer)
|
||||||
' Sposto tutte le lavorazioni disabilitate e le eventuali inglobate nella nuova fase
|
' Sposto tutte le lavorazioni disabilitate e le eventuali inglobate nella nuova fase
|
||||||
Dim nId = EgtGetFirstOperation()
|
Dim nId = EgtGetFirstOperation()
|
||||||
While nId <> GDB_ID.NULL
|
While nId <> GDB_ID.NULL
|
||||||
@@ -409,9 +428,50 @@ Public Module SplitAuto
|
|||||||
End If
|
End If
|
||||||
nId = nNextId
|
nId = nNextId
|
||||||
End While
|
End While
|
||||||
Return True
|
End Sub
|
||||||
End Function
|
|
||||||
|
|
||||||
|
' Miglioramento della gestione delle lavorazioni
|
||||||
|
Friend Sub ChangeOperationPhase(nNewPhase As Integer)
|
||||||
|
' creo l'elenco delle lavorazioni che devono essere sposate
|
||||||
|
Dim MchList As New List(Of Integer)
|
||||||
|
' Recupero le lavorazioni disabilitate e le eventuali inglobate nella nuova fase
|
||||||
|
Dim nId = EgtGetFirstOperation()
|
||||||
|
While nId <> GDB_ID.NULL
|
||||||
|
Dim nNextId = EgtGetNextOperation(nId)
|
||||||
|
If IsValidMachining(nId) And EgtGetOperationPhase(nId) = nNewPhase - 1 And EgtExistsInfo(nId, INFO_MCH_USER_OFF) Then
|
||||||
|
' Provo ad inserire la lavorazione nell'elenco
|
||||||
|
AddMach(MchList, nId)
|
||||||
|
' sposto le inglobate
|
||||||
|
Dim sInfo As String = String.Empty
|
||||||
|
If EgtGetInfo(nId, INFO_MCH_OTHMID, sInfo) Then
|
||||||
|
Dim sItems() As String = sInfo.Split(",".ToCharArray)
|
||||||
|
For Each sId2 As String In sItems
|
||||||
|
Dim nId2 As Integer = 0
|
||||||
|
StringToInt(sId2, nId2)
|
||||||
|
If nId2 > 0 Then
|
||||||
|
' Provo ad inserire la lavorazione nell'elenco
|
||||||
|
AddMach(MchList, nId2)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
nId = nNextId
|
||||||
|
End While
|
||||||
|
' Procedo ora a spostare le lavorazioni nella nuova disposizione
|
||||||
|
For Each ItemMchId As Integer In MchList
|
||||||
|
EgtChangeOperationPhase(ItemMchId, nNewPhase)
|
||||||
|
Next
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' Inserisce gli inidici delle lavorazioni evitando di inserire dei doppioni
|
||||||
|
Private Sub AddMach(MchList As List(Of Integer), IdMch As Integer)
|
||||||
|
For Each Item As Integer In MchList
|
||||||
|
If IdMch = Item Then
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
MchList.Add(IdMch)
|
||||||
|
End Sub
|
||||||
'-----------------------------------------------------------------------------------------------
|
'-----------------------------------------------------------------------------------------------
|
||||||
Friend Function CalculateSplitAuto() As Boolean
|
Friend Function CalculateSplitAuto() As Boolean
|
||||||
' Fase iniziale
|
' Fase iniziale
|
||||||
|
|||||||
@@ -63,17 +63,27 @@
|
|||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<ListBox Name="MachiningLsBx" Grid.Row="1" ItemTemplate="{DynamicResource NameIdLsBxItem}"
|
<ListBox Name="MachiningLsBx" Grid.Row="1"
|
||||||
SelectionMode="Extended">
|
SelectionMode="Extended">
|
||||||
<ListBox.ItemContainerStyle>
|
<ListBox.ItemTemplate>
|
||||||
<Style TargetType="ListBoxItem">
|
<DataTemplate>
|
||||||
|
<TextBlock Text="{Binding Name}">
|
||||||
|
<TextBlock.Style>
|
||||||
|
<Style TargetType="TextBlock" BasedOn="{StaticResource OmagCut_CurrProjSummeryTextBlock}">
|
||||||
<Style.Triggers>
|
<Style.Triggers>
|
||||||
<DataTrigger Binding="{Binding bIsActive}" Value="False">
|
<DataTrigger Binding="{Binding bIsActive}" Value="False">
|
||||||
|
<Setter Property="TextDecorations" Value="Strikethrough"/>
|
||||||
<Setter Property="Foreground" Value="{StaticResource OmagCut_White}"/>
|
<Setter Property="Foreground" Value="{StaticResource OmagCut_White}"/>
|
||||||
</DataTrigger>
|
</DataTrigger>
|
||||||
|
<DataTrigger Binding="{Binding bIsActive}" Value="True">
|
||||||
|
<Setter Property="Foreground" Value="Black"/>
|
||||||
|
</DataTrigger>
|
||||||
</Style.Triggers>
|
</Style.Triggers>
|
||||||
</Style>
|
</Style>
|
||||||
</ListBox.ItemContainerStyle>
|
</TextBlock.Style>
|
||||||
|
</TextBlock>
|
||||||
|
</DataTemplate>
|
||||||
|
</ListBox.ItemTemplate>
|
||||||
</ListBox>
|
</ListBox>
|
||||||
|
|
||||||
<Grid Grid.Row="2">
|
<Grid Grid.Row="2">
|
||||||
@@ -122,13 +132,32 @@
|
|||||||
<Button Name="CutBtn" Grid.Column="0" Style="{DynamicResource OmagCut_YellowIconButton}">
|
<Button Name="CutBtn" Grid.Column="0" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
<Image Source="{DynamicResource Allunga-AccorciaImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
<Image Source="{DynamicResource Allunga-AccorciaImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
<Button Name="CutStartBtn" Grid.Column="1" Style="{DynamicResource OmagCut_YellowIconButton}">
|
<Button Name="CutStartBtn" Grid.Column="1" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
<Image Source="{DynamicResource Inizio-Allunga-AccorciaImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
<Image Source="{DynamicResource Inizio-Allunga-AccorciaImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
<Button Name="CutEndBtn" Grid.Column="2" Style="{DynamicResource OmagCut_YellowIconButton}">
|
<Button Name="CutEndBtn" Grid.Column="2" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
<Image Source="{DynamicResource Fine-Allunga-AccorciaImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
<Image Source="{DynamicResource Fine-Allunga-AccorciaImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
|
<!-- solo per macchine con lavorazioni Waterjet -->
|
||||||
|
<ToggleButton Name="BridgesWJBtn" Grid.Column="0" Style="{DynamicResource OmagCut_YellowIconToggleButton}">
|
||||||
|
<Image Source="{DynamicResource PonticelliWJImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
|
</ToggleButton>
|
||||||
|
|
||||||
|
<!--solo per macchine con lavorazioni Waterjet-->
|
||||||
|
<Button Name="QualityWJBtn" Grid.Column="1" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Image Source="{DynamicResource QualityWJImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<!-- solo per macchine con lavorazioni Waterjet -->
|
||||||
|
<ToggleButton Name="BridgesDeleteWJBtn" Grid.Column="3" Style="{DynamicResource OmagCut_YellowIconToggleButton}">
|
||||||
|
<Image Source="{DynamicResource PonticelliDeleteWJImg}" Style="{StaticResource OmagCut_ArrowButtonIcon}"/>
|
||||||
|
</ToggleButton>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -7,12 +7,13 @@ Public Class SplitPageUC
|
|||||||
' Riferimento alla MainWindow
|
' Riferimento alla MainWindow
|
||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
||||||
|
|
||||||
' Flag di pagina attiva
|
' Flag di pagina attiva
|
||||||
Private m_bActive As Boolean = False
|
Private m_bActive As Boolean = False
|
||||||
' Tipo movimento dei grezzi (manuale o con testa ventosa)
|
' Tipo movimento dei grezzi (manuale o con testa ventosa)
|
||||||
Private m_bByHand As Boolean = True
|
Private m_bByHand As Boolean = True
|
||||||
' Abilitazione movimento finale pezzi su tavola ausiliaria
|
' Abilitazione movimento finale pezzi su tavola ausiliaria
|
||||||
Private m_bEnableOnAuxTab As Boolean = False
|
Friend m_bEnableOnAuxTab As Boolean = False
|
||||||
' Stato
|
' Stato
|
||||||
Private m_nCurrPhase As Integer = 0
|
Private m_nCurrPhase As Integer = 0
|
||||||
Private m_MachiningList As New List(Of SplitMach)
|
Private m_MachiningList As New List(Of SplitMach)
|
||||||
@@ -26,6 +27,19 @@ Public Class SplitPageUC
|
|||||||
' verifico che le lavorazioni selezionate siano omogenee (con lo stesso utensile)
|
' verifico che le lavorazioni selezionate siano omogenee (con lo stesso utensile)
|
||||||
Private m_bAreHomogeneous As Boolean = False
|
Private m_bAreHomogeneous As Boolean = False
|
||||||
|
|
||||||
|
' Id tagli WJ per generazione ponticelli tra due percorsi
|
||||||
|
Private m_nIdSelectedPartWJ_Srt As Integer = GDB_ID.NULL
|
||||||
|
Private m_nIdSelectedSideWJ_Srt As Integer = GDB_ID.NULL
|
||||||
|
Private m_nIdSelectedWaterJet_Srt As Integer = GDB_ID.NULL
|
||||||
|
Private m_nIdSelectedPartWJ_End As Integer = GDB_ID.NULL
|
||||||
|
Private m_nIdSelectedSideWJ_End As Integer = GDB_ID.NULL
|
||||||
|
Private m_nIdSelectedWaterJet_End As Integer = GDB_ID.NULL
|
||||||
|
' Id gruppo Bridges (Nuovo da versione 30/08/2022)
|
||||||
|
Private m_nIdBridgesGroup As Integer = GDB_ID.NULL
|
||||||
|
Private m_nIdBridge As Integer = GDB_ID.NULL
|
||||||
|
Private m_ptSrtBridge As New Point3d
|
||||||
|
Private m_ptEndBridge As New Point3d
|
||||||
|
|
||||||
Private m_ItemList As New ObservableCollection(Of NameIdLsBxItem)
|
Private m_ItemList As New ObservableCollection(Of NameIdLsBxItem)
|
||||||
'Private m_CurrInd As Integer = -1
|
'Private m_CurrInd As Integer = -1
|
||||||
'Private m_CurrItems As New List(Of NameIdLsBxItem)
|
'Private m_CurrItems As New List(Of NameIdLsBxItem)
|
||||||
@@ -35,6 +49,7 @@ Public Class SplitPageUC
|
|||||||
Private m_bModified As Boolean = False
|
Private m_bModified As Boolean = False
|
||||||
Private m_nNbrGrpId As Integer = GDB_ID.NULL
|
Private m_nNbrGrpId As Integer = GDB_ID.NULL
|
||||||
Private m_bToNext As Boolean = False
|
Private m_bToNext As Boolean = False
|
||||||
|
Private m_bToPrev As Boolean = False
|
||||||
Friend m_bOnAuxTab As Boolean = False
|
Friend m_bOnAuxTab As Boolean = False
|
||||||
' Drag
|
' Drag
|
||||||
Private m_nDragInd As Integer = -1
|
Private m_nDragInd As Integer = -1
|
||||||
@@ -43,6 +58,8 @@ Public Class SplitPageUC
|
|||||||
Private m_bDragging As Boolean = False
|
Private m_bDragging As Boolean = False
|
||||||
' Selected cut
|
' Selected cut
|
||||||
Private m_nSelected As Integer = GDB_ID.NULL
|
Private m_nSelected As Integer = GDB_ID.NULL
|
||||||
|
' Abilita la mofica Inizio fine per i tagli interni sugli angoli
|
||||||
|
Private m_StartEndModifyOnIntCorner As Boolean = False
|
||||||
|
|
||||||
Private Sub SplitPageUC_Initialized(sender As Object, e As EventArgs)
|
Private Sub SplitPageUC_Initialized(sender As Object, e As EventArgs)
|
||||||
PrevBtn.IsEnabled = False
|
PrevBtn.IsEnabled = False
|
||||||
@@ -70,6 +87,8 @@ Public Class SplitPageUC
|
|||||||
ModifyBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 17) ' Modifica
|
ModifyBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 17) ' Modifica
|
||||||
AutoBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 18) ' Auto
|
AutoBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 18) ' Auto
|
||||||
RestartBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 19) ' Restart
|
RestartBtn.Content = EgtMsg(MSG_SPLITPAGEUC + 19) ' Restart
|
||||||
|
BridgesWJBtn.ToolTip = "Bridges"
|
||||||
|
BridgesDeleteWJBtn.ToolTip = "Remove bridges"
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub SplitPageUC_Loaded(sender As Object, e As EventArgs) Handles Me.Loaded
|
Private Sub SplitPageUC_Loaded(sender As Object, e As EventArgs) Handles Me.Loaded
|
||||||
@@ -90,6 +109,8 @@ Public Class SplitPageUC
|
|||||||
m_bEnableOnAuxTab = Not m_bByHand AndAlso
|
m_bEnableOnAuxTab = Not m_bByHand AndAlso
|
||||||
m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.MOVE_PARTS) AndAlso
|
m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.MOVE_PARTS) AndAlso
|
||||||
EgtGetTableId(AUX_TAB) <> GDB_ID.NULL
|
EgtGetTableId(AUX_TAB) <> GDB_ID.NULL
|
||||||
|
' verifico se è abilitata la possibiltà di allungare i lati interni
|
||||||
|
m_StartEndModifyOnIntCorner = (GetPrivateProfileInt(S_NEST, K_STARTENDMODIFYONINTCORNER, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
' Nascondo eventuali pezzi in parcheggio
|
' Nascondo eventuali pezzi in parcheggio
|
||||||
HideParkedParts()
|
HideParkedParts()
|
||||||
' Nascondo eventuale contorno da foto
|
' Nascondo eventuale contorno da foto
|
||||||
@@ -147,6 +168,7 @@ Public Class SplitPageUC
|
|||||||
m_bModified = False
|
m_bModified = False
|
||||||
' Reset flag tipo uscita
|
' Reset flag tipo uscita
|
||||||
m_bToNext = False
|
m_bToNext = False
|
||||||
|
m_bToPrev = False
|
||||||
' Abilitazione bottoni
|
' Abilitazione bottoni
|
||||||
EnableButtons()
|
EnableButtons()
|
||||||
' Se sola visualizzazione, segnalazione di eventuale fase di restart
|
' Se sola visualizzazione, segnalazione di eventuale fase di restart
|
||||||
@@ -160,7 +182,8 @@ Public Class SplitPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ShowMachiningList()
|
' preparo la lista delle lavorazioni da mostrare in interfaccia
|
||||||
|
Public Sub ShowMachiningList()
|
||||||
m_ItemList.Clear()
|
m_ItemList.Clear()
|
||||||
For i As Integer = 1 To m_MachiningList.Count()
|
For i As Integer = 1 To m_MachiningList.Count()
|
||||||
Dim Mach As SplitMach = m_MachiningList(i - 1)
|
Dim Mach As SplitMach = m_MachiningList(i - 1)
|
||||||
@@ -195,6 +218,243 @@ Public Class SplitPageUC
|
|||||||
Next
|
Next
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
#Region "BRIDGE"
|
||||||
|
|
||||||
|
Private Sub OnMyMouseDownSceneBridges(sender As Object, e As System.Windows.Forms.MouseEventArgs,
|
||||||
|
ByVal IsFirst As Boolean,
|
||||||
|
ByRef m_nIdSelectedSideWJ As Integer,
|
||||||
|
ByRef m_nIdSelectedWaterJet As Integer,
|
||||||
|
ByRef nIdParentPart As Integer)
|
||||||
|
|
||||||
|
' Acquisisco punto da disegno
|
||||||
|
Dim CurrPoint As New Point3d
|
||||||
|
EgtUnProjectPoint(e.Location, CurrPoint)
|
||||||
|
|
||||||
|
' Verifico se selezionato indicativo di pezzo
|
||||||
|
EgtSetObjFilterForSelWin(False, True, False, False, False)
|
||||||
|
Dim nSelMy As Integer
|
||||||
|
EgtSelect(e.Location, Scene.DIM_SEL, Scene.DIM_SEL, nSelMy)
|
||||||
|
Dim nIdMy As Integer = EgtGetFirstObjInSelWin()
|
||||||
|
While nIdMy <> GDB_ID.NULL
|
||||||
|
Dim sLayer As String = String.Empty
|
||||||
|
' layer di origine
|
||||||
|
Dim nIdParent As Integer = EgtGetParent(nIdMy)
|
||||||
|
' recupero il nome del Layer
|
||||||
|
EgtGetName(nIdParent, sLayer)
|
||||||
|
' solo se il nome del layer è quello associato ad un lato esterno allora procedo con l'evidenziazione
|
||||||
|
If sLayer = NAME_OUTLOOP Then
|
||||||
|
If (EgtGetType(nIdMy) = GDB_TY.CRV_ARC OrElse EgtGetType(nIdMy) = GDB_TY.CRV_COMPO OrElse EgtGetType(nIdMy) = GDB_TY.CRV_LINE) AndAlso VerifySideIsAcceptable(nIdMy) Then
|
||||||
|
If m_nIdSelectedSideWJ <> GDB_ID.NULL Or m_nIdSelectedSideWJ = nIdMy Then
|
||||||
|
EgtDeselectObj(m_nIdSelectedSideWJ)
|
||||||
|
End If
|
||||||
|
' recupero il gruppo della lavorazione associata
|
||||||
|
nIdParentPart = EgtGetParent(nIdParent)
|
||||||
|
' se non esiste almeno 1 Preview di tipo WaterJet
|
||||||
|
If IsWaterJetting(nIdMy) Then
|
||||||
|
' NON RECUPERO LA PREVIEW DELLA LAVORAZIONE → m_nIdSelectedWaterJet
|
||||||
|
m_nIdSelectedSideWJ = nIdMy
|
||||||
|
' recupero il punto più vicino alla curva passata
|
||||||
|
If IsFirst Then
|
||||||
|
EgtNearPoint(nIdMy, CurrPoint, GDB_RT.GLOB, m_ptSrtBridge)
|
||||||
|
Else
|
||||||
|
' prima di confermare verifico che non ci siano interferenze
|
||||||
|
EgtNearPoint(nIdMy, CurrPoint, GDB_RT.GLOB, m_ptEndBridge)
|
||||||
|
EgtModifyCurveEndPoint(m_nIdBridge, m_ptEndBridge, GDB_RT.GLOB)
|
||||||
|
If VerifyInterference(m_nIdBridge) Then
|
||||||
|
m_CurrProjPage.ClearMessage()
|
||||||
|
EgtSetInfo(m_nIdBridge, "PartStart", m_nIdSelectedPartWJ_Srt)
|
||||||
|
EgtSetInfo(m_nIdBridge, "EntStart", m_nIdSelectedSideWJ_Srt)
|
||||||
|
EgtSetInfo(m_nIdBridge, "PartEnd", m_nIdSelectedPartWJ_End)
|
||||||
|
EgtSetInfo(m_nIdBridge, "EntEnd", m_nIdSelectedSideWJ_End)
|
||||||
|
EgtSetInfo(m_nIdBridge, "Ph", EgtGetCurrPhase())
|
||||||
|
' Ricalcolo tutte le lavorazioni
|
||||||
|
Dim nWarn As Integer = 0
|
||||||
|
ResetAllMachinings(nWarn)
|
||||||
|
Else
|
||||||
|
' attendo la selezione di un punto valido
|
||||||
|
m_nIdSelectedSideWJ = GDB_ID.NULL
|
||||||
|
nIdParentPart = GDB_ID.NULL
|
||||||
|
m_CurrProjPage.ClearMessage()
|
||||||
|
m_CurrProjPage.SetWarningMessage("Bridge intersects part")
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' salvo il valore del PreView evidenziato
|
||||||
|
EgtSetMark(nIdParentPart)
|
||||||
|
' EgtSetMark(nIdWJ)
|
||||||
|
EgtSelectObj(nIdMy)
|
||||||
|
EgtDraw()
|
||||||
|
Exit While
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
nIdMy = EgtGetNextObjInSelWin()
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub OnMyMouseDownSceneBridgesDelete(sender As Object, e As System.Windows.Forms.MouseEventArgs)
|
||||||
|
' Acquisisco punto da disegno
|
||||||
|
Dim CurrPoint As New Point3d
|
||||||
|
EgtUnProjectPoint(e.Location, CurrPoint)
|
||||||
|
|
||||||
|
' Verifico se selezionato indicativo di pezzo
|
||||||
|
EgtSetObjFilterForSelWin(False, True, False, False, False)
|
||||||
|
Dim nSelMy As Integer
|
||||||
|
EgtSelect(e.Location, Scene.DIM_SEL, Scene.DIM_SEL, nSelMy)
|
||||||
|
Dim nIdMy As Integer = EgtGetFirstObjInSelWin()
|
||||||
|
While nIdMy <> GDB_ID.NULL
|
||||||
|
Dim sGroupName As String = String.Empty
|
||||||
|
Dim sSelName As String = String.Empty
|
||||||
|
' gruppo di appartenenza
|
||||||
|
Dim nIdParent As Integer = EgtGetParent(nIdMy)
|
||||||
|
' recupero il nome del gruppo di appartenenza
|
||||||
|
EgtGetName(nIdParent, sGroupName)
|
||||||
|
' recupero il nome dell'oggetto selezionato
|
||||||
|
EgtGetName(nIdMy, sSelName)
|
||||||
|
If sGroupName.Contains(BRIDGES) AndAlso sSelName.Contains(BRIDGELINE) Then
|
||||||
|
EgtErase(nIdMy)
|
||||||
|
EgtDraw()
|
||||||
|
' Ricalcolo tutte le lavorazioni
|
||||||
|
Dim nWarn As Integer = 0
|
||||||
|
ResetAllMachinings(nWarn)
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
nIdMy = EgtGetNextObjInSelWin()
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub OnMyMouseMoveSceneBridges(ptCurr As Point3d)
|
||||||
|
ptCurr.z = m_ptSrtBridge.z
|
||||||
|
' rappresento il egmento
|
||||||
|
If m_nIdBridge = GDB_ID.NULL Then
|
||||||
|
m_nIdBridge = EgtCreateLine(m_nIdBridgesGroup, m_ptSrtBridge, ptCurr, GDB_RT.GLOB)
|
||||||
|
' assegno un nome alla linea
|
||||||
|
EgtSetName(m_nIdBridge, BRIDGELINE)
|
||||||
|
End If
|
||||||
|
EgtModifyCurveEndPoint(m_nIdBridge, ptCurr, GDB_RT.GLOB)
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Function VerifyInterference(nIdBridge As Integer) As Boolean
|
||||||
|
' prima di procedere alla verifica accorco il segmento (solo per sicurezza) 10 * EPS_SMALL
|
||||||
|
Dim dLen As Double
|
||||||
|
EgtCurveLength(nIdBridge, dLen)
|
||||||
|
If dLen > 21 AndAlso Not EgtCurveIsClosed(nIdBridge) Then
|
||||||
|
EgtTrimCurveEndAtLen(nIdBridge, dLen - 10 * EPS_SMALL)
|
||||||
|
EgtTrimCurveStartAtLen(nIdBridge, 10 * EPS_SMALL)
|
||||||
|
End If
|
||||||
|
' EgtSaveFile("c:\EgtData\OmagCUT\Temp\Bridge.nge", NGE.BIN)
|
||||||
|
Dim nIdPart As Integer = GDB_ID.NULL
|
||||||
|
nIdPart = EgtGetFirstPartInRawPart(m_CurrProjPage.m_nRawId)
|
||||||
|
While nIdPart <> GDB_ID.NULL
|
||||||
|
Dim nIdRegion As Integer = EgtGetFirstNameInGroup(nIdPart, "Region")
|
||||||
|
Dim nIdSurf As Integer = EgtGetFirstInGroup(nIdRegion)
|
||||||
|
While nIdSurf <> GDB_ID.NULL
|
||||||
|
If EgtGetType(nIdSurf) = GDB_TY.SRF_FRGN Then
|
||||||
|
' EgtSaveFile("c:\EgtData\OmagCUT\Temp\Bridge.nge", NGE.BIN)
|
||||||
|
' se la linea bridge interseca la superficie allora restitusco false
|
||||||
|
If EgtCurveWithRegionClassify(nIdBridge, nIdSurf) <> CREGC.OUT Then
|
||||||
|
EgtExtendCurveStartByLen(nIdBridge, 10 * EPS_SMALL)
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
Exit While
|
||||||
|
End If
|
||||||
|
End While
|
||||||
|
nIdPart = EgtGetNextPartInRawPart(nIdPart)
|
||||||
|
End While
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Private Function VerifySideIsAcceptable(nMyId As Integer) As Boolean
|
||||||
|
Dim dVal As Double = 0
|
||||||
|
' verifico che l'entità selezionata non contenga questi parametri
|
||||||
|
If EgtGetInfo(nMyId, INFO_SIDE_ANGLE2, dVal) Then
|
||||||
|
If dVal <> 0 Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
If EgtGetInfo(nMyId, INFO_SIDE_ANGLE, dVal) Then
|
||||||
|
If dVal <> 0 Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
If EgtGetInfo(nMyId, INFO_ORIG_SIDE_ANGLE, dVal) Then
|
||||||
|
If dVal <> 0 Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' altrimenti l'entità è accettabile
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' verifico che il lato selezionato appartenga ad una lavorazione di tipo Waterjet
|
||||||
|
Private Function IsWaterJetting(nMyId As Integer) As Boolean
|
||||||
|
' verifico che sul lato indicato sia impostato un taglio di tipo WaterJet
|
||||||
|
Dim nMchId As Integer = GDB_ID.NULL
|
||||||
|
For nInd As Integer = 0 To m_MachiningList.Count() - 1
|
||||||
|
nMchId = m_MachiningList(nInd).m_nId
|
||||||
|
Dim nMachiningType As Integer = EgtGetOperationType(m_MachiningList(nInd).m_nId)
|
||||||
|
If nMachiningType = MCH_MY.WATERJETTING Then
|
||||||
|
EgtSetCurrMachining(nMchId)
|
||||||
|
Dim nIndex As Integer = 0
|
||||||
|
Dim nIdSide As Integer = GDB_ID.NULL
|
||||||
|
Dim nSub As Integer = GDB_ID.NULL
|
||||||
|
While EgtGetMachiningGeometry(nIndex, nIdSide, nSub)
|
||||||
|
If nIdSide = nMyId Then
|
||||||
|
Return True
|
||||||
|
End If
|
||||||
|
nIndex += 1
|
||||||
|
End While
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Private Sub RefreshMachList()
|
||||||
|
For nI As Integer = 0 To m_MachiningList.Count() - 1
|
||||||
|
' cancello tutti gli indici di lavorazione presenti nel disegno
|
||||||
|
Dim nNbrId As Integer = GDB_ID.NULL
|
||||||
|
EgtErase(m_MachiningList(nI).m_nNbrId)
|
||||||
|
EgtRemoveInfo(m_MachiningList(nI).m_nId, "NbrId")
|
||||||
|
Next
|
||||||
|
' Preparo la lista delle lavorazioni
|
||||||
|
CalculateSplitMachList(m_nCurrPhase, m_MachiningList)
|
||||||
|
' Aggiorno visualizzazione delle lavorazioni
|
||||||
|
For nI As Integer = 0 To m_MachiningList.Count() - 1
|
||||||
|
' sistemo colore
|
||||||
|
ColorMachining(m_MachiningList(nI))
|
||||||
|
' assegno nuova numerazione
|
||||||
|
NumberDirectionMachining(nI)
|
||||||
|
' conto il numero di tipi di lavorazioni
|
||||||
|
CountMachiningType(m_MachiningList(nI), m_nCountSawing, m_nCountWaterjetting, m_nCountOtherMachining)
|
||||||
|
Next
|
||||||
|
' aggiorno grafica
|
||||||
|
ShowMachiningList()
|
||||||
|
' aggiorno la visualizzazione
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub DeselectWJBridgesPart()
|
||||||
|
' se in fase di definzione di un ponticello lo elimino
|
||||||
|
If m_nIdSelectedSideWJ_Srt <> GDB_ID.NULL And m_nIdSelectedSideWJ_End = GDB_ID.NULL And m_nIdBridge <> GDB_ID.NULL Then
|
||||||
|
EgtErase(EgtGetParent(m_nIdBridge))
|
||||||
|
End If
|
||||||
|
m_nIdBridge = GDB_ID.NULL
|
||||||
|
EgtResetMark(m_nIdSelectedPartWJ_Srt)
|
||||||
|
m_nIdSelectedPartWJ_Srt = GDB_ID.NULL
|
||||||
|
EgtDeselectObj(m_nIdSelectedSideWJ_Srt)
|
||||||
|
m_nIdSelectedSideWJ_Srt = GDB_ID.NULL
|
||||||
|
m_nIdSelectedWaterJet_Srt = GDB_ID.NULL
|
||||||
|
EgtResetMark(m_nIdSelectedPartWJ_End)
|
||||||
|
m_nIdSelectedPartWJ_End = GDB_ID.NULL
|
||||||
|
EgtDeselectObj(m_nIdSelectedSideWJ_End)
|
||||||
|
m_nIdSelectedSideWJ_End = GDB_ID.NULL
|
||||||
|
m_nIdSelectedWaterJet_End = GDB_ID.NULL
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#End Region ' Bridge
|
||||||
|
|
||||||
Private Sub OnMyMouseDownScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseDownScene
|
Private Sub OnMyMouseDownScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseDownScene
|
||||||
' Verifico di essere il gestore attivo e non in modalità sola visualizzazione
|
' Verifico di essere il gestore attivo e non in modalità sola visualizzazione
|
||||||
If Not m_bActive OrElse m_bShow Then Return
|
If Not m_bActive OrElse m_bShow Then Return
|
||||||
@@ -203,6 +463,31 @@ Public Class SplitPageUC
|
|||||||
Not m_CurrProjPage.CurrentProjectScene.IsStatusNull() Then
|
Not m_CurrProjPage.CurrentProjectScene.IsStatusNull() Then
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' definizione dei ponticelli
|
||||||
|
If BridgesWJBtn.IsChecked Then
|
||||||
|
If m_nIdSelectedPartWJ_Srt = GDB_ID.NULL Then
|
||||||
|
OnMyMouseDownSceneBridges(sender, e, True, m_nIdSelectedSideWJ_Srt, m_nIdSelectedWaterJet_Srt, m_nIdSelectedPartWJ_Srt)
|
||||||
|
Else
|
||||||
|
OnMyMouseDownSceneBridges(sender, e, False, m_nIdSelectedSideWJ_End, m_nIdSelectedWaterJet_End, m_nIdSelectedPartWJ_End)
|
||||||
|
' aggiorno la visualizzazione delle lavorazioni e la lista
|
||||||
|
RefreshMachList()
|
||||||
|
End If
|
||||||
|
' se entrambi i pezzi sono stati definiti allora procedo alla deselezione
|
||||||
|
If m_nIdSelectedPartWJ_Srt <> GDB_ID.NULL And m_nIdSelectedPartWJ_End <> GDB_ID.NULL Then
|
||||||
|
DeselectWJBridgesPart()
|
||||||
|
End If
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
|
' eliminazione dei ponticelli
|
||||||
|
If BridgesDeleteWJBtn.IsChecked Then
|
||||||
|
OnMyMouseDownSceneBridgesDelete(sender, e)
|
||||||
|
' aggiorno la visualizzazione delle lavorazioni e la lista
|
||||||
|
RefreshMachList()
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
' Reset drag
|
' Reset drag
|
||||||
m_nDragInd = -1
|
m_nDragInd = -1
|
||||||
m_nDragType = 0
|
m_nDragType = 0
|
||||||
@@ -287,13 +572,23 @@ Public Class SplitPageUC
|
|||||||
Private Sub OnMyMouseMoveScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseMoveScene
|
Private Sub OnMyMouseMoveScene(sender As Object, e As System.Windows.Forms.MouseEventArgs) Handles m_CurrProjPage.OnMouseMoveScene
|
||||||
' Verifico di essere il gestore attivo e non in modalità sola visualizzazione
|
' Verifico di essere il gestore attivo e non in modalità sola visualizzazione
|
||||||
If Not m_bActive OrElse m_bShow Then Return
|
If Not m_bActive OrElse m_bShow Then Return
|
||||||
|
' Ricavo il punto corrente in coordinate mondo
|
||||||
|
Dim ptCurr As Point3d
|
||||||
|
EgtUnProjectPoint(e.Location, ptCurr)
|
||||||
|
|
||||||
|
' definizione dei ponticelli
|
||||||
|
If BridgesWJBtn.IsChecked Then
|
||||||
|
If m_nIdSelectedPartWJ_Srt <> GDB_ID.NULL Then
|
||||||
|
OnMyMouseMoveSceneBridges(ptCurr)
|
||||||
|
End If
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
' Se drag non abilitato o in corso
|
' Se drag non abilitato o in corso
|
||||||
If m_nDragInd = -1L Or m_bDragging Then Return
|
If m_nDragInd = -1L Or m_bDragging Then Return
|
||||||
m_bDragging = True
|
m_bDragging = True
|
||||||
Dim nOperId As Integer = m_MachiningList(m_nDragInd).m_nId
|
Dim nOperId As Integer = m_MachiningList(m_nDragInd).m_nId
|
||||||
' Ricavo il punto corrente in coordinate mondo
|
|
||||||
Dim ptCurr As Point3d
|
|
||||||
EgtUnProjectPoint(e.Location, ptCurr)
|
|
||||||
' Ricavo il vettore di movimento e la variazione di lunghezza
|
' Ricavo il vettore di movimento e la variazione di lunghezza
|
||||||
Dim vtMove As Vector3d = ptCurr - m_ptDragPrev
|
Dim vtMove As Vector3d = ptCurr - m_ptDragPrev
|
||||||
Dim dDelta = vtMove * m_MachiningList(m_nDragInd).m_vtDir
|
Dim dDelta = vtMove * m_MachiningList(m_nDragInd).m_vtDir
|
||||||
@@ -418,30 +713,8 @@ Public Class SplitPageUC
|
|||||||
MoveUpBtn.IsEnabled = False
|
MoveUpBtn.IsEnabled = False
|
||||||
MoveDownBtn.IsEnabled = False
|
MoveDownBtn.IsEnabled = False
|
||||||
End If
|
End If
|
||||||
|
' Recupero la selezione dei tagli correnti
|
||||||
GetCurrSelection()
|
GetCurrSelection()
|
||||||
|
|
||||||
'' verifico che siano contigui
|
|
||||||
'Dim bContigus As Boolean = False
|
|
||||||
'Dim OrdIndex = 0
|
|
||||||
'OrdIndex = MachiningLsBx.SelectedItems(MachiningLsBx.SelectedItems.Count - 1).Ind
|
|
||||||
'' recupero l'indice dell'ultimo elemento selezionato
|
|
||||||
'Dim LastSel As NameIdLsBxItem = MachiningLsBx.SelectedItems(MachiningLsBx.SelectedItems.Count - 1)
|
|
||||||
'If MachiningLsBx.SelectedItems.Count = 1 Then
|
|
||||||
' bContigus = True
|
|
||||||
'Else
|
|
||||||
' For Each Item As NameIdLsBxItem In ItemList
|
|
||||||
' If Item.Ind = LastSel.Ind + 1 Or Item.Ind = LastSel.Ind - 1 Then
|
|
||||||
' bContigus = True
|
|
||||||
' End If
|
|
||||||
' Next
|
|
||||||
'End If
|
|
||||||
'' se non contiguo, elimino dai selezionati il primo(che è l'ultimo ad essere stato selezionato)
|
|
||||||
'If Not bContigus Then
|
|
||||||
' ItemList.Remove(LastSel)
|
|
||||||
' MachiningLsBx.SelectedItems.RemoveAt(MachiningLsBx.SelectedItems.Count - 1)
|
|
||||||
'End If
|
|
||||||
|
|
||||||
' resetto marcatura lavorazioni
|
' resetto marcatura lavorazioni
|
||||||
If m_CurrFirstInd > -1 Then
|
If m_CurrFirstInd > -1 Then
|
||||||
For Index As Integer = m_CurrFirstInd To m_CurrLastInd
|
For Index As Integer = m_CurrFirstInd To m_CurrLastInd
|
||||||
@@ -535,6 +808,8 @@ Public Class SplitPageUC
|
|||||||
Next
|
Next
|
||||||
|
|
||||||
VerifyHomogenousMachining(ItemList)
|
VerifyHomogenousMachining(ItemList)
|
||||||
|
' Abilitazione bottone Next
|
||||||
|
EnableButtons()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub AllOnBtn_Click(sender As Object, e As RoutedEventArgs) Handles AllOnBtn.Click
|
Private Sub AllOnBtn_Click(sender As Object, e As RoutedEventArgs) Handles AllOnBtn.Click
|
||||||
@@ -641,6 +916,99 @@ Public Class SplitPageUC
|
|||||||
EnableButtons()
|
EnableButtons()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' ERRORE: questo evento non è eseguito!
|
||||||
|
Private Sub OnKeyDownScene(sender As Object, e As KeyEventArgs)
|
||||||
|
If e.Key = Key.Escape Then
|
||||||
|
' se sono in fase di creazione di un ponticello interrompo
|
||||||
|
DeselectWJBridgesPart()
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub BridgeBtn_Click(sender As Object, e As RoutedEventArgs) Handles BridgesWJBtn.Click
|
||||||
|
' eventualmente spengo il comando per eliminare i ponticelli
|
||||||
|
If BridgesDeleteWJBtn.IsChecked Then
|
||||||
|
BridgesDeleteWJBtn.IsChecked = False
|
||||||
|
End If
|
||||||
|
' se deseleziono resetto tutte le variabili
|
||||||
|
If Not BridgesWJBtn.IsChecked Then
|
||||||
|
' se sono in fase di creazione di un ponticello interrompo
|
||||||
|
DeselectWJBridgesPart()
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' recuoero il gruppo di lavorazione corrente
|
||||||
|
Dim nIdCurrMachGroup As Integer = EgtGetCurrMachGroup()
|
||||||
|
' creo il gruppo per i ponticelli
|
||||||
|
Dim sNameGroup As String = BRIDGES
|
||||||
|
Dim nId As Integer = EgtGetFirstNameInGroup(nIdCurrMachGroup, sNameGroup)
|
||||||
|
If nId <> GDB_ID.NULL Then
|
||||||
|
m_nIdBridgesGroup = nId
|
||||||
|
End If
|
||||||
|
' se non lo trovo allora lo creo
|
||||||
|
If nId = GDB_ID.NULL Then
|
||||||
|
m_nIdBridgesGroup = EgtCreateGroup(nIdCurrMachGroup)
|
||||||
|
EgtSetName(m_nIdBridgesGroup, BRIDGES)
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub BridgeDeleteBtn_Click(Sender As Object, e As RoutedEventArgs) Handles BridgesDeleteWJBtn.Click
|
||||||
|
' eventualmente spengo il comando per inserire i ponticelli
|
||||||
|
If BridgesWJBtn.IsChecked Then
|
||||||
|
BridgesWJBtn.IsChecked = False
|
||||||
|
End If
|
||||||
|
|
||||||
|
If Not BridgesDeleteWJBtn.IsChecked Then
|
||||||
|
DeselectWJBridgesPart()
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub QualityWJBtn_Click(Sender As Object, e As RoutedEventArgs) Handles QualityWJBtn.Click
|
||||||
|
Dim bFirstWJ As Boolean = True
|
||||||
|
Dim sQuality As String = String.Empty
|
||||||
|
' Recupero la lavorazione corrente
|
||||||
|
If m_CurrFirstInd = -1 Then Return
|
||||||
|
Dim bGenModif As Boolean = False
|
||||||
|
For Index As Integer = m_CurrFirstInd To m_CurrLastInd
|
||||||
|
If Not m_ItemList(Index).IsSelected Then
|
||||||
|
Continue For
|
||||||
|
End If
|
||||||
|
Dim nI As Integer = m_ItemList(Index).Ind
|
||||||
|
Dim nOperId As Integer = m_MachiningList(nI).m_nId
|
||||||
|
Dim nMachiningType As Integer = EgtGetOperationType(nOperId)
|
||||||
|
' se altrimenti getto d'acqua
|
||||||
|
If nMachiningType = MCH_MY.WATERJETTING Then
|
||||||
|
' ------------------ INIZIO PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
||||||
|
If bFirstWJ Then
|
||||||
|
EgtSetCurrMachining(nOperId)
|
||||||
|
' Dialogo richiesta valore
|
||||||
|
Dim ValWnd As New EditValueWD(m_MainWindow, m_MainWindow.m_CurrentMachine.Qualities, "Quality")
|
||||||
|
If EgtGetInfo(nOperId, "Quality", sQuality) Then
|
||||||
|
ValWnd.SetItemComboBox(sQuality)
|
||||||
|
Else
|
||||||
|
ValWnd.SetItemComboBox(m_MainWindow.m_CurrentMachine.sCurrWaterJettingQuality)
|
||||||
|
End If
|
||||||
|
If Not ValWnd.ShowDialog() Then Return
|
||||||
|
sQuality = ValWnd.GetItemComboBox
|
||||||
|
' comunico che ho letto il primo dato
|
||||||
|
bFirstWJ = False
|
||||||
|
End If
|
||||||
|
' ------------------ INIZIO PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
||||||
|
' Modifica della lavorazione
|
||||||
|
EgtSetCurrMachining(nOperId)
|
||||||
|
EgtSetInfo(nOperId, "Quality", sQuality)
|
||||||
|
UpdateMachiningPreview(m_MachiningList(nI).m_nId, True)
|
||||||
|
' verifico interferenza
|
||||||
|
bGenModif = True
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
' Se modificato qualcosa
|
||||||
|
If bGenModif Then
|
||||||
|
EgtDraw()
|
||||||
|
m_bModified = True
|
||||||
|
End If
|
||||||
|
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Function AdjustBothCuts(nI As Integer,
|
Private Function AdjustBothCuts(nI As Integer,
|
||||||
Optional bAllForced As Boolean = False,
|
Optional bAllForced As Boolean = False,
|
||||||
Optional bAccForced As Boolean = False) As Boolean
|
Optional bAccForced As Boolean = False) As Boolean
|
||||||
@@ -995,6 +1363,7 @@ Public Class SplitPageUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ModifStartBtn_Click(sender As Object, e As RoutedEventArgs) Handles ModifStartBtn.Click
|
Private Sub ModifStartBtn_Click(sender As Object, e As RoutedEventArgs) Handles ModifStartBtn.Click
|
||||||
|
Dim bLen As Boolean = True
|
||||||
' abilito la finestra per inserire i valori solo per il primo elemento della lista (di default tutti gli altri oggetti assumono lo stesso valore)
|
' abilito la finestra per inserire i valori solo per il primo elemento della lista (di default tutti gli altri oggetti assumono lo stesso valore)
|
||||||
Dim bFirstInd As Boolean = True
|
Dim bFirstInd As Boolean = True
|
||||||
Dim bFirstMill As Boolean = True
|
Dim bFirstMill As Boolean = True
|
||||||
@@ -1030,10 +1399,10 @@ Public Class SplitPageUC
|
|||||||
If bFirstInd Then
|
If bFirstInd Then
|
||||||
' Dialogo richiesta valore
|
' Dialogo richiesta valore
|
||||||
Dim ValWnd As New EditValueWD(m_MainWindow, "SAW: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
Dim ValWnd As New EditValueWD(m_MainWindow, "SAW: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
||||||
ValWnd.SetVal(dOrigUsal)
|
ValWnd.SetVal(dOrigUsal, bLen)
|
||||||
If Not ValWnd.ShowDialog() Then Return
|
If Not ValWnd.ShowDialog() Then Return
|
||||||
' carico il valore letto dal testierino virtuale
|
' carico il valore letto dal testierino virtuale
|
||||||
dUsal = ValWnd.GetVal()
|
dUsal = ValWnd.GetVal(bLen)
|
||||||
' comunico che ho letto il primo dato
|
' comunico che ho letto il primo dato
|
||||||
bFirstInd = False
|
bFirstInd = False
|
||||||
End If
|
End If
|
||||||
@@ -1042,6 +1411,8 @@ Public Class SplitPageUC
|
|||||||
Do
|
Do
|
||||||
' Se c'è limite alla lunghezza libera
|
' Se c'è limite alla lunghezza libera
|
||||||
If m_MachiningList(nI).m_dStartFreeLen < FREELEN_INF Then
|
If m_MachiningList(nI).m_dStartFreeLen < FREELEN_INF Then
|
||||||
|
' se abilitati i controlli sugli allungamenti dei lati interni
|
||||||
|
If Not m_StartEndModifyOnIntCorner Then
|
||||||
' Recupero sicurezza in corner interno
|
' Recupero sicurezza in corner interno
|
||||||
Dim dCornerSafety As Double = Math.Max(GetPrivateProfileDouble(S_MACH_NEST, K_MACH_SAFE_LEN_INTCORNER, 1, m_MainWindow.GetMachIniFile()), 10 * EPS_SMALL)
|
Dim dCornerSafety As Double = Math.Max(GetPrivateProfileDouble(S_MACH_NEST, K_MACH_SAFE_LEN_INTCORNER, 1, m_MainWindow.GetMachIniFile()), 10 * EPS_SMALL)
|
||||||
' Recupero lunghezza baffo del taglio
|
' Recupero lunghezza baffo del taglio
|
||||||
@@ -1051,12 +1422,13 @@ Public Class SplitPageUC
|
|||||||
EgtGetInfo(EgtGetFirstGroupInGroup(nPvId), "DT", dDT)
|
EgtGetInfo(EgtGetFirstGroupInGroup(nPvId), "DT", dDT)
|
||||||
dUsal = Math.Min(dUsal, m_MachiningList(nI).m_dStartFreeLen - dDT - dCornerSafety)
|
dUsal = Math.Min(dUsal, m_MachiningList(nI).m_dStartFreeLen - dDT - dCornerSafety)
|
||||||
End If
|
End If
|
||||||
|
End If
|
||||||
' Modifica della lavorazione
|
' Modifica della lavorazione
|
||||||
EgtSetCurrMachining(nOperId)
|
EgtSetCurrMachining(nOperId)
|
||||||
Dim dAddLen As Double = 0
|
Dim dAddLen As Double = 0
|
||||||
EgtGetMachiningParam(MCH_MP.STARTADDLEN, dAddLen)
|
EgtGetMachiningParam(MCH_MP.STARTADDLEN, dAddLen)
|
||||||
' verifico che non sia sull'angolo interno (altrimenti vieto la modifica)
|
' verifico che non sia sull'angolo interno (altrimenti vieto la modifica)
|
||||||
If dAddLen - dOrigUsal < -10 * EPS_SMALL Then
|
If Not m_StartEndModifyOnIntCorner And (dAddLen - dOrigUsal < -10 * EPS_SMALL) Then
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
EgtSetMachiningParam(MCH_MP.STARTADDLEN, dAddLen + dUsal - dOrigUsal)
|
EgtSetMachiningParam(MCH_MP.STARTADDLEN, dAddLen + dUsal - dOrigUsal)
|
||||||
@@ -1085,10 +1457,10 @@ Public Class SplitPageUC
|
|||||||
' ------------------ INIZIO PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
' ------------------ INIZIO PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
||||||
' Dialogo richiesta valore
|
' Dialogo richiesta valore
|
||||||
Dim ValWnd As New EditValueWD(m_MainWindow, "MILL: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
Dim ValWnd As New EditValueWD(m_MainWindow, "MILL: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
||||||
ValWnd.SetVal(dOrigUsal)
|
ValWnd.SetVal(dOrigUsal, bLen)
|
||||||
If Not ValWnd.ShowDialog() Then Return
|
If Not ValWnd.ShowDialog() Then Return
|
||||||
' carico il valore letto dal testierino virtuale
|
' carico il valore letto dal testierino virtuale
|
||||||
dUsal = ValWnd.GetVal()
|
dUsal = ValWnd.GetVal(bLen)
|
||||||
' comunico che ho letto il primo dato
|
' comunico che ho letto il primo dato
|
||||||
bFirstMill = False
|
bFirstMill = False
|
||||||
End If
|
End If
|
||||||
@@ -1166,6 +1538,7 @@ Public Class SplitPageUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ModifEndBtn_Click(sender As Object, e As RoutedEventArgs) Handles ModifEndBtn.Click
|
Private Sub ModifEndBtn_Click(sender As Object, e As RoutedEventArgs) Handles ModifEndBtn.Click
|
||||||
|
Dim bLen As Boolean = True
|
||||||
' abilito la finestra per inserire i valori solo per il primo elemento della lista (di default tutti gli altri oggetti assumono lo stesso valore)
|
' abilito la finestra per inserire i valori solo per il primo elemento della lista (di default tutti gli altri oggetti assumono lo stesso valore)
|
||||||
Dim bFirstInd As Boolean = True
|
Dim bFirstInd As Boolean = True
|
||||||
Dim bFirstMill As Boolean = True
|
Dim bFirstMill As Boolean = True
|
||||||
@@ -1200,9 +1573,9 @@ Public Class SplitPageUC
|
|||||||
If bFirstInd Then
|
If bFirstInd Then
|
||||||
' Dialogo richiesta valore
|
' Dialogo richiesta valore
|
||||||
Dim ValWnd As New EditValueWD(m_MainWindow, "SAW: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
Dim ValWnd As New EditValueWD(m_MainWindow, "SAW: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
||||||
ValWnd.SetVal(dOrigUeal)
|
ValWnd.SetVal(dOrigUeal, bLen)
|
||||||
If Not ValWnd.ShowDialog() Then Return
|
If Not ValWnd.ShowDialog() Then Return
|
||||||
dUeal = ValWnd.GetVal()
|
dUeal = ValWnd.GetVal(bLen)
|
||||||
bFirstInd = False
|
bFirstInd = False
|
||||||
End If
|
End If
|
||||||
' ------------------ FINE PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
' ------------------ FINE PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
||||||
@@ -1210,6 +1583,8 @@ Public Class SplitPageUC
|
|||||||
Do
|
Do
|
||||||
' Se c'è limite alla lunghezza libera
|
' Se c'è limite alla lunghezza libera
|
||||||
If m_MachiningList(nI).m_dEndFreeLen < FREELEN_INF Then
|
If m_MachiningList(nI).m_dEndFreeLen < FREELEN_INF Then
|
||||||
|
' se abilitati i controlli sugli allungamenti dei lati interni
|
||||||
|
If Not m_StartEndModifyOnIntCorner Then
|
||||||
' Recupero sicurezza in corner interno
|
' Recupero sicurezza in corner interno
|
||||||
Dim dCornerSafety As Double = Math.Max(GetPrivateProfileDouble(S_MACH_NEST, K_MACH_SAFE_LEN_INTCORNER, 1, m_MainWindow.GetMachIniFile()), 10 * EPS_SMALL)
|
Dim dCornerSafety As Double = Math.Max(GetPrivateProfileDouble(S_MACH_NEST, K_MACH_SAFE_LEN_INTCORNER, 1, m_MainWindow.GetMachIniFile()), 10 * EPS_SMALL)
|
||||||
' Recupero lunghezza baffo del taglio
|
' Recupero lunghezza baffo del taglio
|
||||||
@@ -1219,12 +1594,13 @@ Public Class SplitPageUC
|
|||||||
EgtGetInfo(EgtGetFirstGroupInGroup(nPvId), "DT", dDT)
|
EgtGetInfo(EgtGetFirstGroupInGroup(nPvId), "DT", dDT)
|
||||||
dUeal = Math.Min(dUeal, m_MachiningList(nI).m_dEndFreeLen - dDT - dCornerSafety)
|
dUeal = Math.Min(dUeal, m_MachiningList(nI).m_dEndFreeLen - dDT - dCornerSafety)
|
||||||
End If
|
End If
|
||||||
|
End If
|
||||||
|
|
||||||
' Modifica della lavorazione
|
' Modifica della lavorazione
|
||||||
EgtSetCurrMachining(nOperId)
|
EgtSetCurrMachining(nOperId)
|
||||||
Dim dAddLen As Double = 0
|
Dim dAddLen As Double = 0
|
||||||
EgtGetMachiningParam(MCH_MP.ENDADDLEN, dAddLen)
|
EgtGetMachiningParam(MCH_MP.ENDADDLEN, dAddLen)
|
||||||
If dAddLen - dOrigUeal < -10 * EPS_SMALL Then
|
If Not m_StartEndModifyOnIntCorner And (dAddLen - dOrigUeal < -10 * EPS_SMALL) Then
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
EgtSetMachiningParam(MCH_MP.ENDADDLEN, dAddLen + dUeal - dOrigUeal)
|
EgtSetMachiningParam(MCH_MP.ENDADDLEN, dAddLen + dUeal - dOrigUeal)
|
||||||
@@ -1252,9 +1628,9 @@ Public Class SplitPageUC
|
|||||||
If bFirstMill Then
|
If bFirstMill Then
|
||||||
' Dialogo richiesta valore
|
' Dialogo richiesta valore
|
||||||
Dim ValWnd As New EditValueWD(m_MainWindow, "MILL: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
Dim ValWnd As New EditValueWD(m_MainWindow, "MILL: " & EgtMsg(MSG_SPLITPAGEUC + 35)) ' Allungamento
|
||||||
ValWnd.SetVal(dOrigUeal)
|
ValWnd.SetVal(dOrigUeal, bLen)
|
||||||
If Not ValWnd.ShowDialog() Then Return
|
If Not ValWnd.ShowDialog() Then Return
|
||||||
dUeal = ValWnd.GetVal()
|
dUeal = ValWnd.GetVal(bLen)
|
||||||
bFirstMill = False
|
bFirstMill = False
|
||||||
End If
|
End If
|
||||||
' ------------------ FINE PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
' ------------------ FINE PREPARAZIONE TASTIERINO VIRTUALE ------------------
|
||||||
@@ -1387,15 +1763,36 @@ Public Class SplitPageUC
|
|||||||
Private Sub PrevBtn_Click(sender As Object, e As RoutedEventArgs) Handles PrevBtn.Click
|
Private Sub PrevBtn_Click(sender As Object, e As RoutedEventArgs) Handles PrevBtn.Click
|
||||||
' Dichiaro solo visualizzazione
|
' Dichiaro solo visualizzazione
|
||||||
m_bShow = True
|
m_bShow = True
|
||||||
' Esco
|
'' Esco
|
||||||
ExitSplit(False)
|
'ExitSplit(False)
|
||||||
' Torno alla fase precedente
|
' Torno alla fase precedente
|
||||||
EgtSetCurrPhase(EgtGetCurrPhase() - 1)
|
Dim nCurrPhase As Integer = EgtGetCurrPhase()
|
||||||
|
' se questa è la prima fase, non possono tornare più indietro di così
|
||||||
|
If nCurrPhase = 1 Then
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
EgtSetCurrPhase(nCurrPhase - 1)
|
||||||
|
m_bToPrev = True
|
||||||
' Reimposto la precedente
|
' Reimposto la precedente
|
||||||
SplitPageUC_Loaded(Nothing, Nothing)
|
'SplitPageUC_Loaded(Nothing, Nothing)
|
||||||
|
' torno alla disposizione della fase corrente
|
||||||
|
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Remove(m_MainWindow.m_CadCutPageUC.m_SplitPage)
|
||||||
|
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Add(m_MainWindow.m_CadCutPageUC.m_MoveRawPartPage)
|
||||||
|
m_MainWindow.m_CadCutPageUC.m_CadCutMode = CadCutPageUC.CadCutModes.MoveRawPart
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub NextBtn_Click(sender As Object, e As RoutedEventArgs) Handles NextBtn.Click
|
Private Sub NextBtn_Click(sender As Object, e As RoutedEventArgs) Handles NextBtn.Click
|
||||||
|
' ------- VISUALIZZAZIONE -------
|
||||||
|
If m_bShow Then
|
||||||
|
Dim CurrDisposition As Integer = EgtGetPhaseDisposition(m_nCurrPhase)
|
||||||
|
' recupero l'operazione successiva
|
||||||
|
Dim NextDisposition As Integer = EgtGetNextOperation(CurrDisposition)
|
||||||
|
If Not IsNothing(m_MainWindow.m_CadCutPageUC.m_MoveRawPartPage) Then
|
||||||
|
' verifico che l'operazione sia una disposizione, altrimenti cerco
|
||||||
|
NextDisposition = m_MainWindow.m_CadCutPageUC.m_MoveRawPartPage.GetNextDisposition(NextDisposition)
|
||||||
|
m_bOnAuxTab = m_MainWindow.m_CadCutPageUC.m_MoveRawPartPage.IsDispUnloadOnAuxTab(NextDisposition)
|
||||||
|
End If
|
||||||
|
End If
|
||||||
m_bToNext = True
|
m_bToNext = True
|
||||||
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Remove(m_MainWindow.m_CadCutPageUC.m_SplitPage)
|
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Remove(m_MainWindow.m_CadCutPageUC.m_SplitPage)
|
||||||
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Add(m_MainWindow.m_CadCutPageUC.m_MoveRawPartPage)
|
m_MainWindow.m_CadCutPageUC.CadCutPageGrid.Children.Add(m_MainWindow.m_CadCutPageUC.m_MoveRawPartPage)
|
||||||
@@ -1467,8 +1864,37 @@ Public Class SplitPageUC
|
|||||||
' assegno numerazione
|
' assegno numerazione
|
||||||
NumberDirectionMachining(nI)
|
NumberDirectionMachining(nI)
|
||||||
Next
|
Next
|
||||||
|
|
||||||
|
' -------------------- Recupero le lavorazioni indicate come attive --------------------
|
||||||
|
Dim ActiveMachLst As New List(Of Integer)
|
||||||
|
For Each ItemSplitMach As NameIdLsBxItem In m_ItemList
|
||||||
|
ActiveMachLst.Add(ItemSplitMach.Ind)
|
||||||
|
Next
|
||||||
|
' -------------------- Recupero le lavorazioni indicate come attive --------------------
|
||||||
|
|
||||||
' Preparo la lista degli Item
|
' Preparo la lista degli Item
|
||||||
ShowMachiningList()
|
ShowMachiningList()
|
||||||
|
|
||||||
|
' -------------------- Riattivo le lavorazioni precedenti --------------------
|
||||||
|
|
||||||
|
For Each Item As SplitMach In m_MachiningList
|
||||||
|
EgtSetInfo(Item.m_nId, INFO_MCH_USER_OFF, True)
|
||||||
|
Next
|
||||||
|
|
||||||
|
For nIndex As Integer = 0 To ActiveMachLst.Count - 1
|
||||||
|
For Each ItemSplitMach As NameIdLsBxItem In m_ItemList
|
||||||
|
If ItemSplitMach.Ind = ActiveMachLst(nIndex) Then
|
||||||
|
EgtRemoveInfo(m_MachiningList(ItemSplitMach.Ind).m_nId, INFO_MCH_USER_OFF)
|
||||||
|
m_MachiningList(ItemSplitMach.Ind).m_bEnabled = True
|
||||||
|
ItemSplitMach.bIsActive = True
|
||||||
|
' sistemo colore
|
||||||
|
ColorMachining(m_MachiningList(ItemSplitMach.Ind))
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
Next
|
||||||
|
' -------------------- Riattivo le lavorazioni precedenti --------------------
|
||||||
|
|
||||||
' Aggiorno visualizzazione
|
' Aggiorno visualizzazione
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
' Aggiono abilitazione bottoni
|
' Aggiono abilitazione bottoni
|
||||||
@@ -1478,11 +1904,15 @@ Public Class SplitPageUC
|
|||||||
Private Sub SplitPageUC_Unloaded(sender As Object, e As EventArgs) Handles Me.Unloaded
|
Private Sub SplitPageUC_Unloaded(sender As Object, e As EventArgs) Handles Me.Unloaded
|
||||||
m_bActive = False
|
m_bActive = False
|
||||||
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
ExitSplit(Not m_bToNext)
|
ExitSplit(Not m_bToNext And Not m_bToPrev)
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Sub ExitSplit(Optional bTrueExit As Boolean = True)
|
Friend Sub ExitSplit(Optional bTrueExit As Boolean = True)
|
||||||
|
DeselectWJBridgesPart()
|
||||||
|
BridgesWJBtn.IsChecked = False
|
||||||
|
BridgesDeleteWJBtn.IsChecked = False
|
||||||
|
|
||||||
' Rimuovo evidenziazione e numeri
|
' Rimuovo evidenziazione e numeri
|
||||||
RemoveMarkAndNumbers()
|
RemoveMarkAndNumbers()
|
||||||
' Ripristino colori lavorazioni
|
' Ripristino colori lavorazioni
|
||||||
@@ -1493,22 +1923,7 @@ Public Class SplitPageUC
|
|||||||
EgtEnableModified()
|
EgtEnableModified()
|
||||||
' se modificato salvo ordine e stato delle lavorazioni
|
' se modificato salvo ordine e stato delle lavorazioni
|
||||||
If m_bModified Then
|
If m_bModified Then
|
||||||
' Al primo posto deve rimanere la disposizione della fase
|
SaveOrderMachinig(m_nCurrPhase)
|
||||||
Dim nFirstOperId As Integer = EgtGetPhaseDisposition(m_nCurrPhase)
|
|
||||||
For i As Integer = m_ItemList.Count() - 1 To 0 Step -1
|
|
||||||
Dim nI As Integer = m_ItemList(i).Ind
|
|
||||||
Dim nMchId As Integer = m_MachiningList(nI).m_nId
|
|
||||||
EgtRelocate(nMchId, nFirstOperId, GDB_POS.AFTER)
|
|
||||||
If m_MachiningList(nI).m_bEnabled Then
|
|
||||||
EgtSetOperationMode(m_MachiningList(nI).m_nId, True)
|
|
||||||
EgtRemoveInfo(m_MachiningList(nI).m_nId, INFO_MCH_USER_OFF)
|
|
||||||
Else
|
|
||||||
EgtSetOperationMode(m_MachiningList(nI).m_nId, False)
|
|
||||||
EgtSetInfo(m_MachiningList(nI).m_nId, INFO_MCH_USER_OFF, True)
|
|
||||||
End If
|
|
||||||
Next
|
|
||||||
' dichiaro ordine salvato
|
|
||||||
m_MainWindow.m_CurrentProjectPageUC.SetOrderMachiningFlag()
|
|
||||||
End If
|
End If
|
||||||
' Affondamento ridotto
|
' Affondamento ridotto
|
||||||
Dim dReducedDepth As Double = GetPrivateProfileDouble(S_MACH_NEST, K_MACH_REDUCEDDEPTH, 1, m_MainWindow.GetMachIniFile())
|
Dim dReducedDepth As Double = GetPrivateProfileDouble(S_MACH_NEST, K_MACH_REDUCEDDEPTH, 1, m_MainWindow.GetMachIniFile())
|
||||||
@@ -1532,6 +1947,25 @@ Public Class SplitPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Friend Sub SaveOrderMachinig(CurrPhase As Integer)
|
||||||
|
' Al primo posto deve rimanere la disposizione della fase
|
||||||
|
Dim nFirstOperId As Integer = EgtGetPhaseDisposition(CurrPhase)
|
||||||
|
For i As Integer = m_ItemList.Count() - 1 To 0 Step -1
|
||||||
|
Dim nI As Integer = m_ItemList(i).Ind
|
||||||
|
Dim nMchId As Integer = m_MachiningList(nI).m_nId
|
||||||
|
EgtRelocate(nMchId, nFirstOperId, GDB_POS.AFTER)
|
||||||
|
If m_MachiningList(nI).m_bEnabled Then
|
||||||
|
EgtSetOperationMode(m_MachiningList(nI).m_nId, True)
|
||||||
|
EgtRemoveInfo(m_MachiningList(nI).m_nId, INFO_MCH_USER_OFF)
|
||||||
|
Else
|
||||||
|
EgtSetOperationMode(m_MachiningList(nI).m_nId, False)
|
||||||
|
EgtSetInfo(m_MachiningList(nI).m_nId, INFO_MCH_USER_OFF, True)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
' dichiaro ordine salvato
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.SetOrderMachiningFlag()
|
||||||
|
End Sub
|
||||||
|
|
||||||
Friend Function GetDisabledCutsCount() As Integer
|
Friend Function GetDisabledCutsCount() As Integer
|
||||||
' Determino il numero di tagli disabilitati
|
' Determino il numero di tagli disabilitati
|
||||||
Dim nCount As Integer = 0
|
Dim nCount As Integer = 0
|
||||||
@@ -1596,7 +2030,7 @@ Public Class SplitPageUC
|
|||||||
NextBtn.IsEnabled = (GetDisabledCutsCount() > 0 And GetSplitCutsCount() = 1)
|
NextBtn.IsEnabled = (GetDisabledCutsCount() > 0 And GetSplitCutsCount() = 1)
|
||||||
' Altrimenti
|
' Altrimenti
|
||||||
Else
|
Else
|
||||||
' movimento standard sulla tavola (almeno un taglio disabilitato)
|
' movimento standard sulla tavola (almeno un taglio disabilitato allora False)
|
||||||
Dim bStdTab As Boolean = (GetDisabledCutsCount() > 0)
|
Dim bStdTab As Boolean = (GetDisabledCutsCount() > 0)
|
||||||
' movimento su tavola di scarico
|
' movimento su tavola di scarico
|
||||||
m_bOnAuxTab = Not bStdTab AndAlso (m_nCurrPhase = EgtGetPhaseCount() And m_bEnableOnAuxTab)
|
m_bOnAuxTab = Not bStdTab AndAlso (m_nCurrPhase = EgtGetPhaseCount() And m_bEnableOnAuxTab)
|
||||||
@@ -1644,6 +2078,9 @@ Public Class SplitPageUC
|
|||||||
ModifEndBtn.IsEnabled = Not m_bShow
|
ModifEndBtn.IsEnabled = Not m_bShow
|
||||||
InvertBtn.IsEnabled = Not m_bShow
|
InvertBtn.IsEnabled = Not m_bShow
|
||||||
PauseBtn.IsEnabled = Not m_bShow And m_MainWindow.m_CurrentMachine.bEnablePause
|
PauseBtn.IsEnabled = Not m_bShow And m_MainWindow.m_CurrentMachine.bEnablePause
|
||||||
|
BridgesWJBtn.IsEnabled = Not m_bShow
|
||||||
|
BridgesDeleteWJBtn.IsEnabled = Not m_bShow
|
||||||
|
QualityWJBtn.IsEnabled = Not m_bShow
|
||||||
|
|
||||||
' nascondo i comandi che non devono essere visualizzati in funzione delle lavorazioni attive
|
' nascondo i comandi che non devono essere visualizzati in funzione delle lavorazioni attive
|
||||||
If m_nCountSawing = 0 And (m_nCountWaterjetting > 0 Or m_nCountOtherMachining) Then
|
If m_nCountSawing = 0 And (m_nCountWaterjetting > 0 Or m_nCountOtherMachining) Then
|
||||||
@@ -1725,6 +2162,7 @@ Public Class SplitPageUC
|
|||||||
|
|
||||||
Private Sub VisibilityButtonFromMachinig(ByVal Type As Integer)
|
Private Sub VisibilityButtonFromMachinig(ByVal Type As Integer)
|
||||||
If Type <> MCH_OY.SAWING Then
|
If Type <> MCH_OY.SAWING Then
|
||||||
|
|
||||||
CutBtn.Visibility = Visibility.Hidden
|
CutBtn.Visibility = Visibility.Hidden
|
||||||
CutStartBtn.Visibility = Visibility.Hidden
|
CutStartBtn.Visibility = Visibility.Hidden
|
||||||
CutEndBtn.Visibility = Visibility.Hidden
|
CutEndBtn.Visibility = Visibility.Hidden
|
||||||
@@ -1755,6 +2193,24 @@ Public Class SplitPageUC
|
|||||||
AllExtendBtn.Visibility = Visibility.Visible
|
AllExtendBtn.Visibility = Visibility.Visible
|
||||||
AllReduceBtn.Visibility = Visibility.Visible
|
AllReduceBtn.Visibility = Visibility.Visible
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' gestione bottone per generazione ponticelli
|
||||||
|
If Type = MCH_OY.WATERJETTING Then
|
||||||
|
' siccome la stessa posizione è occupata da due comandi sovrapposti
|
||||||
|
If CutStartBtn.Visibility = Visibility.Hidden Then
|
||||||
|
BridgesWJBtn.Visibility = Visibility.Visible
|
||||||
|
BridgesDeleteWJBtn.Visibility = Visibility.Visible
|
||||||
|
QualityWJBtn.Visibility = Visibility.Visible
|
||||||
|
Else
|
||||||
|
BridgesWJBtn.Visibility = Visibility.Hidden
|
||||||
|
BridgesDeleteWJBtn.Visibility = Visibility.Hidden
|
||||||
|
QualityWJBtn.Visibility = Visibility.Hidden
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
BridgesWJBtn.Visibility = Visibility.Hidden
|
||||||
|
BridgesDeleteWJBtn.Visibility = Visibility.Hidden
|
||||||
|
QualityWJBtn.Visibility = Visibility.Hidden
|
||||||
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function ModifyOtherLeadIn(nI As Integer, nLiOthType As Integer) As Boolean
|
Private Function ModifyOtherLeadIn(nI As Integer, nLiOthType As Integer) As Boolean
|
||||||
@@ -2006,7 +2462,7 @@ Public Class SplitPageUC
|
|||||||
m_MachiningList(nI).m_bCanStartAll = m_MachiningList(nI).m_bCanEndAll
|
m_MachiningList(nI).m_bCanStartAll = m_MachiningList(nI).m_bCanEndAll
|
||||||
m_MachiningList(nI).m_bCanEndAll = bCanAll
|
m_MachiningList(nI).m_bCanEndAll = bCanAll
|
||||||
' Swap stato interferenza
|
' Swap stato interferenza
|
||||||
if ( m_MachiningList( nI).m_nInterf And FMI_TYPE.LI) <> 0 And ( m_MachiningList( nI).m_nInterf And FMI_TYPE.LO) = 0 Then
|
If (m_MachiningList(nI).m_nInterf And FMI_TYPE.LI) <> 0 And (m_MachiningList(nI).m_nInterf And FMI_TYPE.LO) = 0 Then
|
||||||
m_MachiningList(nI).m_nInterf -= FMI_TYPE.LI
|
m_MachiningList(nI).m_nInterf -= FMI_TYPE.LI
|
||||||
m_MachiningList(nI).m_nInterf += FMI_TYPE.LO
|
m_MachiningList(nI).m_nInterf += FMI_TYPE.LO
|
||||||
ElseIf (m_MachiningList(nI).m_nInterf And FMI_TYPE.LI) = 0 And (m_MachiningList(nI).m_nInterf And FMI_TYPE.LO) <> 0 Then
|
ElseIf (m_MachiningList(nI).m_nInterf And FMI_TYPE.LI) = 0 And (m_MachiningList(nI).m_nInterf And FMI_TYPE.LO) <> 0 Then
|
||||||
|
|||||||
@@ -67,17 +67,17 @@ Module VacuumCups
|
|||||||
End Function
|
End Function
|
||||||
|
|
||||||
' carico i dati macchina relativi al peso massimo movimentabile
|
' carico i dati macchina relativi al peso massimo movimentabile
|
||||||
Friend Sub GetWeightInformation(Density As Double, MaxSingle As Double, MaxDouble As Double)
|
Friend Sub SetWeightInformation(Density As Double, MaxSingle As Double, MaxDouble As Double)
|
||||||
m_RawDensity = Density
|
m_RawDensity = Density
|
||||||
m_MaxWeightSinglePlugger = MaxSingle
|
m_MaxWeightSinglePlugger = MaxSingle
|
||||||
m_MaxWeightDoublePlugger = MaxDouble
|
m_MaxWeightDoublePlugger = MaxDouble
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Sub GetRotationForExtraStrokeY(Rotate As Boolean)
|
Friend Sub SetRotationForExtraStrokeY(Rotate As Boolean)
|
||||||
bRotateVacuumNearExtraStrokeY = Rotate
|
bRotateVacuumNearExtraStrokeY = Rotate
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Sub GetRotationForExtraStrokeX(Rotate As Boolean)
|
Friend Sub SetRotationForExtraStrokeX(Rotate As Boolean)
|
||||||
bRotateVacuumNearExtraStrokeX = Rotate
|
bRotateVacuumNearExtraStrokeX = Rotate
|
||||||
End Sub
|
End Sub
|
||||||
Friend Function GetVacuumId() As Integer
|
Friend Function GetVacuumId() As Integer
|
||||||
@@ -451,14 +451,14 @@ Module VacuumCups
|
|||||||
Dim dPreferredRot As Double = m_dPreferredRot
|
Dim dPreferredRot As Double = m_dPreferredRot
|
||||||
' -------------------- INIZIO GESTIONE ROTAZIONE ASSE C PER NON ANDARE IN EXTRA-CORSA --------------------
|
' -------------------- INIZIO GESTIONE ROTAZIONE ASSE C PER NON ANDARE IN EXTRA-CORSA --------------------
|
||||||
' verifico l'orientamento del pezzo
|
' verifico l'orientamento del pezzo
|
||||||
If bRotateVacuumNearExtraStrokeX And (Math.Abs(dRotAngDeg - 90) < 45 Or Math.Abs(dRotAngDeg - 270) < 45) Then
|
If bRotateVacuumNearExtraStrokeX And Not IsHorizontal(dAngOrizzDeg) Then
|
||||||
' se l'orientamento è verticale
|
' se l'orientamento è verticale
|
||||||
If frMinRect.Orig().x < b3Tab.Center().x Then
|
If frMinRect.Orig().x < b3Tab.Center().x Then
|
||||||
dPreferredRot = m_dPrefVertRotXMinus
|
dPreferredRot = m_dPrefVertRotXMinus
|
||||||
Else
|
Else
|
||||||
dPreferredRot = m_dPrefVertRotXPlus
|
dPreferredRot = m_dPrefVertRotXPlus
|
||||||
End If
|
End If
|
||||||
ElseIf bRotateVacuumNearExtraStrokeY And (Math.Abs(dRotAngDeg - 90) > 45 Or Math.Abs(dRotAngDeg - 270) > 45) Then
|
ElseIf bRotateVacuumNearExtraStrokeY And IsHorizontal(dAngOrizzDeg) Then
|
||||||
' se l'orientemanto è orizzontale e la macchina è stata abilitata
|
' se l'orientemanto è orizzontale e la macchina è stata abilitata
|
||||||
If frMinRect.Orig().y < b3Tab.Center().y Then
|
If frMinRect.Orig().y < b3Tab.Center().y Then
|
||||||
dPreferredRot = m_dPrefVertRotYPlus
|
dPreferredRot = m_dPrefVertRotYPlus
|
||||||
@@ -539,16 +539,34 @@ Module VacuumCups
|
|||||||
Return dDist
|
Return dDist
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
' assegante le posizioni del centro delle ventose e l'angolo di posizionamento orizzontale verifica che la posizione sia raggiungibile
|
Private Function IsHorizontal(dDegAng As Double) As Boolean
|
||||||
|
If (Math.Abs(dDegAng) > 45 And Math.Abs(dDegAng) < 135) Or (Math.Abs(dDegAng) > 225 And Math.Abs(dDegAng) < 315) Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' assegnate le posizioni del centro delle ventose e l'angolo di posizionamento orizzontale verifica che la posizione sia raggiungibile
|
||||||
Public Function VerifyOutOfStrokes(ptRef As Point3d, dRotAngDeg As Double) As Integer
|
Public Function VerifyOutOfStrokes(ptRef As Point3d, dRotAngDeg As Double) As Integer
|
||||||
Dim dX, dY, dZ As Double
|
' Posizione Home dell'asse rotante
|
||||||
Dim nStat As Integer
|
|
||||||
Dim dCHome As Double
|
Dim dCHome As Double
|
||||||
EgtGetAxisHomePos("C", dCHome)
|
EgtGetAxisHomePos("C", dCHome)
|
||||||
' imposto la l'uscita della ventosa come fosse l'uscita di un utensile
|
' Corse dell'asse
|
||||||
|
Dim dCMin As Double
|
||||||
|
EgtGetAxisMin("C", dCMin)
|
||||||
|
Dim dCMax As Double
|
||||||
|
EgtGetAxisMax("C", dCMax)
|
||||||
|
' Porto l'angolo nel range
|
||||||
|
Dim dRotAngMachDeg As Double = dRotAngDeg + dCHome
|
||||||
|
AdjustAngleInRange(dRotAngMachDeg, dCMin, dCMax)
|
||||||
|
' Imposto la ventosa come fosse un utensile
|
||||||
EgtSetCalcTool("", "H4", 1)
|
EgtSetCalcTool("", "H4", 1)
|
||||||
EgtGetCalcPositions(ptRef, dRotAngDeg + dCHome, 0, nStat, dX, dY, dZ)
|
' Calcolo gli assi macchina
|
||||||
EgtVerifyOutstroke(dX, dY, dZ, dRotAngDeg + dCHome, 0, nStat)
|
Dim dX, dY, dZ As Double
|
||||||
|
Dim nStat As Integer
|
||||||
|
EgtGetCalcPositions(ptRef, dRotAngMachDeg, 0, nStat, dX, dY, dZ)
|
||||||
|
' Verifico le corse
|
||||||
|
EgtVerifyOutstroke(dX, dY, dZ, dRotAngMachDeg, 0, nStat)
|
||||||
Return nStat
|
Return nStat
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
|||||||
@@ -189,6 +189,8 @@ Module ConstGen
|
|||||||
Public Const INFO_TOPRODAREA As String = "ToProdArea"
|
Public Const INFO_TOPRODAREA As String = "ToProdArea"
|
||||||
' Info per nome progetti
|
' Info per nome progetti
|
||||||
Public Const INFO_PROJNAME As String = "ProjName"
|
Public Const INFO_PROJNAME As String = "ProjName"
|
||||||
|
' Info per parcheggio asse C
|
||||||
|
Public Const INFO_CAXESHOME As String = "CAxesHome"
|
||||||
|
|
||||||
' Nome layer delle regioni
|
' Nome layer delle regioni
|
||||||
Public Const NAME_REGION As String = "Region"
|
Public Const NAME_REGION As String = "Region"
|
||||||
@@ -214,7 +216,8 @@ Module ConstGen
|
|||||||
Public Const INFO_DEPTH As String = "Depth"
|
Public Const INFO_DEPTH As String = "Depth"
|
||||||
Public Const INFO_WIDTH As String = "Width"
|
Public Const INFO_WIDTH As String = "Width"
|
||||||
Public Const INFO_DEPTH2 As String = "Depth2"
|
Public Const INFO_DEPTH2 As String = "Depth2"
|
||||||
Public CONST INFO_AGG2 As String = "Agg2"
|
Public Const INFO_AGG2 As String = "Agg2"
|
||||||
|
Public Const INFO_ROUNDOFF As String = "RoundOff"
|
||||||
' Info in entità da tagliare per taglio ristretto
|
' Info in entità da tagliare per taglio ristretto
|
||||||
Public Const INFO_STRICT As String = "Strict"
|
Public Const INFO_STRICT As String = "Strict"
|
||||||
' Info in entità da tagliare per angolo di lato e tallone
|
' Info in entità da tagliare per angolo di lato e tallone
|
||||||
@@ -342,6 +345,11 @@ Module ConstGen
|
|||||||
' Info in pezzo per facet di ultima superficie selezionata
|
' Info in pezzo per facet di ultima superficie selezionata
|
||||||
Public Const INFO_FRAME_FACET As String = "Facet"
|
Public Const INFO_FRAME_FACET As String = "Facet"
|
||||||
|
|
||||||
|
' Nome del groppo dei ponticelli per lavorazioni Water
|
||||||
|
Public Const BRIDGES As String = "Bridges"
|
||||||
|
' Nome dell'entità ponticello contenuta nel gruppo BRIDGES
|
||||||
|
Public Const BRIDGELINE As String = "BridgeLine"
|
||||||
|
|
||||||
' utensile per le lavorazioni manuali
|
' utensile per le lavorazioni manuali
|
||||||
Public Const DUMMY_SAW As String = "DummySAW"
|
Public Const DUMMY_SAW As String = "DummySAW"
|
||||||
' lavorazione manuale
|
' lavorazione manuale
|
||||||
@@ -385,6 +393,9 @@ Module ConstGen
|
|||||||
Public Function COL_MCH_DRIPCUT() As Color3d
|
Public Function COL_MCH_DRIPCUT() As Color3d
|
||||||
Return New Color3d(255, 0, 165)
|
Return New Color3d(255, 0, 165)
|
||||||
End Function
|
End Function
|
||||||
|
Public Function COL_MCH_ONENGRAVE_ANG() As Color3d
|
||||||
|
Return New Color3d(255, 255, 100)
|
||||||
|
End Function
|
||||||
Public Function COL_MCH_DRIPFREE() As Color3d
|
Public Function COL_MCH_DRIPFREE() As Color3d
|
||||||
Return New Color3d(192, 0, 128)
|
Return New Color3d(192, 0, 128)
|
||||||
End Function
|
End Function
|
||||||
|
|||||||
@@ -18,6 +18,7 @@ Module ConstIni
|
|||||||
Public Const S_GENERAL As String = "General"
|
Public Const S_GENERAL As String = "General"
|
||||||
Public Const K_DEBUG As String = "Debug"
|
Public Const K_DEBUG As String = "Debug"
|
||||||
Public Const K_LICENCE As String = "Licence"
|
Public Const K_LICENCE As String = "Licence"
|
||||||
|
Public Const K_NETKEY As String = "NetKey"
|
||||||
Public Const K_MESSAGESDIR As String = "MessagesDir"
|
Public Const K_MESSAGESDIR As String = "MessagesDir"
|
||||||
Public Const K_MESSAGES As String = "Messages"
|
Public Const K_MESSAGES As String = "Messages"
|
||||||
Public Const K_SUPPORT As String = "Support"
|
Public Const K_SUPPORT As String = "Support"
|
||||||
@@ -49,6 +50,8 @@ Module ConstIni
|
|||||||
Public Const K_SMARTMACHININGPAGE As String = "SmartMachiningPage"
|
Public Const K_SMARTMACHININGPAGE As String = "SmartMachiningPage"
|
||||||
Public Const K_STARTPROGRAM As String = "StartProgram"
|
Public Const K_STARTPROGRAM As String = "StartProgram"
|
||||||
Public Const K_GENERATECN As String = "GenerateCN"
|
Public Const K_GENERATECN As String = "GenerateCN"
|
||||||
|
Public Const K_FRACTIONPATTERN As String = "FractionPattern"
|
||||||
|
Public Const K_PRECISION As String = "Precision"
|
||||||
|
|
||||||
|
|
||||||
Public Const S_LANGUAGES As String = "Languages"
|
Public Const S_LANGUAGES As String = "Languages"
|
||||||
@@ -133,7 +136,9 @@ Module ConstIni
|
|||||||
Public Const K_ENGRAVENUMBER2 As String = "EngraveNumber2"
|
Public Const K_ENGRAVENUMBER2 As String = "EngraveNumber2"
|
||||||
Public Const K_ENGRAVEOFFSET2 As String = "EngraveOffset2"
|
Public Const K_ENGRAVEOFFSET2 As String = "EngraveOffset2"
|
||||||
Public Const K_ENGRAVEDEPTH As String = "EngraveDepth"
|
Public Const K_ENGRAVEDEPTH As String = "EngraveDepth"
|
||||||
|
Public Const K_ENGRAVEDEPTH2 As String = "EngraveDepth2"
|
||||||
Public Const K_ENGRAVESHORT As String = "EngraveShort"
|
Public Const K_ENGRAVESHORT As String = "EngraveShort"
|
||||||
|
Public Const K_ENGRAVEANGLE As String = "EngraveAngle"
|
||||||
Public Const K_DRIPOFFSET As String = "DripOffset"
|
Public Const K_DRIPOFFSET As String = "DripOffset"
|
||||||
Public Const K_DRIPOFFSET2 As String = "DripOffset2"
|
Public Const K_DRIPOFFSET2 As String = "DripOffset2"
|
||||||
Public Const K_DRIPDEPTH As String = "DripDepth"
|
Public Const K_DRIPDEPTH As String = "DripDepth"
|
||||||
@@ -141,6 +146,7 @@ Module ConstIni
|
|||||||
Public Const K_UNDERDRILLDEPTH As String = "UnderDrillDepth"
|
Public Const K_UNDERDRILLDEPTH As String = "UnderDrillDepth"
|
||||||
Public Const K_FILOTOPOFFSET As String = "FiloTopOffset"
|
Public Const K_FILOTOPOFFSET As String = "FiloTopOffset"
|
||||||
Public Const K_FILOTOPDEPTH As String = "FiloTopDepth"
|
Public Const K_FILOTOPDEPTH As String = "FiloTopDepth"
|
||||||
|
Public Const K_ROUNDOFF As String = "RoundOff"
|
||||||
|
|
||||||
Public Const S_NEST As String = "Nest"
|
Public Const S_NEST As String = "Nest"
|
||||||
Public Const K_DIRECT As String = "Direct"
|
Public Const K_DIRECT As String = "Direct"
|
||||||
@@ -153,6 +159,7 @@ Module ConstIni
|
|||||||
Public Const K_AUTOMATICOPTIMIZE As String = "AutomaticOptimize"
|
Public Const K_AUTOMATICOPTIMIZE As String = "AutomaticOptimize"
|
||||||
Public Const K_AUTOMATICMAXTIME As String = "AutomaticMaxTime"
|
Public Const K_AUTOMATICMAXTIME As String = "AutomaticMaxTime"
|
||||||
Public Const K_DRAG_RETTANGLE As String = "DragRectangle"
|
Public Const K_DRAG_RETTANGLE As String = "DragRectangle"
|
||||||
|
Public Const K_STARTENDMODIFYONINTCORNER As String = "StartEndModifyOnIntCorner"
|
||||||
|
|
||||||
Public Const S_SPLIT As String = "Split"
|
Public Const S_SPLIT As String = "Split"
|
||||||
Public Const K_MOVE_LEV As String = "MoveLevel"
|
Public Const K_MOVE_LEV As String = "MoveLevel"
|
||||||
@@ -168,6 +175,14 @@ Module ConstIni
|
|||||||
Public Const K_CSVCURRDIR As String = "CurrDir"
|
Public Const K_CSVCURRDIR As String = "CurrDir"
|
||||||
Public Const K_CSVLASTFILE As String = "LastFile"
|
Public Const K_CSVLASTFILE As String = "LastFile"
|
||||||
|
|
||||||
|
Public Const S_TRF As String = "TRF"
|
||||||
|
Public Const K_ORDCODE As String = "OrdCode"
|
||||||
|
Public Const K_ORDDESC As String = "OrdDesc"
|
||||||
|
Public Const K_PARTCODE As String = "PartCode"
|
||||||
|
Public Const K_MATCODE As String = "MatCode"
|
||||||
|
Public Const K_SURFCODE As String = "SurfCode"
|
||||||
|
Public Const K_TRFTHICKNESS As String = "TrfThickness"
|
||||||
|
|
||||||
Public Const S_SLABDXF As String = "SlabDxf"
|
Public Const S_SLABDXF As String = "SlabDxf"
|
||||||
Public Const K_IMPORTSLABDXF As String = "ImportSlabDxf"
|
Public Const K_IMPORTSLABDXF As String = "ImportSlabDxf"
|
||||||
Public Const K_SLABLAYER As String = "SlabLayer"
|
Public Const K_SLABLAYER As String = "SlabLayer"
|
||||||
@@ -214,6 +229,15 @@ Module ConstIni
|
|||||||
Public Const K_RAWROTATION As String = "Rotation"
|
Public Const K_RAWROTATION As String = "Rotation"
|
||||||
Public Const K_PERPENDICULAR As String = "Perpendicular"
|
Public Const K_PERPENDICULAR As String = "Perpendicular"
|
||||||
|
|
||||||
|
Public Const S_SCRAPS As String = "Scraps"
|
||||||
|
Public Const K_ENABLESCRAPS As String = "EnableScraps"
|
||||||
|
Public Const K_PHOTODIR As String = "PhotoDir"
|
||||||
|
Public Const K_LASTBLOCK As String = "LastBlock"
|
||||||
|
Public Const K_TEMPLATE As String = "Template"
|
||||||
|
Public Const K_DAT As String = "Dat"
|
||||||
|
Public Const K_ZEBRAUTILITIES As String = "ZebraUtilities"
|
||||||
|
Public Const K_ENABLE_PRINTER As String = "EnablePrinter"
|
||||||
|
|
||||||
Public Const S_REG As String = "Reg"
|
Public Const S_REG As String = "Reg"
|
||||||
Public Const K_REGSTEP As String = "Step"
|
Public Const K_REGSTEP As String = "Step"
|
||||||
Public Const K_REGANGSTEP As String = "AngStep"
|
Public Const K_REGANGSTEP As String = "AngStep"
|
||||||
@@ -306,6 +330,9 @@ Module ConstIni
|
|||||||
Public Const K_DC_TEST_LENGTH As String = "TestLength"
|
Public Const K_DC_TEST_LENGTH As String = "TestLength"
|
||||||
Public Const K_DC_TEST_ANGH As String = "TestAngH"
|
Public Const K_DC_TEST_ANGH As String = "TestAngH"
|
||||||
Public Const K_DC_TEST_OFFSET As String = "TestOffset"
|
Public Const K_DC_TEST_OFFSET As String = "TestOffset"
|
||||||
|
Public Const K_DC_OFFSET_SQUARING As String = "OffsetSquaring"
|
||||||
|
Public Const K_DC_EXTRA_LEN_SQUARING As String = "ExtraLenSquaring"
|
||||||
|
Public Const K_ENABLEINVERT As String = "EnableInvert"
|
||||||
|
|
||||||
Public Const S_STATDATA As String = "StatData"
|
Public Const S_STATDATA As String = "StatData"
|
||||||
Public Const K_SD_DAY As String = "Day"
|
Public Const K_SD_DAY As String = "Day"
|
||||||
|
|||||||
@@ -46,6 +46,16 @@
|
|||||||
Public Const K_THREADSLEEP As String = "ThreadSleep"
|
Public Const K_THREADSLEEP As String = "ThreadSleep"
|
||||||
Public Const K_PHOTODELEY As String = "PhotoDeley"
|
Public Const K_PHOTODELEY As String = "PhotoDeley"
|
||||||
|
|
||||||
|
Public Const S_NCFANUC As String = "NcFanuc"
|
||||||
|
Public Const K_SETNCMODE As String = "SetNcMode"
|
||||||
|
Public Const K_BASEADDRINT As String = "BaseAddrInt"
|
||||||
|
Public Const K_BASEADDRBIT As String = "BaseAddrBit"
|
||||||
|
Public Const K_NUMVARINT As String = "NumVarInt"
|
||||||
|
Public Const K_NUMVARBIT As String = "NumVarBit"
|
||||||
|
|
||||||
|
Public Const S_EXECLUA As String = "ExecLua"
|
||||||
|
Public Const K_FILESCRIPT_LUA As String = "FileScript"
|
||||||
|
|
||||||
Public Const S_NCDATA As String = "NcData"
|
Public Const S_NCDATA As String = "NcData"
|
||||||
Public Const K_NEWVARIABLE As String = "NewVariable"
|
Public Const K_NEWVARIABLE As String = "NewVariable"
|
||||||
Public Const K_NEWCONSOLE As String = "NewConsole"
|
Public Const K_NEWCONSOLE As String = "NewConsole"
|
||||||
@@ -75,6 +85,7 @@
|
|||||||
Public Const K_TABLEDOWN As String = "TableDown"
|
Public Const K_TABLEDOWN As String = "TableDown"
|
||||||
Public Const K_MANUAL As String = "Manual"
|
Public Const K_MANUAL As String = "Manual"
|
||||||
Public Const K_DOORCLOSED As String = "DoorClosed"
|
Public Const K_DOORCLOSED As String = "DoorClosed"
|
||||||
|
Public Const K_DOOROPENDED As String = "DoorOpened"
|
||||||
Public Const K_LIMITZ As String = "LimitZ"
|
Public Const K_LIMITZ As String = "LimitZ"
|
||||||
Public Const K_POWEROVR As String = "PowerOvr"
|
Public Const K_POWEROVR As String = "PowerOvr"
|
||||||
Public Const K_PARKING As String = "Parking"
|
Public Const K_PARKING As String = "Parking"
|
||||||
@@ -109,6 +120,7 @@
|
|||||||
Public Const K_FEEDHOLD As String = "FeedHold"
|
Public Const K_FEEDHOLD As String = "FeedHold"
|
||||||
Public Const K_SPOTLIGHT1 As String = "SpotLight1"
|
Public Const K_SPOTLIGHT1 As String = "SpotLight1"
|
||||||
Public Const K_SPOTLIGHT2 As String = "SpotLight2"
|
Public Const K_SPOTLIGHT2 As String = "SpotLight2"
|
||||||
|
Public Const K_NAXES As String = "nAxes"
|
||||||
' Nuove variabili
|
' Nuove variabili
|
||||||
Public Const K_SPEEDHOLD As String = "SpeedHold"
|
Public Const K_SPEEDHOLD As String = "SpeedHold"
|
||||||
Public Const K_XYJOG As String = "XYJog"
|
Public Const K_XYJOG As String = "XYJog"
|
||||||
@@ -216,6 +228,10 @@
|
|||||||
Public Const K_MACH_CUTFSEVLEN As String = "CutFsevLen"
|
Public Const K_MACH_CUTFSEVLEN As String = "CutFsevLen"
|
||||||
Public Const K_MACH_CUTFSEVPERC As String = "CutFsevPerc"
|
Public Const K_MACH_CUTFSEVPERC As String = "CutFsevPerc"
|
||||||
Public Const K_USELASERORIGIN As String = "UseLaserOrigin"
|
Public Const K_USELASERORIGIN As String = "UseLaserOrigin"
|
||||||
|
Public Const K_HOLES_DIAMITERWJ As String = "HolesDiameterWJ"
|
||||||
|
Public Const K_HOLES_OFFSETWJ As String = "HolesOffsetWJ"
|
||||||
|
Public Const K_MIN_RADIUSWJ As String = "MinRadiusWJ"
|
||||||
|
Public Const K_MACH_DRILLINGWJ_ON_CORNERS As String = "DrillingWJOnCorners"
|
||||||
' DrillMillC90
|
' DrillMillC90
|
||||||
' CutLongDxSx
|
' CutLongDxSx
|
||||||
' AngRotMultiCut
|
' AngRotMultiCut
|
||||||
@@ -233,6 +249,9 @@
|
|||||||
Public Const K_MACH_ROTATEVACUUMFOREXTRASTROKEY As String = "RotateVacuumForExtraStrokeY"
|
Public Const K_MACH_ROTATEVACUUMFOREXTRASTROKEY As String = "RotateVacuumForExtraStrokeY"
|
||||||
Public Const K_MACH_ROTATEVACUUMFOREXTRASTROKEX As String = "RotateVacuumForExtraStrokeX"
|
Public Const K_MACH_ROTATEVACUUMFOREXTRASTROKEX As String = "RotateVacuumForExtraStrokeX"
|
||||||
|
|
||||||
|
Public Const K_ISNEWSCRAPS As String = "IsNewScraps"
|
||||||
|
Public Const K_DATABASEID As String = "DatabaseID"
|
||||||
|
|
||||||
Public Const S_MACH_REG As String = "Reg"
|
Public Const S_MACH_REG As String = "Reg"
|
||||||
Public Const K_MACH_MAX_ROT_ANG As String = "MaxRotAng"
|
Public Const K_MACH_MAX_ROT_ANG As String = "MaxRotAng"
|
||||||
|
|
||||||
@@ -260,6 +279,7 @@
|
|||||||
Public Const S_MACH_PROBING As String = "Probing"
|
Public Const S_MACH_PROBING As String = "Probing"
|
||||||
Public Const K_PROBINGSTATEVAR As String = "ProbingStateVar"
|
Public Const K_PROBINGSTATEVAR As String = "ProbingStateVar"
|
||||||
Public Const K_SAWDIAMETER As String = "SawDiameter"
|
Public Const K_SAWDIAMETER As String = "SawDiameter"
|
||||||
|
Public Const K_TOOLLENGTH As String = "ToolLength"
|
||||||
Public Const K_RAWTHICKNESS As String = "RawThickness"
|
Public Const K_RAWTHICKNESS As String = "RawThickness"
|
||||||
Public Const K_ENABLERAWPROBE As String = "EnableRawProbe"
|
Public Const K_ENABLERAWPROBE As String = "EnableRawProbe"
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,177 @@
|
|||||||
|
<UserControl x:Class="ControlsDirectCutUC"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
DataContext="Self"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:OmagCUT="clr-namespace:OmagCUT"
|
||||||
|
xmlns:EgtWPFLib="clr-namespace:EgtWPFLib;assembly=EgtWPFLib"
|
||||||
|
mc:Ignorable="d"
|
||||||
|
d:DesignHeight="597.3" d:DesignWidth="256">
|
||||||
|
|
||||||
|
<Grid Name="LeftButtonGrid" Grid.Row="1" >
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<!--<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="7*"/>-->
|
||||||
|
<RowDefinition Height="9*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<!-- Definizione della Grid laterale -->
|
||||||
|
<Grid Name="CutTypeGrid" Grid.Row="1" >
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<!--<RowDefinition Height="1*"/>-->
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<Button Name="ManualBtn" Grid.Column="2" Grid.Row="0"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Movimento-manualeImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="ManualTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Button Name="SingleCutBtn" Grid.Row="1"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Taglio-singoloImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="SingleCutTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Button Name="MultipleCutBtn" Grid.Row="2"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Taglio-multiploImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="MultipleCutTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Button Name="GridCutBtn" Grid.Row="3"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Taglio-grigliaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="GridCutTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
|
||||||
|
<Button Name="SingleDrillBtn" Grid.Row="4"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Foro-singoloImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="SingleDrillTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Button Name="FlatteningCutBtn" Grid.Row="5"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource SpianaturaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="FlatteningCutTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<!--<Button Name="PolishingBtn" Grid.Row="6"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource LucidaturaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="PolishingTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>-->
|
||||||
|
|
||||||
|
<!--<Button Name="CopyTemplateBtn" Grid.Row="7"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Copia-dimaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="CopyTemplateTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>-->
|
||||||
|
|
||||||
|
<Button Name="SquaringBtn" Grid.Row="6"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Copia-dimaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="SquaringTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<!--<Button Name="SawTestBtn" Grid.Row="6"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Test-lamaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="SawTestTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>-->
|
||||||
|
|
||||||
|
<Grid Name="ChangeUCGrid" Grid.Row="7">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Button Name="ChangeUCBtn" Grid.ColumnSpan="2" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<!--<Image Name="ImageCompo9" Source="{DynamicResource NumericKeyboardArrowImg}" />-->
|
||||||
|
<TextBlock Name="ChangeUCTxBl" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
|
</UserControl>
|
||||||
@@ -0,0 +1,265 @@
|
|||||||
|
Imports EgtUILib
|
||||||
|
Public Class ControlsDirectCutUC
|
||||||
|
|
||||||
|
' Dichiarazione delle Page UserControl
|
||||||
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
|
' ---- MAI USATA ---- nuova finestra per i comandi per il taglio manuale nuovo
|
||||||
|
Friend m_SingleCutAuto As SingleCutAuto
|
||||||
|
' ---- MAI USATA ----
|
||||||
|
Friend m_MachineButtons As MachineButtonsUC
|
||||||
|
Friend m_ManualAxesMove As ManualAxesMoveUC
|
||||||
|
Friend m_SingleCut As SingleCutUC
|
||||||
|
Friend m_SingleDrill As SingleDrillUC
|
||||||
|
Friend m_MultipleCut As MultipleCut
|
||||||
|
Friend m_GridCut As GridCut
|
||||||
|
Friend m_FlatteningCut As FlatteningCut
|
||||||
|
Friend m_Squaring As SquaringUC
|
||||||
|
Friend m_ControlsMachineButton As ControlsMachineButtonUC
|
||||||
|
Friend m_VacuumMachineButton As VacuumMachineButtonUC
|
||||||
|
|
||||||
|
Friend m_ControlDirectCutPage1 As ControlsDirectCutUC1
|
||||||
|
|
||||||
|
' Stato di visualizzazione della macchina
|
||||||
|
Friend m_bShowMachine As Boolean = False
|
||||||
|
Friend m_nMachLook As Integer = MCH_LOOK.ALL
|
||||||
|
' Dati generali CN
|
||||||
|
Friend m_CN As CN_generico
|
||||||
|
Private m_bFirst As Boolean = True
|
||||||
|
' Riferimento alla pagina correntemente attiva
|
||||||
|
Friend m_ActiveDirectCutPage As DirectCutPages = DirectCutPages.DirectCut
|
||||||
|
' Variabili che indicano attivazione paginette con bottoni macchina
|
||||||
|
Private m_ControlsBtn_IsActive As Boolean
|
||||||
|
|
||||||
|
Public Shared m_dZSafe As Double = 52
|
||||||
|
|
||||||
|
' Variabile che indica se sono attivi i bottoni macchina nuovi o vecchi
|
||||||
|
Friend m_NewMachineButtonsType As Boolean
|
||||||
|
' Indica che la finestra del talio Singolo deve essere di tipo manuale
|
||||||
|
Friend m_bManulaCut As Boolean = False
|
||||||
|
|
||||||
|
' elenco dei nuovi bottoni
|
||||||
|
Private m_ButtonJogList As New List(Of MachineButton)
|
||||||
|
|
||||||
|
Enum DirectCutPages
|
||||||
|
' pagina principale di tagli diretti
|
||||||
|
DirectCut
|
||||||
|
' nuova pagina di tagli diretti
|
||||||
|
DirectCut1
|
||||||
|
' elenco dei comandi associati
|
||||||
|
ManualAxesMove
|
||||||
|
SingleCut
|
||||||
|
MultipleCut
|
||||||
|
GridCut
|
||||||
|
FlatteningCut
|
||||||
|
Polishing
|
||||||
|
CopyTemplate
|
||||||
|
SawTest
|
||||||
|
SingleCutAuto
|
||||||
|
SingleDrill
|
||||||
|
Squaring
|
||||||
|
End Enum
|
||||||
|
|
||||||
|
Private Sub ControlsDirectCutUC_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
|
' leggo la configurazione del programma per i nuovi tagli manuali
|
||||||
|
m_bManulaCut = GetPrivateProfileInt(S_GENERAL, K_MANUAL_CUT, 0, m_MainWindow.GetIniFile()) <> 0
|
||||||
|
|
||||||
|
'Creazione delle Page UserControl
|
||||||
|
m_MachineButtons = New MachineButtonsUC
|
||||||
|
m_ManualAxesMove = New ManualAxesMoveUC
|
||||||
|
m_SingleCut = New SingleCutUC
|
||||||
|
m_SingleDrill = New SingleDrillUC
|
||||||
|
m_MultipleCut = New MultipleCut
|
||||||
|
m_GridCut = New GridCut
|
||||||
|
m_FlatteningCut = New FlatteningCut
|
||||||
|
m_Squaring = New SquaringUC
|
||||||
|
m_ControlsMachineButton = New ControlsMachineButtonUC
|
||||||
|
m_VacuumMachineButton = New VacuumMachineButtonUC
|
||||||
|
' reiferimento alla pagina succesiva
|
||||||
|
m_ControlDirectCutPage1 = New ControlsDirectCutUC1
|
||||||
|
' Costruisco la finestra per il nuovo tipo di taglio manuale
|
||||||
|
m_SingleCutAuto = New SingleCutAuto
|
||||||
|
|
||||||
|
'Posizionemento nella griglia delle Page UserControl DirectCutPageUC
|
||||||
|
m_MachineButtons.SetValue(Grid.RowProperty, 2)
|
||||||
|
m_MachineButtons.SetValue(Grid.ColumnSpanProperty, 7)
|
||||||
|
m_ManualAxesMove.SetValue(Grid.RowProperty, 1)
|
||||||
|
If m_bManulaCut Then
|
||||||
|
m_SingleCutAuto.SetValue(Grid.RowProperty, 1)
|
||||||
|
Else
|
||||||
|
m_SingleCut.SetValue(Grid.RowProperty, 1)
|
||||||
|
End If
|
||||||
|
m_SingleDrill.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_MultipleCut.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_GridCut.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_FlatteningCut.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_Squaring.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_ControlsMachineButton.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_VacuumMachineButton.SetValue(Grid.RowProperty, 1)
|
||||||
|
|
||||||
|
' ManualBtn.Content = EgtMsg(90201)
|
||||||
|
ManualTxt.Text = EgtMsg(90201)
|
||||||
|
'SingleCutBtn.Content = EgtMsg(90202)
|
||||||
|
SingleCutTxt.Text = EgtMsg(90202)
|
||||||
|
'SingleDrillBtn.Content = "Foro singolo"
|
||||||
|
SingleDrillTxt.Text = EgtMsg(90258)
|
||||||
|
'MultipleCutBtn.Content = EgtMsg(90203)
|
||||||
|
MultipleCutTxt.Text = EgtMsg(90203)
|
||||||
|
'GridCutBtn.Content = EgtMsg(90204)
|
||||||
|
GridCutTxt.Text = EgtMsg(90204)
|
||||||
|
'FlatteningCutBtn.Content = EgtMsg(90206)
|
||||||
|
FlatteningCutTxt.Text = EgtMsg(90206)
|
||||||
|
' 90261=Squaring
|
||||||
|
SquaringTxt.Text = EgtMsg(90261)
|
||||||
|
' 90409=Others
|
||||||
|
ChangeUCTxBl.Text = EgtMsg(90409)
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ControlsDirectCutUC_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
|
' Se rientro da simulazione
|
||||||
|
If m_ActiveDirectCutPage = DirectCutPages.SingleCut Then
|
||||||
|
LeftButtonGrid.Children.Add(m_SingleCut)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.SingleCutAuto Then
|
||||||
|
LeftButtonGrid.Children.Add(m_SingleCutAuto)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.MultipleCut Then
|
||||||
|
LeftButtonGrid.Children.Add(m_MultipleCut)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.GridCut Then
|
||||||
|
LeftButtonGrid.Children.Add(m_GridCut)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.FlatteningCut Then
|
||||||
|
LeftButtonGrid.Children.Add(m_FlatteningCut)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.SingleDrill Then
|
||||||
|
LeftButtonGrid.Children.Add(m_SingleDrill)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.Squaring Then
|
||||||
|
LeftButtonGrid.Children.Add(m_Squaring)
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
|
If m_MainWindow.m_DirectCutPageUC.m_ActiveControl <> DirectCutPageUC.Controls.MachineButtonUC Or
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ActiveControl <> DirectCutPageUC.Controls.VacuumButtonUC Then
|
||||||
|
' Caso standard
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.DirectCut
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Attivo le lavorazioni solo se esiste il grezzo e se presente testa H1
|
||||||
|
Dim bRawOk As Boolean = (GetRawHeight() > EPS_SMALL)
|
||||||
|
Dim bH1Exists As Boolean = (EgtGetHeadId("H1") <> GDB_ID.NULL)
|
||||||
|
|
||||||
|
ManualBtn.IsEnabled = bH1Exists
|
||||||
|
' sviluppo rimasto in sospeso
|
||||||
|
If m_bManulaCut Then
|
||||||
|
' anche se non è presente un grezzo mantengo abilitato il bottone
|
||||||
|
SingleCutBtn.IsEnabled = True
|
||||||
|
Else
|
||||||
|
SingleCutBtn.IsEnabled = bRawOk
|
||||||
|
End If
|
||||||
|
MultipleCutBtn.IsEnabled = bRawOk
|
||||||
|
GridCutBtn.IsEnabled = bRawOk
|
||||||
|
SingleDrillBtn.IsEnabled = (bRawOk And bH1Exists)
|
||||||
|
FlatteningCutBtn.IsEnabled = (bRawOk And bH1Exists)
|
||||||
|
SquaringBtn.IsEnabled = bRawOk
|
||||||
|
|
||||||
|
' aggiorno la visualizzazione dei parametri
|
||||||
|
ReloadParam()
|
||||||
|
|
||||||
|
' Nascondo i pezzi in parcheggio
|
||||||
|
HideParkedParts()
|
||||||
|
EgtZoom(ZM.ALL)
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' ricarico i parametri utensili per definizione
|
||||||
|
Public Sub ReloadParam()
|
||||||
|
Dim sCurrSawing As String = m_MainWindow.m_CurrentMachine.sCurrSawing
|
||||||
|
Dim sCurrSaw As String = m_MainWindow.m_CurrentMachine.sCurrSaw
|
||||||
|
Dim bSaw As Boolean = False
|
||||||
|
|
||||||
|
' se esiste una lavorazione di lama corrente vuol dire che deve essere preferita
|
||||||
|
If Not String.IsNullOrEmpty(sCurrSaw) And Not String.IsNullOrEmpty(sCurrSawing) Then
|
||||||
|
bSaw = EgtSetCalcTool(sCurrSaw, "H1", 1)
|
||||||
|
End If
|
||||||
|
m_SingleCut.SetEnableParam(bSaw)
|
||||||
|
m_MultipleCut.SetEnableParam(bSaw)
|
||||||
|
m_GridCut.SetEnableParam(bSaw)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#Region "COMMAND CLICK BTN"
|
||||||
|
|
||||||
|
Private Sub ManualBtn_Click(sender As Object, e As RoutedEventArgs) Handles ManualBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_ManualAxesMove)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.ManualAxesMove
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SingleCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles SingleCutBtn.Click
|
||||||
|
If m_bManulaCut Then
|
||||||
|
LeftButtonGrid.Children.Add(m_SingleCutAuto)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.SingleCutAuto
|
||||||
|
Else
|
||||||
|
LeftButtonGrid.Children.Add(m_SingleCut)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.SingleCut
|
||||||
|
End If
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub MultipleCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles MultipleCutBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_MultipleCut)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.MultipleCut
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub GridCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles GridCutBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_GridCut)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.GridCut
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub FlatteningCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles FlatteningCutBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_FlatteningCut)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.FlatteningCut
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SquaringBtn_Click(sender As Object, e As RoutedEventArgs) Handles SquaringBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_Squaring)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.Squaring
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SingleDrillBtn_Click(sender As Object, e As RoutedEventArgs) Handles SingleDrillBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_SingleDrill)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.SingleDrill
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' cambio pagina
|
||||||
|
Private Sub ChangeUCBtn_Click(sender As Object, e As RoutedEventArgs) Handles ChangeUCBtn.Click
|
||||||
|
DirectCutPage_Unloaded(Nothing, Nothing)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.DirectCut
|
||||||
|
m_MainWindow.m_DirectCutPageUC.LoadDirectCutUC1()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#End Region ' Command Click Btn
|
||||||
|
|
||||||
|
|
||||||
|
Friend Sub DirectCutPage_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
||||||
|
Select Case m_ActiveDirectCutPage
|
||||||
|
Case DirectCutPages.DirectCut Or DirectCutPages.ManualAxesMove
|
||||||
|
' Non è necessario fare alcunché
|
||||||
|
Case DirectCutPages.SingleCut
|
||||||
|
LeftButtonGrid.Children.Remove(m_SingleCut)
|
||||||
|
Case DirectCutPages.SingleCutAuto
|
||||||
|
LeftButtonGrid.Children.Remove(m_SingleCutAuto)
|
||||||
|
Case DirectCutPages.MultipleCut
|
||||||
|
LeftButtonGrid.Children.Remove(m_MultipleCut)
|
||||||
|
Case DirectCutPages.GridCut
|
||||||
|
LeftButtonGrid.Children.Remove(m_GridCut)
|
||||||
|
Case DirectCutPages.FlatteningCut
|
||||||
|
LeftButtonGrid.Children.Remove(m_FlatteningCut)
|
||||||
|
Case DirectCutPages.SingleDrill
|
||||||
|
LeftButtonGrid.Children.Remove(m_SingleDrill)
|
||||||
|
Case DirectCutPages.Squaring
|
||||||
|
LeftButtonGrid.Children.Remove(m_Squaring)
|
||||||
|
End Select
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
End Class
|
||||||
@@ -0,0 +1,86 @@
|
|||||||
|
<UserControl x:Class="ControlsDirectCutUC1"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
DataContext="Self"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:OmagCUT="clr-namespace:OmagCUT"
|
||||||
|
xmlns:EgtWPFLib="clr-namespace:EgtWPFLib;assembly=EgtWPFLib"
|
||||||
|
mc:Ignorable="d"
|
||||||
|
d:DesignHeight="597.3" d:DesignWidth="256">
|
||||||
|
|
||||||
|
<Grid Name="LeftButtonGrid" Grid.Row="1" >
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<!--<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="7*"/>-->
|
||||||
|
<RowDefinition Height="9*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<!-- Definizione della Grid laterale -->
|
||||||
|
<Grid Name="CutTypeGrid" Grid.Row="1" >
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<!--<RowDefinition Height="1*"/>-->
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<Button Name="SawTestBtn" Grid.Row="0"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Test-lamaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="SawTestTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Button Name="PolishingBtn" Grid.Row="1"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource LucidaturaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="PolishingTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Button Name="CopyTemplateBtn" Grid.Row="2"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Copia-dimaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="CopyTemplateTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<Grid Name="ChangeUC1Grid" Grid.Row="7">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Button Name="ChangeUC1Btn" Grid.ColumnSpan="2" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Image Name="ImageCompo9" Source="{DynamicResource NumericKeyboardArrowImg}" />
|
||||||
|
<!--<TextBlock Name="LabelCompo9" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>-->
|
||||||
|
</Grid>
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
</Grid>
|
||||||
|
</UserControl>
|
||||||
@@ -0,0 +1,142 @@
|
|||||||
|
Imports EgtUILib
|
||||||
|
Public Class ControlsDirectCutUC1
|
||||||
|
|
||||||
|
' Dichiarazione delle Page UserControl
|
||||||
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
|
Friend m_Polishing As Polishing
|
||||||
|
Friend m_CopyTemplate As CopyTemplateUC
|
||||||
|
Friend m_SawTest As SawTestUC
|
||||||
|
|
||||||
|
' Stato di visualizzazione della macchina
|
||||||
|
Friend m_bShowMachine As Boolean = False
|
||||||
|
Friend m_nMachLook As Integer = MCH_LOOK.ALL
|
||||||
|
' Dati generali CN
|
||||||
|
Friend m_CN As CN_generico
|
||||||
|
Private m_bFirst As Boolean = True
|
||||||
|
' Riferimento alla pagina correntemente attiva
|
||||||
|
Friend m_ActiveDirectCutPage As DirectCutPages = DirectCutPages.DirectCut
|
||||||
|
' Variabili che indicano attivazione paginette con bottoni macchina
|
||||||
|
Private m_ControlsBtn_IsActive As Boolean
|
||||||
|
|
||||||
|
Public Shared m_dZSafe As Double = 52
|
||||||
|
|
||||||
|
' Variabile che indica se sono attivi i bottoni macchina nuovi o vecchi
|
||||||
|
Friend m_NewMachineButtonsType As Boolean
|
||||||
|
' Indica che la finestra del talio Singolo deve essere di tipo manuale
|
||||||
|
Friend m_bManulaCut As Boolean = False
|
||||||
|
|
||||||
|
Enum DirectCutPages
|
||||||
|
DirectCut
|
||||||
|
DirectCut1
|
||||||
|
Polishing
|
||||||
|
CopyTemplate
|
||||||
|
SawTest
|
||||||
|
End Enum
|
||||||
|
|
||||||
|
Private Sub ControlsDirectCutUC_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
|
' leggo la configurazione del programma per i nuovi tagli manuali
|
||||||
|
m_bManulaCut = GetPrivateProfileInt(S_GENERAL, K_MANUAL_CUT, 0, m_MainWindow.GetIniFile()) <> 0
|
||||||
|
|
||||||
|
'Creazione delle Page UserControl
|
||||||
|
m_SawTest = New SawTestUC
|
||||||
|
m_Polishing = New Polishing
|
||||||
|
m_CopyTemplate = New CopyTemplateUC
|
||||||
|
|
||||||
|
'Posizionemento nella griglia delle Page UserControl
|
||||||
|
m_SawTest.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_Polishing.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_CopyTemplate.SetValue(Grid.RowProperty, 1)
|
||||||
|
|
||||||
|
' assegno i nomi ai pulsanti
|
||||||
|
SawTestTxt.Text = EgtMsg(90207)
|
||||||
|
PolishingTxt.Text = EgtMsg(90231)
|
||||||
|
'CopyTemplateBtn.Content = EgtMsg(90209)
|
||||||
|
CopyTemplateTxt.Text = EgtMsg(90209)
|
||||||
|
'SquaringTxt.Text = "Squaring"
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ControlsDirectCutUC1_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
|
' Se rientro da simulazione
|
||||||
|
If m_ActiveDirectCutPage = DirectCutPages.SawTest Then
|
||||||
|
LeftButtonGrid.Children.Add(m_SawTest)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.CopyTemplate Then
|
||||||
|
Me.LeftButtonGrid.Children.Add(m_CopyTemplate)
|
||||||
|
Return
|
||||||
|
ElseIf m_ActiveDirectCutPage = DirectCutPages.Polishing Then
|
||||||
|
Me.LeftButtonGrid.Children.Add(m_Polishing)
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Caso standard
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.DirectCut1
|
||||||
|
|
||||||
|
' Attivo le lavorazioni solo se esiste il grezzo e se presente testa H1
|
||||||
|
Dim bRawOk As Boolean = (GetRawHeight() > EPS_SMALL)
|
||||||
|
Dim bH1Exists As Boolean = (EgtGetHeadId("H1") <> GDB_ID.NULL)
|
||||||
|
|
||||||
|
PolishingBtn.IsEnabled = (bRawOk And m_MainWindow.m_CurrentMachine.bPolishing)
|
||||||
|
SawTestBtn.IsEnabled = (bRawOk And bH1Exists)
|
||||||
|
CopyTemplateBtn.IsEnabled = bH1Exists
|
||||||
|
|
||||||
|
' aggiorno la visualizzazione dei parametri
|
||||||
|
ReloadParam()
|
||||||
|
|
||||||
|
' Nascondo i pezzi in parcheggio
|
||||||
|
HideParkedParts()
|
||||||
|
EgtZoom(ZM.ALL)
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' ricarica i dati utensili
|
||||||
|
Public Sub ReloadParam()
|
||||||
|
Dim sCurrSawing As String = m_MainWindow.m_CurrentMachine.sCurrSawing
|
||||||
|
Dim sCurrSaw As String = m_MainWindow.m_CurrentMachine.sCurrSaw
|
||||||
|
Dim bSaw As Boolean = False
|
||||||
|
|
||||||
|
' se esiste una lavorazione di lama corrente vuol dire che deve essere preferita
|
||||||
|
If Not String.IsNullOrEmpty(sCurrSaw) And Not String.IsNullOrEmpty(sCurrSawing) Then
|
||||||
|
bSaw = EgtSetCalcTool(sCurrSaw, "H1", 1)
|
||||||
|
End If
|
||||||
|
'm_SingleCut.SetEnableParam(bSaw)
|
||||||
|
'm_MultipleCut.SetEnableParam(bSaw)
|
||||||
|
'm_GridCut.SetEnableParam(bSaw)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#Region "COMMAND CLICK BTN"
|
||||||
|
Private Sub SawTestBtn_Click(sender As Object, e As RoutedEventArgs) Handles SawTestBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_SawTest)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.SawTest
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub PolishingBtn_Click(sender As Object, e As RoutedEventArgs) Handles PolishingBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_Polishing)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.Polishing
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub CopyTemplateBtn_Click(sender As Object, e As RoutedEventArgs) Handles CopyTemplateBtn.Click
|
||||||
|
LeftButtonGrid.Children.Add(m_CopyTemplate)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.CopyTemplate
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ChangeUC1Btn_Click(sender As Object, e As RoutedEventArgs) Handles ChangeUC1Btn.Click
|
||||||
|
DirectCutPage_Unloaded(Nothing, Nothing)
|
||||||
|
m_ActiveDirectCutPage = DirectCutPages.DirectCut1
|
||||||
|
m_MainWindow.m_DirectCutPageUC.LoadDirectCutUC()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#End Region ' Command Click Btn
|
||||||
|
|
||||||
|
Friend Sub DirectCutPage_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
||||||
|
Select Case m_ActiveDirectCutPage
|
||||||
|
Case DirectCutPages.SawTest
|
||||||
|
LeftButtonGrid.Children.Remove(m_SawTest)
|
||||||
|
Case DirectCutPages.Polishing
|
||||||
|
LeftButtonGrid.Children.Remove(m_Polishing)
|
||||||
|
Case DirectCutPages.CopyTemplate
|
||||||
|
LeftButtonGrid.Children.Remove(m_CopyTemplate)
|
||||||
|
End Select
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
End Class
|
||||||
@@ -76,6 +76,11 @@ Public Class ControlsMachineButtonUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
#Region "STATE CHANGED"
|
||||||
|
' ------------------------------------------------------------------------------
|
||||||
|
' i segeunti metodi notificano il cambiamento di stato di specifici bottoni
|
||||||
|
'-------------------------------------------------------------------------------
|
||||||
|
|
||||||
Friend Sub SpindleStateChanged(SpindleState As Boolean)
|
Friend Sub SpindleStateChanged(SpindleState As Boolean)
|
||||||
Dim SpindleButton As TwoStateButton = Nothing
|
Dim SpindleButton As TwoStateButton = Nothing
|
||||||
For Each MachineButton As MachineButton In m_ButtonList
|
For Each MachineButton As MachineButton In m_ButtonList
|
||||||
@@ -255,38 +260,34 @@ Public Class ControlsMachineButtonUC
|
|||||||
Dim DoorOpenedButton As ThreeStateButton = Nothing
|
Dim DoorOpenedButton As ThreeStateButton = Nothing
|
||||||
For Each MachineButton As MachineButton In m_ButtonList
|
For Each MachineButton As MachineButton In m_ButtonList
|
||||||
If MachineButton.StateFlag = K_DOORCLOSED Then
|
If MachineButton.StateFlag = K_DOORCLOSED Then
|
||||||
'If TypeOf MachineButton Is NoStateButton Then
|
|
||||||
' DoorClosedButton = DirectCast(MachineButton, NoStateButton)
|
|
||||||
'ElseIf TypeOf MachineButton Is TwoStateButton Then
|
|
||||||
' DoorClosedButton = DirectCast(MachineButton, TwoStateButton)
|
|
||||||
'ElseIf TypeOf MachineButton Is ThreeStateButton Then
|
|
||||||
' DoorClosedButton = DirectCast(MachineButton, ThreeStateButton)
|
|
||||||
'ElseIf TypeOf MachineButton Is DoubleCommandButton Then
|
|
||||||
' DoorClosedButton = DirectCast(MachineButton, DoubleCommandButton)
|
|
||||||
'ElseIf TypeOf MachineButton Is PressedCommandButton Then
|
|
||||||
' DoorClosedButton = DirectCast(MachineButton, PressedCommandButton)
|
|
||||||
'End If
|
|
||||||
DoorClosedButton = MachineButton
|
DoorClosedButton = MachineButton
|
||||||
End If
|
End If
|
||||||
If MachineButton.StateFlag = "DoorOpened" Then
|
If MachineButton.StateFlag = K_DOOROPENDED Then
|
||||||
DoorOpenedButton = MachineButton
|
DoorOpenedButton = MachineButton
|
||||||
End If
|
End If
|
||||||
Next
|
Next
|
||||||
|
' Chiusura porte (gesrtione comando Three/Two state
|
||||||
If Not IsNothing(DoorClosedButton) Then
|
If Not IsNothing(DoorClosedButton) Then
|
||||||
Select Case DoorClosedState
|
Select Case DoorClosedState
|
||||||
Case 0
|
Case 0
|
||||||
|
' porta aperta
|
||||||
DoorClosedButton.Background = Application.Current.FindResource("OmagCut_Red")
|
DoorClosedButton.Background = Application.Current.FindResource("OmagCut_Red")
|
||||||
Case 1, 2
|
Case 1, 2
|
||||||
|
' porta in movimento/aperta
|
||||||
DoorClosedButton.Background = Application.Current.FindResource("OmagCut_LightGray")
|
DoorClosedButton.Background = Application.Current.FindResource("OmagCut_LightGray")
|
||||||
End Select
|
End Select
|
||||||
End If
|
End If
|
||||||
|
' Chiusura porte (gesrtione comando Three/Two state
|
||||||
If Not IsNothing(DoorOpenedButton) Then
|
If Not IsNothing(DoorOpenedButton) Then
|
||||||
Select Case DoorClosedState
|
Select Case DoorClosedState
|
||||||
Case 0
|
Case 0
|
||||||
|
' porta aperta
|
||||||
DoorOpenedButton.Background = Application.Current.FindResource("OmagCut_LightGray")
|
DoorOpenedButton.Background = Application.Current.FindResource("OmagCut_LightGray")
|
||||||
Case 1
|
Case 1
|
||||||
|
' porta in movimento
|
||||||
DoorOpenedButton.Background = Application.Current.FindResource("OmagCut_Yellow")
|
DoorOpenedButton.Background = Application.Current.FindResource("OmagCut_Yellow")
|
||||||
Case 2
|
Case 2
|
||||||
|
' porta chiusa
|
||||||
DoorOpenedButton.Background = Application.Current.FindResource("OmagCut_Green")
|
DoorOpenedButton.Background = Application.Current.FindResource("OmagCut_Green")
|
||||||
End Select
|
End Select
|
||||||
End If
|
End If
|
||||||
@@ -372,6 +373,7 @@ Public Class ControlsMachineButtonUC
|
|||||||
'End If
|
'End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
#End Region ' State Range
|
||||||
|
|
||||||
Public Function GetPrivateProfileMachineButtons(
|
Public Function GetPrivateProfileMachineButtons(
|
||||||
ByVal lpAppName As String,
|
ByVal lpAppName As String,
|
||||||
@@ -569,13 +571,64 @@ Public MustInherit Class MachineButton
|
|||||||
EgtOutLog("dopo scrittura seconda variabile")
|
EgtOutLog("dopo scrittura seconda variabile")
|
||||||
End If
|
End If
|
||||||
Return
|
Return
|
||||||
|
Case 4
|
||||||
|
' ------------------------------------ FANUC ------------------------------------
|
||||||
|
' eventuale scrittura di linea di comando MDI
|
||||||
|
If Not String.IsNullOrEmpty(CmdString) Then
|
||||||
|
' attivo mpdalità MDI
|
||||||
|
m_CN.DGeneralFunctions_WriteCncMode(2)
|
||||||
|
System.Threading.Thread.Sleep(100)
|
||||||
|
' salvo la stringa di comando ricevuta dal file lua
|
||||||
|
m_CN.sz_ManualDataInput = CmdString
|
||||||
|
' esguo la funzione che ha il compito di scrivere il comando MDI
|
||||||
|
m_CN.MDI_command()
|
||||||
|
End If
|
||||||
|
' attivo modalità AUTO
|
||||||
|
m_CN.DGeneralFunctions_WriteCncMode(7)
|
||||||
|
System.Threading.Thread.Sleep(100)
|
||||||
|
If String.IsNullOrEmpty(EValue) Then
|
||||||
|
' EActive: impulsivo "D#####"
|
||||||
|
m_CN.NC_pulse_bit(ENumber)
|
||||||
|
EgtOutLog("Fanuc_DNumber= " & ENumber)
|
||||||
|
Else
|
||||||
|
' EActive + EValue: scrittura comando invariabile Short oppure Bit
|
||||||
|
If ENumber.Contains(".") Then
|
||||||
|
' D#####.#
|
||||||
|
Dim bEValue As Boolean
|
||||||
|
If EValue.Trim = "1" Then bEValue = True
|
||||||
|
m_CN.NC_write_var_bit(ENumber, CBool(EValue))
|
||||||
|
Else
|
||||||
|
' D#####
|
||||||
|
m_CN.NC_write_var_short(ENumber, CShort(EValue))
|
||||||
|
End If
|
||||||
|
EgtOutLog("Fanuc_DNumber= " & ENumber & " DValue= " & EValue)
|
||||||
|
End If
|
||||||
|
' eventale caricamento seconda variabile
|
||||||
|
If String.IsNullOrEmpty(EValue2) Then
|
||||||
|
' EActive: impulsivo "D#####"
|
||||||
|
m_CN.NC_pulse_bit(ENumber2)
|
||||||
|
EgtOutLog("Fanuc_DNumber= " & ENumber2)
|
||||||
|
Else
|
||||||
|
' EActive + EValue: scrittura comando invariabile Short oppure Bit
|
||||||
|
If ENumber2.Contains(".") Then
|
||||||
|
' D#####.#
|
||||||
|
Dim bEValue2 As Boolean
|
||||||
|
If EValue2.Trim = "1" Then bEValue2 = True
|
||||||
|
m_CN.NC_write_var_bit(ENumber2, CBool(EValue2))
|
||||||
|
Else
|
||||||
|
' D#####
|
||||||
|
m_CN.NC_write_var_short(ENumber2, CShort(EValue2))
|
||||||
|
End If
|
||||||
|
EgtOutLog("Fanuc_DNumber2= " & ENumber2 & " DValue2= " & EValue2)
|
||||||
|
End If
|
||||||
|
Return
|
||||||
End Select
|
End Select
|
||||||
End If
|
End If
|
||||||
'--------------------------------------------------------- MDI ---------------------------------------------------------
|
'--------------------------------------------------------- MDI ---------------------------------------------------------
|
||||||
Dim nResult As Short
|
Dim nResult As Short
|
||||||
' assegno la modalità di funzionamento
|
' assegno la modalità di funzionamento
|
||||||
Select Case m_MainWindow.m_CNCommunication.m_nNCType
|
Select Case m_MainWindow.m_CNCommunication.m_nNCType
|
||||||
Case 1, 2
|
Case 1, 2, 4
|
||||||
nResult = m_CN.DGeneralFunctions_WriteCncMode(2) ' Modalità MDI per controlli num
|
nResult = m_CN.DGeneralFunctions_WriteCncMode(2) ' Modalità MDI per controlli num
|
||||||
Case 3
|
Case 3
|
||||||
'Per il siemens non devo fare nulla
|
'Per il siemens non devo fare nulla
|
||||||
@@ -599,7 +652,7 @@ Public MustInherit Class MachineButton
|
|||||||
m_CN.DGeneralFunctions_CycleStart()
|
m_CN.DGeneralFunctions_CycleStart()
|
||||||
End If
|
End If
|
||||||
System.Threading.Thread.Sleep(300)
|
System.Threading.Thread.Sleep(300)
|
||||||
' riprostino la modalità manuale
|
' ripristino la modalità manuale..?? siucuri ??
|
||||||
nResult = m_CN.DGeneralFunctions_WriteCncMode(7) ' Modalità manuale
|
nResult = m_CN.DGeneralFunctions_WriteCncMode(7) ' Modalità manuale
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -620,6 +673,7 @@ Public MustInherit Class MachineButton
|
|||||||
EgtTdbGetCurrToolParam(MCH_TP.FEED, dFeed)
|
EgtTdbGetCurrToolParam(MCH_TP.FEED, dFeed)
|
||||||
End If
|
End If
|
||||||
EgtLuaSetGlobNumVar("CMD.F", dFeed)
|
EgtLuaSetGlobNumVar("CMD.F", dFeed)
|
||||||
|
|
||||||
Dim dSpeed As Double = 0
|
Dim dSpeed As Double = 0
|
||||||
If Not String.IsNullOrWhiteSpace(m_DirectCutPage.m_ManualAxesMove.SpeedTxBx.Text) Then
|
If Not String.IsNullOrWhiteSpace(m_DirectCutPage.m_ManualAxesMove.SpeedTxBx.Text) Then
|
||||||
StringToDouble(m_DirectCutPage.m_ManualAxesMove.SpeedTxBx.Text, dSpeed)
|
StringToDouble(m_DirectCutPage.m_ManualAxesMove.SpeedTxBx.Text, dSpeed)
|
||||||
@@ -628,6 +682,7 @@ Public MustInherit Class MachineButton
|
|||||||
EgtTdbGetCurrToolParam(MCH_TP.SPEED, dSpeed)
|
EgtTdbGetCurrToolParam(MCH_TP.SPEED, dSpeed)
|
||||||
End If
|
End If
|
||||||
EgtLuaSetGlobNumVar("CMD.S", dSpeed)
|
EgtLuaSetGlobNumVar("CMD.S", dSpeed)
|
||||||
|
|
||||||
Dim dL1, dL2, dL3, dR1, dR2 As Double
|
Dim dL1, dL2, dL3, dR1, dR2 As Double
|
||||||
m_MainWindow.m_CNCommunication.GetAxesPositions(dL1, dL2, dL3, dR1, dR2)
|
m_MainWindow.m_CNCommunication.GetAxesPositions(dL1, dL2, dL3, dR1, dR2)
|
||||||
EgtLuaSetGlobNumVar("CMD.L1", dL1)
|
EgtLuaSetGlobNumVar("CMD.L1", dL1)
|
||||||
@@ -789,6 +844,7 @@ Public Class NoStateButton
|
|||||||
ExecuteMDICommand(TLuaScriptName)
|
ExecuteMDICommand(TLuaScriptName)
|
||||||
End If
|
End If
|
||||||
Else
|
Else
|
||||||
|
' FANUC, SIEMENS
|
||||||
ExecuteMDICommand(TLuaScriptName)
|
ExecuteMDICommand(TLuaScriptName)
|
||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|||||||
@@ -5,6 +5,8 @@ Public Class CopyTemplateUC
|
|||||||
' Riferimenti a pagine
|
' Riferimenti a pagine
|
||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
||||||
|
Private m_refControlDirectCutUC As ControlsDirectCutUC1
|
||||||
|
|
||||||
' Flag di pagina attiva
|
' Flag di pagina attiva
|
||||||
Private m_bActive As Boolean = False
|
Private m_bActive As Boolean = False
|
||||||
' Array stringhe modalità di acquisizione dei punti
|
' Array stringhe modalità di acquisizione dei punti
|
||||||
@@ -59,6 +61,7 @@ Public Class CopyTemplateUC
|
|||||||
|
|
||||||
Private Sub CopyTemplate_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
Private Sub CopyTemplate_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
||||||
|
m_refControlDirectCutUC = m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC1
|
||||||
m_bActive = True
|
m_bActive = True
|
||||||
SaveBtn.IsEnabled = False
|
SaveBtn.IsEnabled = False
|
||||||
LineBtn.IsChecked = True
|
LineBtn.IsChecked = True
|
||||||
@@ -254,8 +257,7 @@ Public Class CopyTemplateUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_refControlDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function EraseCopyTemplatePart() As Boolean
|
Private Function EraseCopyTemplatePart() As Boolean
|
||||||
|
|||||||
@@ -43,14 +43,16 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
<!-- Definizione della Grid laterale -->
|
<!-- Definizione della Grid laterale -->
|
||||||
|
<!--
|
||||||
<Grid Name="LeftButtonGrid" Grid.Row="1" >
|
<Grid Name="LeftButtonGrid" Grid.Row="1" >
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
<RowDefinition Height="7*"/>
|
<RowDefinition Height="7*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
-->
|
||||||
<!-- Definizione della Grid laterale -->
|
<!-- Definizione della Grid laterale -->
|
||||||
<Grid Name="CutTypeGrid" Grid.Row="1" >
|
<!--<Grid Name="CutTypeGrid" Grid.Row="1" >
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
@@ -154,7 +156,8 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
<Button Name="CopyTemplateBtn" Grid.Row="7"
|
-->
|
||||||
|
<!--<Button Name="CopyTemplateBtn" Grid.Row="7"
|
||||||
Style="{DynamicResource OmagCut_YellowIconButton}">
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
<Grid>
|
<Grid>
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
@@ -165,6 +168,19 @@
|
|||||||
<TextBlock Name="CopyTemplateTxt" Grid.Column="1"
|
<TextBlock Name="CopyTemplateTxt" Grid.Column="1"
|
||||||
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
</Button>-->
|
||||||
|
<!--
|
||||||
|
<Button Name="SquaringBtn" Grid.Row="7"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="80"/>
|
||||||
|
<ColumnDefinition Width="140"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Image Source="{DynamicResource Copia-dimaImg}" Style="{DynamicResource OmagCut_ButtonIcon}" Grid.Column="0" />
|
||||||
|
<TextBlock Name="SquaringTxt" Grid.Column="1"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</Grid>
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
<Button Name="SawTestBtn" Grid.Row="8"
|
<Button Name="SawTestBtn" Grid.Row="8"
|
||||||
@@ -180,9 +196,10 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
</Grid>
|
</Grid>-->
|
||||||
|
<!--
|
||||||
|
|
||||||
</Grid>
|
</Grid>-->
|
||||||
|
|
||||||
<!-- Definizione della Grid laterale per bottoni macchina -->
|
<!-- Definizione della Grid laterale per bottoni macchina -->
|
||||||
<Grid Name="MachineButtonGrid" Grid.Row="1">
|
<Grid Name="MachineButtonGrid" Grid.Row="1">
|
||||||
@@ -201,7 +218,11 @@
|
|||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="5*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
<!--<ColumnDefinition Width="1*"/>-->
|
<!--<ColumnDefinition Width="1*"/>-->
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
@@ -240,8 +261,16 @@
|
|||||||
<!--<Image Source="{DynamicResource VacuumImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>-->
|
<!--<Image Source="{DynamicResource VacuumImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>-->
|
||||||
</ToggleButton>
|
</ToggleButton>
|
||||||
|
|
||||||
|
<!--Parking-->
|
||||||
|
<ToggleButton Name="ParkingBtn" Grid.Column="6"
|
||||||
|
Style="{DynamicResource OmagCut_GradientYellowIconToggleButton}">
|
||||||
|
<Image Source="{DynamicResource ParkingImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>
|
||||||
|
</ToggleButton>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!--Comando Manula/MDI-->
|
<!--Comando Manula/MDI-->
|
||||||
<Button Name="ManualModeBtn" Grid.Column="7"
|
<Button Name="ManualModeBtn" Grid.Column="11"
|
||||||
Style="{DynamicResource OmagCut_YellowGradientYellowIconButton}">
|
Style="{DynamicResource OmagCut_YellowGradientYellowIconButton}">
|
||||||
<Image Source="{DynamicResource ManualImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>
|
<Image Source="{DynamicResource ManualImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>
|
||||||
</Button>
|
</Button>
|
||||||
|
|||||||
@@ -7,18 +7,20 @@ Public Class DirectCutPageUC
|
|||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Friend m_MachineButtons As MachineButtonsUC
|
Friend m_MachineButtons As MachineButtonsUC
|
||||||
Friend m_ManualAxesMove As ManualAxesMoveUC
|
Friend m_ManualAxesMove As ManualAxesMoveUC
|
||||||
Friend m_SingleCut As SingleCutUC
|
|
||||||
Friend m_SingleDrill As SingleDrillUC
|
|
||||||
' nuova finestra per i comandi per il taglio manuale nuovo
|
|
||||||
Friend m_SingleCutAuto As SingleCutAuto
|
|
||||||
Friend m_MultipleCut As MultipleCut
|
|
||||||
Friend m_GridCut As GridCut
|
|
||||||
Friend m_FlatteningCut As FlatteningCut
|
|
||||||
Friend m_Polishing As Polishing
|
|
||||||
Friend m_CopyTemplate As CopyTemplateUC
|
|
||||||
Friend m_SawTest As SawTestUC
|
|
||||||
Friend m_ControlsMachineButton As ControlsMachineButtonUC
|
Friend m_ControlsMachineButton As ControlsMachineButtonUC
|
||||||
Friend m_VacuumMachineButton As VacuumMachineButtonUC
|
Friend m_VacuumMachineButton As VacuumMachineButtonUC
|
||||||
|
Friend m_ControlsDirectCutUC As ControlsDirectCutUC
|
||||||
|
Friend m_ControlsDirectCutUC1 As ControlsDirectCutUC1
|
||||||
|
|
||||||
|
Friend m_ActiveControl As Controls
|
||||||
|
Enum Controls
|
||||||
|
DirectCutUC
|
||||||
|
DirectCutUC1
|
||||||
|
MachineButtonUC
|
||||||
|
VacuumButtonUC
|
||||||
|
End Enum
|
||||||
|
|
||||||
|
|
||||||
' Stato di visualizzazione della macchina
|
' Stato di visualizzazione della macchina
|
||||||
Friend m_bShowMachine As Boolean = False
|
Friend m_bShowMachine As Boolean = False
|
||||||
@@ -26,8 +28,6 @@ Public Class DirectCutPageUC
|
|||||||
' Dati generali CN
|
' Dati generali CN
|
||||||
Friend m_CN As CN_generico
|
Friend m_CN As CN_generico
|
||||||
Private m_bFirst As Boolean = True
|
Private m_bFirst As Boolean = True
|
||||||
' Riferimento alla pagina correntemente attiva
|
|
||||||
Friend m_ActiveDirectCutPage As DirectCutPages = DirectCutPages.DirectCut
|
|
||||||
' Variabili che indicano attivazione paginette con bottoni macchina
|
' Variabili che indicano attivazione paginette con bottoni macchina
|
||||||
Private m_ControlsBtn_IsActive As Boolean
|
Private m_ControlsBtn_IsActive As Boolean
|
||||||
|
|
||||||
@@ -41,94 +41,42 @@ Public Class DirectCutPageUC
|
|||||||
' elenco dei nuovi bottoni
|
' elenco dei nuovi bottoni
|
||||||
Private m_ButtonJogList As New List(Of MachineButton)
|
Private m_ButtonJogList As New List(Of MachineButton)
|
||||||
|
|
||||||
Enum DirectCutPages
|
|
||||||
DirectCut
|
|
||||||
ManualAxesMove
|
|
||||||
SingleCut
|
|
||||||
MultipleCut
|
|
||||||
GridCut
|
|
||||||
FlatteningCut
|
|
||||||
Polishing
|
|
||||||
CopyTemplate
|
|
||||||
SawTest
|
|
||||||
SingleCutAuto
|
|
||||||
SingleDrill
|
|
||||||
End Enum
|
|
||||||
|
|
||||||
Private Sub DirectCutPage_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
Private Sub DirectCutPage_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
' leggo la configurazione del programma per i nuovi tagli manuali
|
|
||||||
m_bManulaCut = GetPrivateProfileInt(S_GENERAL, K_MANUAL_CUT, 0, m_MainWindow.GetIniFile()) <> 0
|
|
||||||
|
|
||||||
'Creazione delle Page UserControl
|
'Creazione delle Page UserControl
|
||||||
m_MachineButtons = New MachineButtonsUC
|
m_MachineButtons = New MachineButtonsUC
|
||||||
m_ManualAxesMove = New ManualAxesMoveUC
|
m_ManualAxesMove = New ManualAxesMoveUC
|
||||||
m_SingleCut = New SingleCutUC
|
|
||||||
m_SingleDrill = New SingleDrillUC
|
|
||||||
m_MultipleCut = New MultipleCut
|
|
||||||
m_GridCut = New GridCut
|
|
||||||
m_FlatteningCut = New FlatteningCut
|
|
||||||
m_Polishing = New Polishing
|
|
||||||
m_CopyTemplate = New CopyTemplateUC
|
|
||||||
m_SawTest = New SawTestUC
|
|
||||||
m_ControlsMachineButton = New ControlsMachineButtonUC
|
m_ControlsMachineButton = New ControlsMachineButtonUC
|
||||||
m_VacuumMachineButton = New VacuumMachineButtonUC
|
m_VacuumMachineButton = New VacuumMachineButtonUC
|
||||||
' Costruisco la finestra per il nuovo tipo di taglio manuale
|
m_ControlsDirectCutUC = New ControlsDirectCutUC
|
||||||
m_SingleCutAuto = New SingleCutAuto
|
m_ControlsDirectCutUC1 = New ControlsDirectCutUC1
|
||||||
|
|
||||||
'Posizionemento nella griglia delle Page UserControl
|
'Posizionemento nella griglia delle Page UserControl
|
||||||
m_MachineButtons.SetValue(Grid.RowProperty, 2)
|
m_MachineButtons.SetValue(Grid.RowProperty, 2)
|
||||||
m_MachineButtons.SetValue(Grid.ColumnSpanProperty, 7)
|
m_MachineButtons.SetValue(Grid.ColumnSpanProperty, m_MachineButtons.nCountButton)
|
||||||
m_ManualAxesMove.SetValue(Grid.RowProperty, 1)
|
m_ManualAxesMove.SetValue(Grid.RowProperty, 1)
|
||||||
If m_bManulaCut Then
|
|
||||||
m_SingleCutAuto.SetValue(Grid.RowProperty, 1)
|
m_ControlsDirectCutUC.SetValue(Grid.RowProperty, 1)
|
||||||
Else
|
m_ControlsDirectCutUC1.SetValue(Grid.RowProperty, 1)
|
||||||
m_SingleCut.SetValue(Grid.RowProperty, 1)
|
|
||||||
End If
|
|
||||||
m_SingleDrill.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_MultipleCut.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_GridCut.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_FlatteningCut.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_Polishing.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_CopyTemplate.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_SawTest.SetValue(Grid.RowProperty, 1)
|
|
||||||
m_ControlsMachineButton.SetValue(Grid.RowProperty, 1)
|
m_ControlsMachineButton.SetValue(Grid.RowProperty, 1)
|
||||||
m_VacuumMachineButton.SetValue(Grid.RowProperty, 1)
|
m_VacuumMachineButton.SetValue(Grid.RowProperty, 1)
|
||||||
|
|
||||||
' verifico che sia presente almeno uno dei bottoni della nuova console (SOLO PER MACCHINA CON paragrafo [ControlMachButtons])
|
' verifico che sia presente almeno uno dei bottoni della nuova console (SOLO PER MACCHINA CON paragrafo [ControlMachButtons])
|
||||||
Dim bCollapsedNewBottonsConsole As Boolean = Not m_ControlsMachineButton.GetPrivateProfileMachineButtons("JogButtons", "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
Dim bCollapsedNewBottonsConsole As Boolean = Not m_ControlsMachineButton.GetPrivateProfileMachineButtons("JogButtons", "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
||||||
m_NewMachineButtonsType = m_ControlsMachineButton.GetPrivateProfileMachineButtons(S_CONTROLMACHBUTTONS, "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
m_NewMachineButtonsType = m_ControlsMachineButton.GetPrivateProfileMachineButtons(S_CONTROLMACHBUTTONS, "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
||||||
|
' verifico che sia presente almeno uno dei bottoni della nuova console (SOLO PER MACCHINA CON paragrafo [VacuumMachButtons])
|
||||||
|
Dim bCollapsedVacuumButton As Boolean = Not m_ControlsMachineButton.GetPrivateProfileMachineButtons(S_VACUUMMACHBUTTONS, "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
||||||
If Not m_NewMachineButtonsType Then
|
If Not m_NewMachineButtonsType Then
|
||||||
'Assegno MachineButtons alla pagina
|
'Assegno MachineButtons alla pagina
|
||||||
LowerButtonGrid.Children.Add(m_MachineButtons)
|
LowerButtonGrid.Children.Add(m_MachineButtons)
|
||||||
ControlsMachineBtn.Visibility = Windows.Visibility.Collapsed
|
ControlsMachineBtn.Visibility = Windows.Visibility.Collapsed
|
||||||
VacuumMachineBtn.Visibility = Windows.Visibility.Collapsed
|
VacuumMachineBtn.Visibility = Windows.Visibility.Collapsed
|
||||||
End If
|
End If
|
||||||
|
' se non sono configurate le ventose allora nascondo il comando
|
||||||
If GetPrivateProfileInt(S_NUMERICALCONTROL, K_TYPE, 0, m_MainWindow.GetMachIniFile()) = 0 Then
|
If m_NewMachineButtonsType AndAlso bCollapsedVacuumButton Then
|
||||||
ManualBtn.IsEnabled = False
|
VacuumMachineBtn.Visibility = Windows.Visibility.Collapsed
|
||||||
ManualModeBtn.Visibility = Windows.Visibility.Hidden
|
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' ManualBtn.Content = EgtMsg(90201)
|
|
||||||
ManualTxt.Text = EgtMsg(90201)
|
|
||||||
'SingleCutBtn.Content = EgtMsg(90202)
|
|
||||||
SingleCutTxt.Text = EgtMsg(90202)
|
|
||||||
'SingleDrillBtn.Content = "Foro singolo"
|
|
||||||
SingleDrillTxt.Text = EgtMsg(90258)
|
|
||||||
'MultipleCutBtn.Content = EgtMsg(90203)
|
|
||||||
MultipleCutTxt.Text = EgtMsg(90203)
|
|
||||||
'GridCutBtn.Content = EgtMsg(90204)
|
|
||||||
GridCutTxt.Text = EgtMsg(90204)
|
|
||||||
'FlatteningCutBtn.Content = EgtMsg(90206)
|
|
||||||
FlatteningCutTxt.Text = EgtMsg(90206)
|
|
||||||
'PolishingBtn.Content = EgtMsg(90231)
|
|
||||||
PolishingTxt.Text = EgtMsg(90231)
|
|
||||||
'CopyTemplateBtn.Content = EgtMsg(90209)
|
|
||||||
CopyTemplateTxt.Text = EgtMsg(90209)
|
|
||||||
'SawTestBtn.Content = EgtMsg(90207)
|
|
||||||
SawTestTxt.text = EgtMsg(90207)
|
|
||||||
|
|
||||||
|
|
||||||
' nuovi bottoni 20/05/2021 - modifica specifiche 04/08/2021
|
' nuovi bottoni 20/05/2021 - modifica specifiche 04/08/2021
|
||||||
' leggo il numero di assi attivi nella macchina
|
' leggo il numero di assi attivi nella macchina
|
||||||
Dim AxesNumber = GetPrivateProfileInt(S_AXES, K_AXESNUM, 5, m_MainWindow.GetMachIniFile())
|
Dim AxesNumber = GetPrivateProfileInt(S_AXES, K_AXESNUM, 5, m_MainWindow.GetMachIniFile())
|
||||||
@@ -176,59 +124,10 @@ Public Class DirectCutPageUC
|
|||||||
' lo stato di questi comandi vieni carico dalla lettura del PLC (refresh)
|
' lo stato di questi comandi vieni carico dalla lettura del PLC (refresh)
|
||||||
'----------- FINE NUOVI BOTTONI------------
|
'----------- FINE NUOVI BOTTONI------------
|
||||||
|
|
||||||
' Se rientro da simulazione
|
LoadLastDirectCutControls()
|
||||||
If m_ActiveDirectCutPage = DirectCutPages.SingleCut Then
|
|
||||||
LeftButtonGrid.Children.Add(m_SingleCut)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.SingleCutAuto Then
|
|
||||||
LeftButtonGrid.Children.Add(m_SingleCutAuto)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.MultipleCut Then
|
|
||||||
LeftButtonGrid.Children.Add(m_MultipleCut)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.GridCut Then
|
|
||||||
LeftButtonGrid.Children.Add(m_GridCut)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.FlatteningCut Then
|
|
||||||
LeftButtonGrid.Children.Add(m_FlatteningCut)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.Polishing Then
|
|
||||||
LeftButtonGrid.Children.Add(m_Polishing)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.SawTest Then
|
|
||||||
LeftButtonGrid.Children.Add(m_SawTest)
|
|
||||||
Return
|
|
||||||
ElseIf m_ActiveDirectCutPage = DirectCutPages.SingleDrill Then
|
|
||||||
LeftButtonGrid.Children.Add(m_SingleDrill)
|
|
||||||
Return
|
|
||||||
End If
|
|
||||||
|
|
||||||
' Caso standard
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.DirectCut
|
|
||||||
|
|
||||||
' Se macchina fotografica abilitata
|
' Se macchina fotografica abilitata
|
||||||
PhotoBtn.IsEnabled = m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.MAN_PHOTO)
|
PhotoBtn.IsEnabled = m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.MAN_PHOTO)
|
||||||
|
|
||||||
' Attivo le lavorazioni solo se esiste il grezzo e se presente testa H1
|
|
||||||
Dim bRawOk As Boolean = (GetRawHeight() > EPS_SMALL)
|
|
||||||
Dim bH1Exists As Boolean = (EgtGetHeadId("H1") <> GDB_ID.NULL)
|
|
||||||
|
|
||||||
ManualBtn.IsEnabled = bH1Exists
|
|
||||||
' sviluppo rimasto in sospeso
|
|
||||||
If m_bManulaCut Then
|
|
||||||
' anche se non è presente un grezzo mantengo abilitato il bottone
|
|
||||||
SingleCutBtn.IsEnabled = True
|
|
||||||
Else
|
|
||||||
SingleCutBtn.IsEnabled = bRawOk
|
|
||||||
End If
|
|
||||||
MultipleCutBtn.IsEnabled = bRawOk
|
|
||||||
GridCutBtn.IsEnabled = bRawOk
|
|
||||||
SingleDrillBtn.IsEnabled = (bRawOk And bH1Exists)
|
|
||||||
FlatteningCutBtn.IsEnabled = (bRawOk And bH1Exists)
|
|
||||||
PolishingBtn.IsEnabled = (bRawOk And m_MainWindow.m_CurrentMachine.bPolishing)
|
|
||||||
SawTestBtn.IsEnabled = (bRawOk And bH1Exists)
|
|
||||||
CopyTemplateBtn.IsEnabled = bH1Exists
|
|
||||||
|
|
||||||
' aggiorno la visualizzazione dei parametri
|
' aggiorno la visualizzazione dei parametri
|
||||||
ReloadParam()
|
ReloadParam()
|
||||||
|
|
||||||
@@ -247,9 +146,9 @@ Public Class DirectCutPageUC
|
|||||||
If Not String.IsNullOrEmpty(sCurrSaw) And Not String.IsNullOrEmpty(sCurrSawing) Then
|
If Not String.IsNullOrEmpty(sCurrSaw) And Not String.IsNullOrEmpty(sCurrSawing) Then
|
||||||
bSaw = EgtSetCalcTool(sCurrSaw, "H1", 1)
|
bSaw = EgtSetCalcTool(sCurrSaw, "H1", 1)
|
||||||
End If
|
End If
|
||||||
m_SingleCut.SetEnableParam(bSaw)
|
m_ControlsDirectCutUC.m_SingleCut.SetEnableParam(bSaw)
|
||||||
m_MultipleCut.SetEnableParam(bSaw)
|
m_ControlsDirectCutUC.m_MultipleCut.SetEnableParam(bSaw)
|
||||||
m_GridCut.SetEnableParam(bSaw)
|
m_ControlsDirectCutUC.m_GridCut.SetEnableParam(bSaw)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub SetVisibilityJogButtuns()
|
Private Sub SetVisibilityJogButtuns()
|
||||||
@@ -257,6 +156,7 @@ Public Class DirectCutPageUC
|
|||||||
ZCBtn.Visibility = Visibility.Collapsed
|
ZCBtn.Visibility = Visibility.Collapsed
|
||||||
ZBBtn.Visibility = Visibility.Collapsed
|
ZBBtn.Visibility = Visibility.Collapsed
|
||||||
RemoteBtn.Visibility = Visibility.Collapsed
|
RemoteBtn.Visibility = Visibility.Collapsed
|
||||||
|
ParkingBtn.Visibility = Visibility.Collapsed
|
||||||
|
|
||||||
Dim Item As MachineButton = Nothing
|
Dim Item As MachineButton = Nothing
|
||||||
For Each Item In m_ButtonJogList
|
For Each Item In m_ButtonJogList
|
||||||
@@ -277,6 +177,10 @@ Public Class DirectCutPageUC
|
|||||||
RemoteBtn.Visibility = Visibility.Visible
|
RemoteBtn.Visibility = Visibility.Visible
|
||||||
RemoteBtn.Foreground = Brushes.White
|
RemoteBtn.Foreground = Brushes.White
|
||||||
RemoteBtn.Content = "Remote"
|
RemoteBtn.Content = "Remote"
|
||||||
|
Case K_PARKING
|
||||||
|
ParkingBtn.Visibility = Visibility.Visible
|
||||||
|
ParkingBtn.Foreground = Brushes.White
|
||||||
|
ParkingBtn.ToolTip = "Parking"
|
||||||
End Select
|
End Select
|
||||||
Next
|
Next
|
||||||
End Sub
|
End Sub
|
||||||
@@ -305,63 +209,13 @@ Public Class DirectCutPageUC
|
|||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ManualBtn_Click(sender As Object, e As RoutedEventArgs) Handles ManualBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_ManualAxesMove)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.ManualAxesMove
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub SingleCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles SingleCutBtn.Click
|
|
||||||
If m_bManulaCut Then
|
|
||||||
LeftButtonGrid.Children.Add(m_SingleCutAuto)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.SingleCutAuto
|
|
||||||
Else
|
|
||||||
LeftButtonGrid.Children.Add(m_SingleCut)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.SingleCut
|
|
||||||
End If
|
|
||||||
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub MultipleCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles MultipleCutBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_MultipleCut)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.MultipleCut
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub GridCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles GridCutBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_GridCut)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.GridCut
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub FlatteningCutBtn_Click(sender As Object, e As RoutedEventArgs) Handles FlatteningCutBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_FlatteningCut)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.FlatteningCut
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub PolishingBtn_Click(sender As Object, e As RoutedEventArgs) Handles PolishingBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_Polishing)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.Polishing
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub CopyTemplateBtn_Click(sender As Object, e As RoutedEventArgs) Handles CopyTemplateBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_CopyTemplate)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.CopyTemplate
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub SawTestBtn_Click(sender As Object, e As RoutedEventArgs) Handles SawTestBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_SawTest)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.SawTest
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub SingleDrillBtn_Click(sender As Object, e As RoutedEventArgs) Handles SingleDrillBtn.Click
|
|
||||||
LeftButtonGrid.Children.Add(m_SingleDrill)
|
|
||||||
m_ActiveDirectCutPage = DirectCutPages.SingleDrill
|
|
||||||
End Sub
|
|
||||||
|
|
||||||
Private Sub ControlsMachineBtn_Click(sender As Object, e As RoutedEventArgs) Handles ControlsMachineBtn.Click
|
Private Sub ControlsMachineBtn_Click(sender As Object, e As RoutedEventArgs) Handles ControlsMachineBtn.Click
|
||||||
If ControlsMachineBtn.IsChecked Then
|
If ControlsMachineBtn.IsChecked Then
|
||||||
m_ControlsMachineButton = New ControlsMachineButtonUC
|
m_ControlsMachineButton = New ControlsMachineButtonUC
|
||||||
m_ControlsMachineButton.SetValue(Grid.RowProperty, 1)
|
m_ControlsMachineButton.SetValue(Grid.RowProperty, 1)
|
||||||
m_NewMachineButtonsType = m_ControlsMachineButton.GetPrivateProfileMachineButtons(S_CONTROLMACHBUTTONS, "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
m_NewMachineButtonsType = m_ControlsMachineButton.GetPrivateProfileMachineButtons(S_CONTROLMACHBUTTONS, "Button1", Nothing, Nothing, Nothing, Nothing, Nothing, Nothing, m_MainWindow.GetMachIniFile())
|
||||||
MachineButtonGrid.Children.Add(m_ControlsMachineButton)
|
MachineButtonGrid.Children.Add(m_ControlsMachineButton)
|
||||||
|
m_ActiveControl = Controls.MachineButtonUC
|
||||||
If VacuumMachineBtn.IsChecked Then
|
If VacuumMachineBtn.IsChecked Then
|
||||||
MachineButtonGrid.Children.Remove(m_VacuumMachineButton)
|
MachineButtonGrid.Children.Remove(m_VacuumMachineButton)
|
||||||
VacuumMachineBtn.IsChecked = False
|
VacuumMachineBtn.IsChecked = False
|
||||||
@@ -374,6 +228,7 @@ Public Class DirectCutPageUC
|
|||||||
Private Sub VacuumMachineBtn_Click(sender As Object, e As RoutedEventArgs) Handles VacuumMachineBtn.Click
|
Private Sub VacuumMachineBtn_Click(sender As Object, e As RoutedEventArgs) Handles VacuumMachineBtn.Click
|
||||||
If VacuumMachineBtn.IsChecked Then
|
If VacuumMachineBtn.IsChecked Then
|
||||||
MachineButtonGrid.Children.Add(m_VacuumMachineButton)
|
MachineButtonGrid.Children.Add(m_VacuumMachineButton)
|
||||||
|
m_ActiveControl = Controls.VacuumButtonUC
|
||||||
If ControlsMachineBtn.IsChecked Then
|
If ControlsMachineBtn.IsChecked Then
|
||||||
MachineButtonGrid.Children.Remove(m_ControlsMachineButton)
|
MachineButtonGrid.Children.Remove(m_ControlsMachineButton)
|
||||||
ControlsMachineBtn.IsChecked = False
|
ControlsMachineBtn.IsChecked = False
|
||||||
@@ -383,7 +238,21 @@ Public Class DirectCutPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
'------------------NUOVI BOTTONI PER GESTIONE JOYSTICK-------------------------------------------------
|
Friend Sub LoadDirectCutUC()
|
||||||
|
ManageControls()
|
||||||
|
m_ActiveControl = Controls.DirectCutUC
|
||||||
|
MachineButtonGrid.Children.Add(m_ControlsDirectCutUC)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Friend Sub LoadDirectCutUC1()
|
||||||
|
ManageControls()
|
||||||
|
m_ActiveControl = Controls.DirectCutUC1
|
||||||
|
MachineButtonGrid.Children.Add(m_ControlsDirectCutUC1)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
|
||||||
|
#Region "[JogButtons]"
|
||||||
|
|
||||||
Private Sub XYBtn_Click(sender As Object, e As RoutedEventArgs) Handles XYBtn.Click
|
Private Sub XYBtn_Click(sender As Object, e As RoutedEventArgs) Handles XYBtn.Click
|
||||||
' riverco in elenco il bottone XYJog
|
' riverco in elenco il bottone XYJog
|
||||||
Dim XYJogButton As MachineButton = Nothing
|
Dim XYJogButton As MachineButton = Nothing
|
||||||
@@ -513,7 +382,45 @@ Public Class DirectCutPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
'------------------NUOVI BOTTONI PER GESTIONE JOYSTICK-------------------------------------------------
|
Private Sub ParkingBtn_Click(sender As Object, e As RoutedEventArgs) Handles ParkingBtn.Click
|
||||||
|
Dim ParkingButton As MachineButton = Nothing
|
||||||
|
Dim ItemButton As MachineButton = Nothing
|
||||||
|
For Each ItemButton In m_ButtonJogList
|
||||||
|
If ItemButton.StateFlag = K_PARKING Then
|
||||||
|
ParkingButton = ItemButton
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
If IsNothing(ParkingButton) Then Return
|
||||||
|
' eseguo lo script lua associato
|
||||||
|
Dim CurrentBtn As Primitives.ToggleButton = e.Source
|
||||||
|
Dim sLuaFileName As String = String.Empty
|
||||||
|
' verifico lo stato del bottone per avviare il giusto script
|
||||||
|
If CurrentBtn.IsChecked() Then
|
||||||
|
sLuaFileName = ParkingButton.TLuaScriptName
|
||||||
|
Else
|
||||||
|
sLuaFileName = ParkingButton.FLuaScriptName
|
||||||
|
End If
|
||||||
|
ParkingButton.ExecuteMDICommand(sLuaFileName)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Friend Sub ParkingStateChanged(bParkingState As Boolean)
|
||||||
|
' devo decodificare il tipo di pulsante, quindi eseguire la conversione...
|
||||||
|
Dim ParkingButton As TwoStateButton = Nothing
|
||||||
|
For Each MachineButton As MachineButton In m_ButtonJogList
|
||||||
|
If MachineButton.StateFlag.Trim = K_PARKING Then
|
||||||
|
ParkingButton = MachineButton
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
If Not IsNothing(ParkingButton) Then
|
||||||
|
ParkingButton.SetIsChecked(bParkingState)
|
||||||
|
ParkingButton.IsChecked = bParkingState
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#End Region '[JogButtons]
|
||||||
|
|
||||||
Private Sub MachViewModeBtn_Click(sender As Object, e As RoutedEventArgs) Handles MachViewModeBtn.Click
|
Private Sub MachViewModeBtn_Click(sender As Object, e As RoutedEventArgs) Handles MachViewModeBtn.Click
|
||||||
If m_bShowMachine Then
|
If m_bShowMachine Then
|
||||||
' aggiorno lo stato
|
' aggiorno lo stato
|
||||||
@@ -522,6 +429,8 @@ Public Class DirectCutPageUC
|
|||||||
m_nMachLook = MCH_LOOK.TAB_HEAD
|
m_nMachLook = MCH_LOOK.TAB_HEAD
|
||||||
Case MCH_LOOK.TAB_HEAD
|
Case MCH_LOOK.TAB_HEAD
|
||||||
m_nMachLook = MCH_LOOK.TAB_TOOL
|
m_nMachLook = MCH_LOOK.TAB_TOOL
|
||||||
|
Case MCH_LOOK.TAB_TOOL
|
||||||
|
m_nMachLook = MCH_LOOK.TAB
|
||||||
Case Else
|
Case Else
|
||||||
m_nMachLook = MCH_LOOK.ALL
|
m_nMachLook = MCH_LOOK.ALL
|
||||||
End Select
|
End Select
|
||||||
@@ -532,36 +441,40 @@ Public Class DirectCutPageUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Sub DirectCutPage_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
Friend Sub DirectCutPage_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
||||||
Select Case m_ActiveDirectCutPage
|
ManageControls()
|
||||||
Case DirectCutPages.DirectCut Or DirectCutPages.ManualAxesMove
|
End Sub
|
||||||
' Non è necessario fare alcunché
|
|
||||||
Case DirectCutPages.SingleCut
|
Friend Sub ManageControls()
|
||||||
LeftButtonGrid.Children.Remove(m_SingleCut)
|
Select Case m_ActiveControl
|
||||||
Case DirectCutPages.SingleCutAuto
|
Case Controls.DirectCutUC
|
||||||
LeftButtonGrid.Children.Remove(m_SingleCutAuto)
|
MachineButtonGrid.Children.Remove(m_ControlsDirectCutUC)
|
||||||
Case DirectCutPages.MultipleCut
|
m_ControlsDirectCutUC.DirectCutPage_Unloaded(Nothing, Nothing)
|
||||||
LeftButtonGrid.Children.Remove(m_MultipleCut)
|
Case Controls.DirectCutUC1
|
||||||
Case DirectCutPages.GridCut
|
MachineButtonGrid.Children.Remove(m_ControlsDirectCutUC1)
|
||||||
LeftButtonGrid.Children.Remove(m_GridCut)
|
m_ControlsDirectCutUC1.DirectCutPage_Unloaded(Nothing, Nothing)
|
||||||
Case DirectCutPages.FlatteningCut
|
Case Controls.MachineButtonUC
|
||||||
LeftButtonGrid.Children.Remove(m_FlatteningCut)
|
|
||||||
Case DirectCutPages.Polishing
|
|
||||||
LeftButtonGrid.Children.Remove(m_Polishing)
|
|
||||||
Case DirectCutPages.CopyTemplate
|
|
||||||
LeftButtonGrid.Children.Remove(m_CopyTemplate)
|
|
||||||
Case DirectCutPages.SawTest
|
|
||||||
LeftButtonGrid.Children.Remove(m_SawTest)
|
|
||||||
Case DirectCutPages.SingleDrill
|
|
||||||
LeftButtonGrid.Children.Remove(m_SingleDrill)
|
|
||||||
End Select
|
|
||||||
If ControlsMachineBtn.IsChecked Then
|
|
||||||
MachineButtonGrid.Children.Remove(m_ControlsMachineButton)
|
MachineButtonGrid.Children.Remove(m_ControlsMachineButton)
|
||||||
|
MachineButtonGrid.Children.Remove(m_ControlsDirectCutUC)
|
||||||
|
MachineButtonGrid.Children.Remove(m_ControlsDirectCutUC1)
|
||||||
ControlsMachineBtn.IsChecked = False
|
ControlsMachineBtn.IsChecked = False
|
||||||
End If
|
Case Controls.VacuumButtonUC
|
||||||
If VacuumMachineBtn.IsChecked Then
|
MachineButtonGrid.Children.Remove(m_ControlsMachineButton)
|
||||||
|
MachineButtonGrid.Children.Remove(m_ControlsDirectCutUC)
|
||||||
MachineButtonGrid.Children.Remove(m_VacuumMachineButton)
|
MachineButtonGrid.Children.Remove(m_VacuumMachineButton)
|
||||||
VacuumMachineBtn.IsChecked = False
|
VacuumMachineBtn.IsChecked = False
|
||||||
End If
|
End Select
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Friend Sub LoadLastDirectCutControls()
|
||||||
|
Select Case m_ActiveControl
|
||||||
|
Case Controls.DirectCutUC
|
||||||
|
MachineButtonGrid.Children.Add(m_ControlsDirectCutUC)
|
||||||
|
Case Controls.DirectCutUC1
|
||||||
|
MachineButtonGrid.Children.Add(m_ControlsDirectCutUC1)
|
||||||
|
Case Else
|
||||||
|
m_ActiveControl = Controls.DirectCutUC
|
||||||
|
MachineButtonGrid.Children.Add(m_ControlsDirectCutUC)
|
||||||
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ManualModeBtn_Click(sender As Object, e As RoutedEventArgs) Handles ManualModeBtn.Click
|
Private Sub ManualModeBtn_Click(sender As Object, e As RoutedEventArgs) Handles ManualModeBtn.Click
|
||||||
|
|||||||
@@ -65,7 +65,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="3"
|
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="3"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="LenghtTxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="LenghtTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
|
|||||||
@@ -66,6 +66,7 @@ Public Class FlatteningCut
|
|||||||
Right
|
Right
|
||||||
End Enum
|
End Enum
|
||||||
|
|
||||||
|
' Per abilitare la spianatura con la FRESA deve essere imposatato a TRUE il flag "Usa Fresa" nella pagina MACCHINA (campo INCISIONI)
|
||||||
Private Sub FlatteningCut_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
Private Sub FlatteningCut_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
' Creo lista modalità di acquisizione punto
|
' Creo lista modalità di acquisizione punto
|
||||||
m_PointsModeArray(PT_MODE.SAW) = EgtMsg(MSG_DIRECTCUTPAGEUC + 24)
|
m_PointsModeArray(PT_MODE.SAW) = EgtMsg(MSG_DIRECTCUTPAGEUC + 24)
|
||||||
@@ -189,7 +190,7 @@ Public Class FlatteningCut
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -567,6 +568,7 @@ Public Class FlatteningCut
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -609,18 +611,21 @@ Public Class FlatteningCut
|
|||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
EgtMdbSetGeneralParam(MCH_GP.SAFEZ, DirectCutPageUC.m_dZSafe)
|
EgtMdbSetGeneralParam(MCH_GP.SAFEZ, DirectCutPageUC.m_dZSafe)
|
||||||
EgtMdbSave()
|
EgtMdbSave()
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
' ricavo l'ingombro di lavorazione in funzione dell'utensile selezionato
|
' ricavo l'ingombro di lavorazione in funzione dell'utensile selezionato
|
||||||
Private Function GetFootPrintTool() As Double
|
Private Function GetFootPrintTool() As Double
|
||||||
|
' vedere nella pagina Allarm il capito "Incisioni"
|
||||||
|
Dim bForceUseMill As Boolean = (GetPrivateProfileInt(S_MACH_NEST, K_MACH_ENGRAVING_WITHMILL, 1, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
Dim dFootPrint As Double = 0
|
Dim dFootPrint As Double = 0
|
||||||
' verifico quale lavorazione è attiva
|
' verifico quale lavorazione è attiva
|
||||||
If Not String.IsNullOrEmpty(m_MainWindow.m_CurrentMachine.sCurrSawing) Then
|
If Not String.IsNullOrEmpty(m_MainWindow.m_CurrentMachine.sCurrSawing) AndAlso Not bForceUseMill Then
|
||||||
EgtTdbGetCurrToolParam(MCH_TP.THICK, dFootPrint)
|
EgtTdbGetCurrToolParam(MCH_TP.THICK, dFootPrint)
|
||||||
ElseIf Not String.IsNullOrEmpty(m_MainWindow.m_CurrentMachine.sCurrMilling) Then
|
ElseIf Not String.IsNullOrEmpty(m_MainWindow.m_CurrentMachine.sCurrMilling) Then
|
||||||
Dim sCurrMill = m_MainWindow.m_CurrentMachine.sCurrMill
|
Dim sCurrMill = m_MainWindow.m_CurrentMachine.sCurrMill
|
||||||
GetDrillFromDrilling(sCurrMill, m_MainWindow.m_CurrentMachine.sCurrMilling)
|
'GetDrillFromDrilling(sCurrMill, m_MainWindow.m_CurrentMachine.sCurrMilling)
|
||||||
|
GetMillFromMilling(sCurrMill, m_MainWindow.m_CurrentMachine.sCurrMilling)
|
||||||
' recupero informazioni della fresa in uso
|
' recupero informazioni della fresa in uso
|
||||||
EgtTdbSetCurrTool(sCurrMill)
|
EgtTdbSetCurrTool(sCurrMill)
|
||||||
EgtTdbGetCurrToolParam(MCH_TP.DIAM, dFootPrint)
|
EgtTdbGetCurrToolParam(MCH_TP.DIAM, dFootPrint)
|
||||||
@@ -652,6 +657,9 @@ Public Class FlatteningCut
|
|||||||
Dim nCutId = EgtCreateLinePDL(nLayerId, ptStart, m_dAngO, m_dLen)
|
Dim nCutId = EgtCreateLinePDL(nLayerId, ptStart, m_dAngO, m_dLen)
|
||||||
' Imposto affondamento e angolo di fianco sul taglio
|
' Imposto affondamento e angolo di fianco sul taglio
|
||||||
EgtSetInfo(nCutId, INFO_DEPTH, m_dDepth)
|
EgtSetInfo(nCutId, INFO_DEPTH, m_dDepth)
|
||||||
|
If (GetPrivateProfileInt(S_MACH_NEST, K_MACH_ENGRAVING_WITHMILL, 1, m_MainWindow.GetMachIniFile()) <> 0) Then
|
||||||
|
EgtSetInfo(nCutId, INFO_WIDTH, GetFootPrintTool)
|
||||||
|
End If
|
||||||
EgtSetInfo(nCutId, INFO_SIDE_ANGLE, 0)
|
EgtSetInfo(nCutId, INFO_SIDE_ANGLE, 0)
|
||||||
' Imposto prima direzione
|
' Imposto prima direzione
|
||||||
EgtSetInfo(nCutId, INFO_DIR, 1)
|
EgtSetInfo(nCutId, INFO_DIR, 1)
|
||||||
|
|||||||
@@ -61,12 +61,12 @@
|
|||||||
|
|
||||||
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="3"
|
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="3"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<Grid Grid.Row="5" Grid.ColumnSpan="2">
|
<Grid Grid.Row="5" Grid.ColumnSpan="2">
|
||||||
@@ -89,7 +89,7 @@
|
|||||||
<TextBlock Name="DimPzXTxBl" Grid.Column="2" Grid.Row="0"
|
<TextBlock Name="DimPzXTxBl" Grid.Column="2" Grid.Row="0"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPzXTxBx" Grid.Column="0" Grid.Row="1" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPzXTxBx" Grid.Column="0" Grid.Row="1" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPzXTxBx" Grid.Column="2" Grid.Row="1" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPzXTxBx" Grid.Column="2" Grid.Row="1" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}" />
|
Style="{StaticResource OmagCut_CalculatorTextBox}" />
|
||||||
@@ -99,7 +99,7 @@
|
|||||||
<TextBlock Name="DimPzYTxBl" Grid.Column="2" Grid.Row="2"
|
<TextBlock Name="DimPzYTxBl" Grid.Column="2" Grid.Row="2"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPzYTxBx" Grid.Column="0" Grid.Row="3" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPzYTxBx" Grid.Column="0" Grid.Row="3" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPzYTxBx" Grid.Column="2" Grid.Row="3" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPzYTxBx" Grid.Column="2" Grid.Row="3" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}" />
|
Style="{StaticResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|||||||
@@ -168,7 +168,7 @@ Public Class GridCut
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -494,6 +494,7 @@ Public Class GridCut
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -534,7 +535,7 @@ Public Class GridCut
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreateGridCut() As Boolean
|
Private Function CreateGridCut() As Boolean
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ Public Class MachineButtonsUC
|
|||||||
Private m_DirectCutPage As DirectCutPageUC
|
Private m_DirectCutPage As DirectCutPageUC
|
||||||
Friend m_CN As CN_generico
|
Friend m_CN As CN_generico
|
||||||
|
|
||||||
|
Public nCountButton As Integer = 11
|
||||||
|
|
||||||
Private m_bOnlyLaser As Boolean = False
|
Private m_bOnlyLaser As Boolean = False
|
||||||
Private m_bFirst As Boolean = True
|
Private m_bFirst As Boolean = True
|
||||||
|
|
||||||
@@ -76,6 +78,9 @@ Public Class MachineButtonsUC
|
|||||||
GetToggleButton(nIndex + 1).Visibility = Windows.Visibility.Hidden
|
GetToggleButton(nIndex + 1).Visibility = Windows.Visibility.Hidden
|
||||||
Next
|
Next
|
||||||
|
|
||||||
|
' notifico nella variabile pubblica il numero di pulsanti inseriti nella barra
|
||||||
|
nCountButton = m_nCount
|
||||||
|
|
||||||
' Se variabile di stato "Nothing"/"DoorOpened"/"DoorClosed" imposto immagine fissa
|
' Se variabile di stato "Nothing"/"DoorOpened"/"DoorClosed" imposto immagine fissa
|
||||||
For nIndex As Integer = 0 To m_nCount - 1
|
For nIndex As Integer = 0 To m_nCount - 1
|
||||||
If StateFlagArray(nIndex) = BTN_STATE_NOTHING OrElse
|
If StateFlagArray(nIndex) = BTN_STATE_NOTHING OrElse
|
||||||
@@ -267,9 +272,62 @@ Public Class MachineButtonsUC
|
|||||||
End If
|
End If
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
|
' CONTROLLO FANUC
|
||||||
|
Case 4
|
||||||
|
' ------------------------------------ FANUC ------------------------------------
|
||||||
|
' eventuale scrittura di linea di comando MDI
|
||||||
|
If Not String.IsNullOrEmpty(CmdString) Then
|
||||||
|
' attivo mpdalità MDI
|
||||||
|
m_CN.DGeneralFunctions_WriteCncMode(2)
|
||||||
|
System.Threading.Thread.Sleep(100)
|
||||||
|
' salvo la stringa di comando ricevuta dal file lua
|
||||||
|
m_CN.sz_ManualDataInput = CmdString
|
||||||
|
' esguo la funzione che ha il compito di scrivere il comando MDI
|
||||||
|
m_CN.MDI_command()
|
||||||
|
End If
|
||||||
|
' attivo modalità AUTO
|
||||||
|
m_CN.DGeneralFunctions_WriteCncMode(7)
|
||||||
|
System.Threading.Thread.Sleep(100)
|
||||||
|
If String.IsNullOrEmpty(EValue) Then
|
||||||
|
' EActive: impulsivo "D#####"
|
||||||
|
m_CN.NC_pulse_bit(ENumber)
|
||||||
|
EgtOutLog("Fanuc_DNumber= " & ENumber)
|
||||||
|
Else
|
||||||
|
' EActive + EValue: scrittura comando invariabile Short oppure Bit
|
||||||
|
If ENumber.Contains(".") Then
|
||||||
|
' D#####.#
|
||||||
|
Dim bEValue As Boolean
|
||||||
|
If EValue.Trim = "1" Then bEValue = True
|
||||||
|
m_CN.NC_write_var_bit(ENumber, CBool(EValue))
|
||||||
|
Else
|
||||||
|
' D#####
|
||||||
|
m_CN.NC_write_var_short(ENumber, CShort(EValue))
|
||||||
|
End If
|
||||||
|
EgtOutLog("Fanuc_DNumber= " & ENumber & " DValue= " & EValue)
|
||||||
|
End If
|
||||||
|
' eventale caricamento seconda variabile
|
||||||
|
If String.IsNullOrEmpty(EValue2) Then
|
||||||
|
' EActive: impulsivo "D#####"
|
||||||
|
m_CN.NC_pulse_bit(ENumber2)
|
||||||
|
EgtOutLog("Fanuc_DNumber= " & ENumber2)
|
||||||
|
Else
|
||||||
|
' EActive + EValue: scrittura comando invariabile Short oppure Bit
|
||||||
|
If ENumber2.Contains(".") Then
|
||||||
|
' D#####.#
|
||||||
|
Dim bEValue2 As Boolean
|
||||||
|
If EValue2.Trim = "1" Then bEValue2 = True
|
||||||
|
m_CN.NC_write_var_bit(ENumber2, CBool(EValue2))
|
||||||
|
Else
|
||||||
|
' D#####
|
||||||
|
m_CN.NC_write_var_short(ENumber2, CShort(EValue2))
|
||||||
|
End If
|
||||||
|
EgtOutLog("Fanuc_DNumber2= " & ENumber2 & " DValue2= " & EValue2)
|
||||||
|
End If
|
||||||
|
Return
|
||||||
End Select
|
End Select
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
|
||||||
Dim nResult As Short
|
Dim nResult As Short
|
||||||
' Imposto modalità MDI per controlli num
|
' Imposto modalità MDI per controlli num
|
||||||
Select Case m_MainWindow.m_CNCommunication.m_nNCType
|
Select Case m_MainWindow.m_CNCommunication.m_nNCType
|
||||||
@@ -286,6 +344,8 @@ Public Class MachineButtonsUC
|
|||||||
m_CN.DGeneralFunctions_CycleStart()
|
m_CN.DGeneralFunctions_CycleStart()
|
||||||
Case 3
|
Case 3
|
||||||
'Per il siemens non devo fare nulla
|
'Per il siemens non devo fare nulla
|
||||||
|
Case 4
|
||||||
|
' Nicola: 27/03/2023 attivazione della funzione M# indicata?
|
||||||
End Select
|
End Select
|
||||||
|
|
||||||
If b2Start Then
|
If b2Start Then
|
||||||
|
|||||||
@@ -69,10 +69,10 @@
|
|||||||
<EgtWPFLib:EgtTextBox x:Name="L3TxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox x:Name="L3TxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<Button x:Name="R1Btn" Grid.Row="4" Height="60" Width="60" Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
<Button x:Name="R1Btn" Grid.Row="4" Height="60" Width="60" Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
||||||
<EgtWPFLib:EgtTextBox x:Name="R1TxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox x:Name="R1TxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<Button x:Name="R2Btn" Grid.Row="5" Height="60" Width="60" Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
<Button x:Name="R2Btn" Grid.Row="5" Height="60" Width="60" Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
||||||
<EgtWPFLib:EgtTextBox x:Name="R2TxBx" Grid.Column="1" Grid.Row="5" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox x:Name="R2TxBx" Grid.Column="1" Grid.Row="5" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<Grid Grid.Row="7" Grid.ColumnSpan="2">
|
<Grid Grid.Row="7" Grid.ColumnSpan="2">
|
||||||
|
|||||||
@@ -21,10 +21,12 @@ Public Class ManualAxesMoveUC
|
|||||||
' Messaggi
|
' Messaggi
|
||||||
L1SawThChBx.Content = EgtMsg(90232) ' Spessore lama
|
L1SawThChBx.Content = EgtMsg(90232) ' Spessore lama
|
||||||
L2SawThChBx.Content = EgtMsg(90232) ' Spessore lama
|
L2SawThChBx.Content = EgtMsg(90232) ' Spessore lama
|
||||||
|
|
||||||
AddHandler m_Timer.Tick, AddressOf Timer_tick
|
AddHandler m_Timer.Tick, AddressOf Timer_tick
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ManualAxesMove_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
Private Sub ManualAxesMove_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
|
m_CN = m_MainWindow.m_DirectCutPageUC.m_CN
|
||||||
' Valori feed e speed da lama corrente
|
' Valori feed e speed da lama corrente
|
||||||
Dim dTemp As Double = 0
|
Dim dTemp As Double = 0
|
||||||
EgtTdbSetCurrTool(m_MainWindow.m_CurrentProjectPageUC.ToolTxBx.Text)
|
EgtTdbSetCurrTool(m_MainWindow.m_CurrentProjectPageUC.ToolTxBx.Text)
|
||||||
@@ -207,7 +209,7 @@ Public Class ManualAxesMoveUC
|
|||||||
System.Threading.Thread.Sleep(150)
|
System.Threading.Thread.Sleep(150)
|
||||||
m_CN.DGeneralFunctions_CycleStart()
|
m_CN.DGeneralFunctions_CycleStart()
|
||||||
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nThreadSleep)
|
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nThreadSleep)
|
||||||
m_CN.DGeneralFunctions_WriteCncMode(7) ' Modalità manuale
|
' m_CN.DGeneralFunctions_WriteCncMode(7) ' Modalità manuale
|
||||||
m_MoveClicked = False
|
m_MoveClicked = False
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -338,7 +340,7 @@ Public Class ManualAxesMoveUC
|
|||||||
End Function
|
End Function
|
||||||
|
|
||||||
Private Sub BackBtn_Click(sender As Object, e As RoutedEventArgs) Handles BackBtn.Click
|
Private Sub BackBtn_Click(sender As Object, e As RoutedEventArgs) Handles BackBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub G0Btn_Checked(sender As Object, e As RoutedEventArgs) Handles G0Btn.Checked
|
Private Sub G0Btn_Checked(sender As Object, e As RoutedEventArgs) Handles G0Btn.Checked
|
||||||
|
|||||||
@@ -68,12 +68,12 @@
|
|||||||
|
|
||||||
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="5"
|
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="5"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="5" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="5" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<Grid Grid.Row="6" Grid.ColumnSpan="2" Visibility="Visible">
|
<Grid Grid.Row="6" Grid.ColumnSpan="2" Visibility="Visible">
|
||||||
@@ -124,70 +124,70 @@
|
|||||||
|
|
||||||
<TextBlock Name="Num1TxBl" Grid.Column="0" Grid.Row="0"
|
<TextBlock Name="Num1TxBl" Grid.Column="0" Grid.Row="0"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz1TxBx" Grid.Column="1" Grid.Row="0" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz1TxBx" Grid.Column="1" Grid.Row="0" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz1TxBx" Grid.Column="3" Grid.Row="0" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz1TxBx" Grid.Column="3" Grid.Row="0" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num2TxBl" Grid.Column="0" Grid.Row="1"
|
<TextBlock Name="Num2TxBl" Grid.Column="0" Grid.Row="1"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz2TxBx" Grid.Column="1" Grid.Row="1" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz2TxBx" Grid.Column="1" Grid.Row="1" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz2TxBx" Grid.Column="3" Grid.Row="1" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz2TxBx" Grid.Column="3" Grid.Row="1" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num3TxBl" Grid.Column="0" Grid.Row="2"
|
<TextBlock Name="Num3TxBl" Grid.Column="0" Grid.Row="2"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz3TxBx" Grid.Column="1" Grid.Row="2" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz3TxBx" Grid.Column="1" Grid.Row="2" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz3TxBx" Grid.Column="3" Grid.Row="2" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz3TxBx" Grid.Column="3" Grid.Row="2" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num4TxBl" Grid.Column="0" Grid.Row="3"
|
<TextBlock Name="Num4TxBl" Grid.Column="0" Grid.Row="3"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz4TxBx" Grid.Column="1" Grid.Row="3" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz4TxBx" Grid.Column="1" Grid.Row="3" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz4TxBx" Grid.Column="3" Grid.Row="3" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz4TxBx" Grid.Column="3" Grid.Row="3" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num5TxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="Num5TxBl" Grid.Column="0" Grid.Row="4"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz5TxBx" Grid.Column="1" Grid.Row="4" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz5TxBx" Grid.Column="1" Grid.Row="4" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz5TxBx" Grid.Column="3" Grid.Row="4" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz5TxBx" Grid.Column="3" Grid.Row="4" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num6TxBl" Grid.Column="0" Grid.Row="5"
|
<TextBlock Name="Num6TxBl" Grid.Column="0" Grid.Row="5"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz6TxBx" Grid.Column="1" Grid.Row="5" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz6TxBx" Grid.Column="1" Grid.Row="5" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz6TxBx" Grid.Column="3" Grid.Row="5" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz6TxBx" Grid.Column="3" Grid.Row="5" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num7TxBl" Grid.Column="0" Grid.Row="6"
|
<TextBlock Name="Num7TxBl" Grid.Column="0" Grid.Row="6"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz7TxBx" Grid.Column="1" Grid.Row="6" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz7TxBx" Grid.Column="1" Grid.Row="6" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz7TxBx" Grid.Column="3" Grid.Row="6" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz7TxBx" Grid.Column="3" Grid.Row="6" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num8TxBl" Grid.Column="0" Grid.Row="7"
|
<TextBlock Name="Num8TxBl" Grid.Column="0" Grid.Row="7"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz8TxBx" Grid.Column="1" Grid.Row="7" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz8TxBx" Grid.Column="1" Grid.Row="7" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz8TxBx" Grid.Column="3" Grid.Row="7" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz8TxBx" Grid.Column="3" Grid.Row="7" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num9TxBl" Grid.Column="0" Grid.Row="8"
|
<TextBlock Name="Num9TxBl" Grid.Column="0" Grid.Row="8"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz9TxBx" Grid.Column="1" Grid.Row="8" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz9TxBx" Grid.Column="1" Grid.Row="8" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz9TxBx" Grid.Column="3" Grid.Row="8" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz9TxBx" Grid.Column="3" Grid.Row="8" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="Num10TxBl" Grid.Column="0" Grid.Row="9"
|
<TextBlock Name="Num10TxBl" Grid.Column="0" Grid.Row="9"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="NumPz10TxBx" Grid.Column="1" Grid.Row="9" Width="75"
|
<EgtWPFLib:EgtTextBox Name="NumPz10TxBx" Grid.Column="1" Grid.Row="9" Width="75" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DimPz10TxBx" Grid.Column="3" Grid.Row="9" Width="75"
|
<EgtWPFLib:EgtTextBox Name="DimPz10TxBx" Grid.Column="3" Grid.Row="9" Width="75"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|||||||
@@ -195,7 +195,7 @@ Public Class MultipleCut
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -540,6 +540,7 @@ Public Class MultipleCut
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -580,7 +581,7 @@ Public Class MultipleCut
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreateMultipleCut() As Boolean
|
Private Function CreateMultipleCut() As Boolean
|
||||||
|
|||||||
@@ -6,6 +6,8 @@ Public Class Polishing
|
|||||||
' Riferimenti a pagine
|
' Riferimenti a pagine
|
||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
||||||
|
Private m_refControlDirectCutUC As ControlsDirectCutUC1
|
||||||
|
|
||||||
' Flag di pagina attiva
|
' Flag di pagina attiva
|
||||||
Private m_bActive As Boolean = False
|
Private m_bActive As Boolean = False
|
||||||
' Flag di simulazione in corso
|
' Flag di simulazione in corso
|
||||||
@@ -30,6 +32,7 @@ Public Class Polishing
|
|||||||
Private Sub Polishing_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
Private Sub Polishing_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
' Attivo la pagina
|
' Attivo la pagina
|
||||||
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
||||||
|
m_refControlDirectCutUC = m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC1
|
||||||
m_bActive = True
|
m_bActive = True
|
||||||
' Se rientro da simulazione
|
' Se rientro da simulazione
|
||||||
If m_bSimul Then
|
If m_bSimul Then
|
||||||
@@ -72,7 +75,7 @@ Public Class Polishing
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_refControlDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC1.DirectCutPages.DirectCut
|
||||||
' Cancello eventuali lucidature
|
' Cancello eventuali lucidature
|
||||||
RemovePolishings()
|
RemovePolishings()
|
||||||
' Riattivo eventuali lavorazioni presenti
|
' Riattivo eventuali lavorazioni presenti
|
||||||
@@ -148,6 +151,7 @@ Public Class Polishing
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_refControlDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -188,7 +192,7 @@ Public Class Polishing
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_refControlDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreatePolishing( sKitName As String) As Boolean
|
Private Function CreatePolishing( sKitName As String) As Boolean
|
||||||
|
|||||||
@@ -70,7 +70,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="OffsetTxBl" Grid.Column="0" Grid.Row="5"
|
<TextBlock Name="OffsetTxBl" Grid.Column="0" Grid.Row="5"
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ Public Class SawTestUC
|
|||||||
' Riferimenti a pagine
|
' Riferimenti a pagine
|
||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
||||||
|
Private m_refControlDirectCutUC As ControlsDirectCutUC1
|
||||||
' Flag di pagina attiva
|
' Flag di pagina attiva
|
||||||
Private m_bActive As Boolean = False
|
Private m_bActive As Boolean = False
|
||||||
' Flag di simulazione in corso
|
' Flag di simulazione in corso
|
||||||
@@ -76,6 +77,7 @@ Public Class SawTestUC
|
|||||||
Private Sub SawTest_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
Private Sub SawTest_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
' Attivo la pagina
|
' Attivo la pagina
|
||||||
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
||||||
|
m_refControlDirectCutUC = m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC1
|
||||||
m_bActive = True
|
m_bActive = True
|
||||||
' Se rientro da simulazione
|
' Se rientro da simulazione
|
||||||
If m_bSimul Then
|
If m_bSimul Then
|
||||||
@@ -139,7 +141,7 @@ Public Class SawTestUC
|
|||||||
WritePrivateProfileString( S_DIRECTCUTS, K_DC_TEST_OFFSET, DoubleToString( m_dOffset, 2), m_MainWindow.GetIniFile())
|
WritePrivateProfileString( S_DIRECTCUTS, K_DC_TEST_OFFSET, DoubleToString( m_dOffset, 2), m_MainWindow.GetIniFile())
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_refControlDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC1.DirectCutPages.DirectCut1
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -419,6 +421,7 @@ Public Class SawTestUC
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_refControlDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -459,7 +462,7 @@ Public Class SawTestUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_refControlDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreateSingleCut() As Boolean
|
Private Function CreateSingleCut() As Boolean
|
||||||
|
|||||||
@@ -363,7 +363,7 @@ Public Class SingleCutAuto
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -715,6 +715,7 @@ Public Class SingleCutAuto
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -758,7 +759,7 @@ Public Class SingleCutAuto
|
|||||||
' reimposto il precedetne utensile e lavorazione
|
' reimposto il precedetne utensile e lavorazione
|
||||||
m_MainWindow.m_CurrentMachine.sCurrSaw = m_PrecSaw
|
m_MainWindow.m_CurrentMachine.sCurrSaw = m_PrecSaw
|
||||||
m_MainWindow.m_CurrentMachine.sCurrSawing = m_PrecSawing
|
m_MainWindow.m_CurrentMachine.sCurrSawing = m_PrecSawing
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreateSingleCut() As Boolean
|
Private Function CreateSingleCut() As Boolean
|
||||||
|
|||||||
@@ -69,12 +69,12 @@
|
|||||||
|
|
||||||
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="5"
|
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="5"
|
||||||
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="5" Margin="0,0,6,0"
|
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="5" Margin="0,0,6,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="OffsetTxBl" Grid.Column="0" Grid.Row="6"
|
<TextBlock Name="OffsetTxBl" Grid.Column="0" Grid.Row="6"
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
Imports EgtUILib
|
Imports System.Windows.Threading
|
||||||
|
Imports EgtUILib
|
||||||
|
|
||||||
Public Class SingleCutUC
|
Public Class SingleCutUC
|
||||||
|
|
||||||
@@ -43,6 +44,10 @@ Public Class SingleCutUC
|
|||||||
Private Const MIN_CUT_LEN As Double = 10.0
|
Private Const MIN_CUT_LEN As Double = 10.0
|
||||||
Private Const MAX_SIDE_ANG As Double = 60.0
|
Private Const MAX_SIDE_ANG As Double = 60.0
|
||||||
' Costanti che indicano la modalità di acquisizione dei punti
|
' Costanti che indicano la modalità di acquisizione dei punti
|
||||||
|
|
||||||
|
' Utilizzato per aggiornare la posizione della macchina
|
||||||
|
Private m_RefreshTimer As New DispatcherTimer
|
||||||
|
|
||||||
Private Enum PT_MODE As Integer
|
Private Enum PT_MODE As Integer
|
||||||
SAW = 0
|
SAW = 0
|
||||||
LASER = 1
|
LASER = 1
|
||||||
@@ -92,6 +97,10 @@ Public Class SingleCutUC
|
|||||||
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = True
|
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = True
|
||||||
EgtSetMachineLook(m_MainWindow.m_DirectCutPageUC.m_nMachLook)
|
EgtSetMachineLook(m_MainWindow.m_DirectCutPageUC.m_nMachLook)
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
' riavvio il timer per visualizzare la poszione della macchina
|
||||||
|
If Not IsNothing(m_RefreshTimer) Then
|
||||||
|
m_RefreshTimer.Start()
|
||||||
|
End If
|
||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
' Disabilito registrazione progetto modificato
|
' Disabilito registrazione progetto modificato
|
||||||
@@ -138,10 +147,29 @@ Public Class SingleCutUC
|
|||||||
' Deseleziono bottone primo punto
|
' Deseleziono bottone primo punto
|
||||||
Point1Btn.IsChecked = False
|
Point1Btn.IsChecked = False
|
||||||
|
|
||||||
' la visualizzazione dei comandi è gestira dalla DirectCutPageUC richiamando la funzione ReloadParam
|
' la visualizzazione dei comandi è gestita dalla DirectCutPageUC richiamando la funzione ReloadParam
|
||||||
|
|
||||||
|
' forzo la macchina ad essere visibile fin da subito
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = True
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_nMachLook = MCH_LOOK.TAB
|
||||||
|
' Creo il timer il timer per aggiornare il posizionamento della macchina
|
||||||
|
AddHandler m_RefreshTimer.Tick, AddressOf RefreshTimer_tick
|
||||||
|
m_RefreshTimer.Interval = TimeSpan.FromMilliseconds(1000)
|
||||||
|
|
||||||
' Aggiorno visualizzazione
|
' Aggiorno visualizzazione
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
|
||||||
|
' Avvi il timer
|
||||||
|
m_RefreshTimer.Start()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub RefreshTimer_tick()
|
||||||
|
' se è impostata la visualizzazione della sola tavola allora non aggiorno il disegno
|
||||||
|
If m_MainWindow.m_DirectCutPageUC.m_nMachLook = MCH_LOOK.TAB Then Return
|
||||||
|
' Aggiorno visualizzazione
|
||||||
|
SetMachineInCurrPos()
|
||||||
|
' Aggiorno il disegno
|
||||||
|
EgtDraw()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Sub SingleCut_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
Friend Sub SingleCut_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
||||||
@@ -157,7 +185,7 @@ Public Class SingleCutUC
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -171,6 +199,8 @@ Public Class SingleCutUC
|
|||||||
EgtSetMachineLook(MCH_LOOK.TAB)
|
EgtSetMachineLook(MCH_LOOK.TAB)
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
End If
|
End If
|
||||||
|
' interrompo il Timer per aggiornare la visualizzazione del posizionamento macchina
|
||||||
|
m_RefreshTimer.Stop()
|
||||||
' Dichiaro pagina non attiva
|
' Dichiaro pagina non attiva
|
||||||
m_bActive = False
|
m_bActive = False
|
||||||
End Sub
|
End Sub
|
||||||
@@ -298,6 +328,7 @@ Public Class SingleCutUC
|
|||||||
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = True
|
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = True
|
||||||
EgtSetMachineLook(m_MainWindow.m_DirectCutPageUC.m_nMachLook)
|
EgtSetMachineLook(m_MainWindow.m_DirectCutPageUC.m_nMachLook)
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
|
||||||
' Seleziono il bottone per indicare che il primo punto è stato acquisito
|
' Seleziono il bottone per indicare che il primo punto è stato acquisito
|
||||||
Point1Btn.IsChecked = True
|
Point1Btn.IsChecked = True
|
||||||
' Abilito e deseleziono secondo punto
|
' Abilito e deseleziono secondo punto
|
||||||
@@ -524,6 +555,7 @@ Public Class SingleCutUC
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -564,7 +596,7 @@ Public Class SingleCutUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreateSingleCut() As Boolean
|
Private Function CreateSingleCut() As Boolean
|
||||||
@@ -582,7 +614,7 @@ Public Class SingleCutUC
|
|||||||
Dim sSawing As String = m_MainWindow.m_CurrentMachine.sCurrSawing
|
Dim sSawing As String = m_MainWindow.m_CurrentMachine.sCurrSawing
|
||||||
EgtTdbSetCurrTool(sSaw)
|
EgtTdbSetCurrTool(sSaw)
|
||||||
Dim dThick As Double = 0
|
Dim dThick As Double = 0
|
||||||
' se è impostata una lavorazione di lama
|
' Se è impostata una lavorazione di lama
|
||||||
If Not String.IsNullOrEmpty(sSawing) Then
|
If Not String.IsNullOrEmpty(sSawing) Then
|
||||||
EgtTdbGetCurrToolParam(MCH_TP.THICK, dThick)
|
EgtTdbGetCurrToolParam(MCH_TP.THICK, dThick)
|
||||||
End If
|
End If
|
||||||
@@ -598,14 +630,19 @@ Public Class SingleCutUC
|
|||||||
Dim ptStart As Point3d = m_ptTipP1
|
Dim ptStart As Point3d = m_ptTipP1
|
||||||
ptStart.z = 0
|
ptStart.z = 0
|
||||||
Dim nCutId = EgtCreateLinePDL(nLayerId, ptStart, m_dAngO, m_dLen)
|
Dim nCutId = EgtCreateLinePDL(nLayerId, ptStart, m_dAngO, m_dLen)
|
||||||
If Math.Abs(m_dOffset) > 10 * EPS_SMALL Then
|
' Applico la correzione di spessore lama -> anche se Offset=0! ver_2.5b1
|
||||||
Dim dTotOffset = m_dOffset
|
Dim dTotOffset = m_dOffset
|
||||||
If m_bSawTh Then dTotOffset += If( m_dOffset > 0, dThick, -dThick)
|
If m_bSawTh Then
|
||||||
|
dTotOffset += If(m_dOffset > 0, dThick, -dThick)
|
||||||
|
EgtOffsetCurve(nCutId, dTotOffset, OFF_TYPE.EXTEND)
|
||||||
|
Else
|
||||||
EgtOffsetCurve(nCutId, dTotOffset, OFF_TYPE.EXTEND)
|
EgtOffsetCurve(nCutId, dTotOffset, OFF_TYPE.EXTEND)
|
||||||
End If
|
End If
|
||||||
' Imposto affondamento e angolo di fianco sul taglio
|
' Imposto affondamento e angolo di fianco sul taglio
|
||||||
EgtSetInfo(nCutId, INFO_DEPTH, m_dDepth)
|
EgtSetInfo(nCutId, INFO_DEPTH, m_dDepth)
|
||||||
EgtSetInfo(nCutId, INFO_SIDE_ANGLE, m_dAngV)
|
EgtSetInfo(nCutId, INFO_SIDE_ANGLE, m_dAngV)
|
||||||
|
' Imposto se disabilitare l'inversine di direzione del taglio
|
||||||
|
If Not m_MainWindow.m_CurrentMachine.bEnableInvert Then EgtSetInfo(nCutId, INFO_ENABLE_INVERT, 0)
|
||||||
' Creo layer per crocetta di riferimento
|
' Creo layer per crocetta di riferimento
|
||||||
Dim nCrossLayerId = EgtCreateGroup(nPartId)
|
Dim nCrossLayerId = EgtCreateGroup(nPartId)
|
||||||
' Aggiungo crocetta/e
|
' Aggiungo crocetta/e
|
||||||
|
|||||||
@@ -136,7 +136,7 @@ Public Class SingleDrillUC
|
|||||||
' Se non vado in simulazione
|
' Se non vado in simulazione
|
||||||
If Not m_bSimul Then
|
If Not m_bSimul Then
|
||||||
' Dichiaro sottopagina da non riattivare
|
' Dichiaro sottopagina da non riattivare
|
||||||
m_MainWindow.m_DirectCutPageUC.m_ActiveDirectCutPage = DirectCutPageUC.DirectCutPages.DirectCut
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
' Rimuovo layer temporaneo per crocette
|
' Rimuovo layer temporaneo per crocette
|
||||||
EgtErase(m_nTempLay)
|
EgtErase(m_nTempLay)
|
||||||
' Rimuovo eventuale pezzo per taglio diretto
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
@@ -342,6 +342,7 @@ Public Class SingleDrillUC
|
|||||||
m_bSimul = True
|
m_bSimul = True
|
||||||
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
@@ -382,7 +383,7 @@ Public Class SingleDrillUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
m_MainWindow.m_DirectCutPageUC.LeftButtonGrid.Children.Remove(Me)
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function CreateSingleDrill() As Boolean
|
Private Function CreateSingleDrill() As Boolean
|
||||||
|
|||||||
@@ -0,0 +1,162 @@
|
|||||||
|
<UserControl x:Class="SquaringUC"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:EgtWPFLib="clr-namespace:EgtWPFLib;assembly=EgtWPFLib"
|
||||||
|
mc:Ignorable="d"
|
||||||
|
d:DesignHeight="597.3" d:DesignWidth="256">
|
||||||
|
|
||||||
|
<!--<Border CornerRadius="{StaticResource Page_CornerRadius}" Background="{StaticResource OmagCut_LightGray}">-->
|
||||||
|
<Border Style="{DynamicResource OmagCut_DirectCutPageBorder}">
|
||||||
|
|
||||||
|
<!-- Definizione della Grid MultipleCut -->
|
||||||
|
<Grid Name="SingleCutGrid" >
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="2*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="2*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<!--<Grid Grid.Row="0" Grid.ColumnSpan="2">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<ToggleButton Name="Point1Btn" Grid.Column="0"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconToggleButton}">
|
||||||
|
<Image Source="{DynamicResource Acquisisci-P1Img}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</ToggleButton>
|
||||||
|
|
||||||
|
<ToggleButton Name="Point2Btn" Grid.Column="1"
|
||||||
|
Style="{DynamicResource OmagCut_YellowIconToggleButton}">
|
||||||
|
<Image Source="{DynamicResource Acquisisci-P2Img}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</ToggleButton>
|
||||||
|
</Grid>-->
|
||||||
|
|
||||||
|
<!--<ComboBox Name="PointModeCmBx" Grid.Row="1" Grid.ColumnSpan="2" Style="{StaticResource OmagCut_ComboBox}"
|
||||||
|
Margin="6,0,6,0">
|
||||||
|
<ComboBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<TextBlock Text="{Binding}" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</DataTemplate>
|
||||||
|
</ComboBox.ItemTemplate>
|
||||||
|
</ComboBox>-->
|
||||||
|
|
||||||
|
<!--<TextBlock Name="DepthTxBl" Grid.Column="0" Grid.Row="2"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="DepthTxBx" Grid.Column="1" Grid.Row="2" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>-->
|
||||||
|
|
||||||
|
<TextBlock Name="OffsetTxBl" Grid.Column="0" Grid.Row="3"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="OffsetTxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
|
<TextBlock Name="ExtraLenTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="ExtraLenTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
|
<!--<TextBlock Name="DirectionTxBl" Grid.Column="0" Grid.Row="3"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="DirectionTxBx" Grid.Column="1" Grid.Row="3" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
|
<TextBlock Name="SideAngleTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="1" Grid.Row="4" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>-->
|
||||||
|
|
||||||
|
<!--<Grid Grid.Row="5" Grid.ColumnSpan="2">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="1.5*"/>
|
||||||
|
<ColumnDefinition Width="2"/>
|
||||||
|
<ColumnDefinition Width="1.5*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<Border Grid.Column="1" Grid.Row="0" Grid.RowSpan="4" Background="Black" />
|
||||||
|
|
||||||
|
<TextBlock Name="NumPzXTxBl" Grid.Column="0" Grid.Row="0"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<TextBlock Name="DimPzXTxBl" Grid.Column="2" Grid.Row="0"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
|
||||||
|
<EgtWPFLib:EgtTextBox Name="NumPzXTxBx" Grid.Column="0" Grid.Row="1" Width="75"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="DimPzXTxBx" Grid.Column="2" Grid.Row="1" Width="75"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
|
<TextBlock Name="NumPzYTxBl" Grid.Column="0" Grid.Row="2"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<TextBlock Name="DimPzYTxBl" Grid.Column="2" Grid.Row="2"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
|
||||||
|
<EgtWPFLib:EgtTextBox Name="NumPzYTxBx" Grid.Column="0" Grid.Row="3" Width="75"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="DimPzYTxBx" Grid.Column="2" Grid.Row="3" Width="75"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<TextBlock Name="SideTxBl" Grid.Row="6" Grid.ColumnSpan="2"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"/>
|
||||||
|
<CheckBox Name="SideChBx" Grid.Row="6" Grid.ColumnSpan="2" Style="{StaticResource OmagCut_CheckBox_Single}"
|
||||||
|
HorizontalAlignment="Right" Margin="0,0,6,0"/>-->
|
||||||
|
|
||||||
|
<Grid Grid.Row="7" Grid.ColumnSpan="2">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<TextBlock Name="XcoordTxBl" Grid.Column="0" Text="X"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="XcoordTxBx" Grid.Column="1" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
<TextBlock Name="YcoordTxBl" Grid.Column="2" Text="Y"
|
||||||
|
Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}" HorizontalAlignment="Center"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="YcoordTxBx" Grid.Column="3" Margin="0,0,6,0"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<Grid Grid.Row="11" Grid.ColumnSpan="2">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Button Name="SimulBtn" Grid.Column="0" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Image Source="{DynamicResource SimulaImg}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
<Button Name="OkBtn" Grid.Column="1" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Image Source="{DynamicResource EseguiImg}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
<Button Name="ExitBtn" Grid.Column="2" Style="{DynamicResource OmagCut_YellowIconButton}">
|
||||||
|
<Image Source="{DynamicResource XImg}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Border>
|
||||||
|
</UserControl>
|
||||||
@@ -0,0 +1,442 @@
|
|||||||
|
Imports EgtUILib
|
||||||
|
|
||||||
|
Public Class SquaringUC
|
||||||
|
|
||||||
|
' Riferimenti a pagine
|
||||||
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
|
Private WithEvents m_CurrProjPage As CurrentProjectPageUC
|
||||||
|
' Flag di pagina attiva
|
||||||
|
Private m_bActive As Boolean = False
|
||||||
|
' Flag di simulazione in corso
|
||||||
|
Private m_bSimul As Boolean = False
|
||||||
|
|
||||||
|
' Origine tavola e dati grezzo
|
||||||
|
Private m_bRawOk As Boolean = False
|
||||||
|
Private m_ptTabOri As Point3d
|
||||||
|
Private m_ptRawMin As Point3d
|
||||||
|
Private m_ptRawMax As Point3d
|
||||||
|
' Parametri P1 acquisito
|
||||||
|
Private m_ptTipP1 As Point3d
|
||||||
|
Private m_vtToolP1 As Vector3d
|
||||||
|
' Parametri P2 acquisito
|
||||||
|
Private m_ptTipP2 As Point3d
|
||||||
|
Private m_vtToolP2 As Vector3d
|
||||||
|
' Parametri della lavorazione
|
||||||
|
Private m_bCutOk As Boolean = False
|
||||||
|
Private m_dDepth As Double = 0
|
||||||
|
Private m_dOffsetSquaring As Double = 150
|
||||||
|
Private m_dExtraLength As Double = 0
|
||||||
|
Private m_dAngO As Double = 180
|
||||||
|
Private m_dAngV As Double = 0
|
||||||
|
Private m_nNumX As Integer = 0
|
||||||
|
Private m_dDimX As Double = 0
|
||||||
|
Private m_nNumY As Integer = 0
|
||||||
|
Private m_dDimY As Double = 0
|
||||||
|
Private m_bHeadSide As Boolean = False
|
||||||
|
|
||||||
|
' Punto selezionato nel disegno
|
||||||
|
Private m_ptPrev As Point3d
|
||||||
|
' Layer per crocette temporanee
|
||||||
|
Private m_nTempLay As Integer = GDB_ID.NULL
|
||||||
|
|
||||||
|
' Costanti
|
||||||
|
Private Const MAX_TAB_DEPTH As Double = 10.0
|
||||||
|
Private Const MIN_CUT_LEN As Double = 10.0
|
||||||
|
Private Const MAX_SIDE_ANG As Double = 60.0
|
||||||
|
|
||||||
|
'Costante che indica il lato in cui posizionare i tagli
|
||||||
|
Private Enum CutSide As Integer
|
||||||
|
Left
|
||||||
|
Right
|
||||||
|
End Enum
|
||||||
|
|
||||||
|
Private Sub GridCut_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
|
OffsetTxBl.Text = EgtMsg(MSG_DIRECTCUTPAGEUC + 28)
|
||||||
|
' 90260=Extra length
|
||||||
|
ExtraLenTxBl.Text = EgtMsg(90260)
|
||||||
|
SimulBtn.ToolTip = EgtMsg(MSG_CADCUTPAGEUC + 1)
|
||||||
|
OkBtn.ToolTip = EgtMsg(MSG_DIRECTCUTPAGEUC + 30)
|
||||||
|
|
||||||
|
' Carico i dati dell'ultimo taglio
|
||||||
|
m_dOffsetSquaring = GetPrivateProfileDouble(S_DIRECTCUTS, K_DC_OFFSET_SQUARING, m_dOffsetSquaring, m_MainWindow.GetIniFile())
|
||||||
|
m_dExtraLength = GetPrivateProfileDouble(S_DIRECTCUTS, K_DC_EXTRA_LEN_SQUARING, m_dExtraLength, m_MainWindow.GetIniFile())
|
||||||
|
m_dDepth = 0
|
||||||
|
m_dAngO = 90
|
||||||
|
m_dAngV = GetPrivateProfileDouble(S_DIRECTCUTS, K_DC_GRID_ANGV, m_dAngV, m_MainWindow.GetIniFile())
|
||||||
|
m_nNumX = 1
|
||||||
|
m_dDimX = GetPrivateProfileDouble(S_DIRECTCUTS, K_DC_GRID_DIMX, m_dDimX, m_MainWindow.GetIniFile())
|
||||||
|
m_nNumY = 1
|
||||||
|
m_dDimY = GetPrivateProfileDouble(S_DIRECTCUTS, K_DC_GRID_DIMY, m_dDimY, m_MainWindow.GetIniFile())
|
||||||
|
m_bHeadSide = False
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub Squaring_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
|
' Attivo la pagina
|
||||||
|
m_CurrProjPage = m_MainWindow.m_CurrentProjectPageUC
|
||||||
|
m_bActive = True
|
||||||
|
' Se rientro da simulazione
|
||||||
|
If m_bSimul Then
|
||||||
|
m_bSimul = False
|
||||||
|
' Disabilito registrazione progetto modificato
|
||||||
|
EgtDisableModified()
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = False
|
||||||
|
EgtSetMachineLook(MCH_LOOK.TAB)
|
||||||
|
EgtDraw()
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' Disabilito registrazione progetto modificato
|
||||||
|
EgtDisableModified()
|
||||||
|
' Creo layer temporaneo per crocette
|
||||||
|
m_nTempLay = EgtCreateGroup(GDB_ID.ROOT)
|
||||||
|
EgtSetLevel(m_nTempLay, GDB_LV.TEMP)
|
||||||
|
' Origine tavola
|
||||||
|
m_bRawOk = True
|
||||||
|
If Not EgtGetTableRef(1, m_ptTabOri) Then
|
||||||
|
m_bRawOk = False
|
||||||
|
EgtOutLog("Error on TableRef1")
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Dati del grezzo
|
||||||
|
If Not GetRawBox(m_ptRawMin, m_ptRawMax) Then
|
||||||
|
m_bRawOk = False
|
||||||
|
EgtOutLog("Error on RawBox")
|
||||||
|
End If
|
||||||
|
' calcolo lalavorazione di squadratura
|
||||||
|
RefreshSquaring()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub RefreshSquaring()
|
||||||
|
If Not m_bRawOk Then Return
|
||||||
|
|
||||||
|
Dim m_ThickSaw As Double
|
||||||
|
EgtTdbGetCurrToolParam(MCH_TP.THICK, m_ThickSaw)
|
||||||
|
|
||||||
|
m_dDepth = CamAuto.GetRawHeight()
|
||||||
|
m_dDimX = Math.Abs(m_ptRawMax.x - m_ptRawMin.x) - 2 * (m_dOffsetSquaring)
|
||||||
|
m_dDimY = Math.Abs(m_ptRawMax.y - m_ptRawMin.y) - 2 * (m_dOffsetSquaring)
|
||||||
|
|
||||||
|
Dim ptStart As New Point3d(m_ptRawMin.x + m_dOffsetSquaring - m_ThickSaw, m_ptRawMin.y + m_dOffsetSquaring, m_ptRawMin.z)
|
||||||
|
Dim ptEnd As New Point3d(ptStart.x + m_dDimX, ptStart.y, m_ptRawMin.z)
|
||||||
|
|
||||||
|
SetCoordVisibility(True)
|
||||||
|
ShowCoord()
|
||||||
|
|
||||||
|
OffsetTxBx.Text = LenToString(m_dOffsetSquaring, 1)
|
||||||
|
ExtraLenTxBx.Text = LenToString(m_dExtraLength, 1)
|
||||||
|
m_bCutOk = False
|
||||||
|
UpdateSimulOkBtn()
|
||||||
|
|
||||||
|
SquaringPoint(ptStart, ptEnd)
|
||||||
|
m_ptPrev = ptStart
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Friend Sub Squaring_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
||||||
|
' Salvo i dati correnti
|
||||||
|
' Salvo i dati correnti
|
||||||
|
WritePrivateProfileString(S_DIRECTCUTS, K_DC_OFFSET_SQUARING, DoubleToString(m_dOffsetSquaring, 2), m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_DIRECTCUTS, K_DC_EXTRA_LEN_SQUARING, DoubleToString(m_dExtraLength, 2), m_MainWindow.GetIniFile())
|
||||||
|
' Se non vado in simulazione
|
||||||
|
If Not m_bSimul Then
|
||||||
|
' Dichiaro sottopagina da non riattivare
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage = ControlsDirectCutUC.DirectCutPages.DirectCut
|
||||||
|
' Rimuovo layer temporaneo per crocette
|
||||||
|
EgtErase(m_nTempLay)
|
||||||
|
' Rimuovo eventuale pezzo per taglio diretto
|
||||||
|
EraseDirectCutPart()
|
||||||
|
' Riattivo eventuali lavorazioni presenti
|
||||||
|
ActivateAllMachinings()
|
||||||
|
' Abilito registrazione progetto modificato
|
||||||
|
EgtEnableModified()
|
||||||
|
' Nascondo la macchina
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = False
|
||||||
|
EgtSetMachineLook(MCH_LOOK.TAB)
|
||||||
|
EgtDraw()
|
||||||
|
End If
|
||||||
|
' Dichiaro pagina non attiva
|
||||||
|
m_bActive = False
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub UpdateSimulOkBtn()
|
||||||
|
If m_bCutOk Then
|
||||||
|
SimulBtn.IsEnabled = True
|
||||||
|
SimulBtn.Foreground = Brushes.Black
|
||||||
|
OkBtn.IsEnabled = True
|
||||||
|
OkBtn.Foreground = Brushes.Black
|
||||||
|
Else
|
||||||
|
SimulBtn.IsEnabled = False
|
||||||
|
SimulBtn.Foreground = Brushes.DarkGray
|
||||||
|
OkBtn.IsEnabled = False
|
||||||
|
OkBtn.Foreground = Brushes.DarkGray
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SquaringPoint(ptMin As Point3d, ptMax As Point3d)
|
||||||
|
' Rimuovo eventuali crocette create acquisendo i punti nel disegno
|
||||||
|
EgtEmptyGroup(m_nTempLay)
|
||||||
|
' Verifico configurazione tavola e grezzo
|
||||||
|
If Not m_bRawOk Then Return
|
||||||
|
|
||||||
|
' Recupero dati utensile e testa corrente
|
||||||
|
Dim sTool As String = ""
|
||||||
|
Dim sHead As String = ""
|
||||||
|
Dim nExit As Integer = 0
|
||||||
|
EgtGetCalcTool(sTool, sHead, nExit)
|
||||||
|
'------------- BOTTOM LEFT -------------------
|
||||||
|
' Assegno punto selezionato nel disegno a m_ptTipP1
|
||||||
|
m_ptTipP1 = ptMin
|
||||||
|
' Porto il tip nell'origine tavola
|
||||||
|
m_ptTipP1.ToLoc(New Frame3d(m_ptTabOri))
|
||||||
|
' Reimposto eventuale precedente utensile
|
||||||
|
EgtSetCalcTool(sTool, sHead, nExit)
|
||||||
|
'------------- TOP RIGHT -------------------
|
||||||
|
' Assegno punto selezionato nel disegno a m_ptTipP2
|
||||||
|
m_ptTipP2 = ptMax
|
||||||
|
' Porto il tip nell'origine tavola
|
||||||
|
m_ptTipP2.ToLoc(New Frame3d(m_ptTabOri))
|
||||||
|
' Reimposto eventuale precedente utensile
|
||||||
|
EgtSetCalcTool(sTool, sHead, nExit)
|
||||||
|
|
||||||
|
' Se il secondo punto non coincide con il primo, disegno il taglio
|
||||||
|
Dim vtDiff As Vector3d = m_ptTipP2 - m_ptTipP1
|
||||||
|
vtDiff.z = 0
|
||||||
|
Dim dLen As Double
|
||||||
|
Dim dAngVertDeg As Double
|
||||||
|
Dim dAngOrizzDeg As Double
|
||||||
|
vtDiff.ToSpherical(dLen, dAngVertDeg, dAngOrizzDeg)
|
||||||
|
If dLen > EPS_SMALL Then
|
||||||
|
m_dAngO = dAngOrizzDeg
|
||||||
|
CreateGridCut()
|
||||||
|
' visuliazzo tavola
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_bShowMachine = False
|
||||||
|
EgtSetMachineLook(MCH_LOOK.TAB)
|
||||||
|
EgtDraw()
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub OffsetTxBx_EgtClosed(sender As Object, e As EventArgs) Handles OffsetTxBx.EgtClosed
|
||||||
|
' Verifico che l'offset impostato non sia superiore a quello massimo
|
||||||
|
Dim dMaxOffset As Double = Math.Min(m_dDimX, m_dDimY) / 2 - 15
|
||||||
|
Dim dOffset As Double = 0
|
||||||
|
StringToLen(OffsetTxBx.Text, dOffset)
|
||||||
|
If dOffset < 0 Then
|
||||||
|
dOffset = 0
|
||||||
|
ElseIf dOffset > dMaxOffset Then
|
||||||
|
dOffset = dMaxOffset
|
||||||
|
End If
|
||||||
|
m_dOffsetSquaring = dOffset
|
||||||
|
OffsetTxBx.Text = LenToString(m_dOffsetSquaring, 2)
|
||||||
|
' Disegno il taglio
|
||||||
|
RefreshSquaring()
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ExtraLength_EgtClosed(sender As Object, e As EventArgs) Handles ExtraLenTxBx.EgtClosed
|
||||||
|
' Verifico che il valore indicato sia almeno maggiore dell'offset indicato
|
||||||
|
Dim dOffset As Double = 0
|
||||||
|
StringToLen(OffsetTxBx.Text, dOffset)
|
||||||
|
Dim MadExtraLeng As Double = Math.Abs(dOffset)
|
||||||
|
Dim dExtraLen As Double
|
||||||
|
StringToLen(ExtraLenTxBx.Text, dExtraLen)
|
||||||
|
If dExtraLen < 0 AndAlso dExtraLen < -MadExtraLeng Then
|
||||||
|
dExtraLen = 0
|
||||||
|
End If
|
||||||
|
m_dExtraLength = dExtraLen
|
||||||
|
ExtraLenTxBx.Text = LenToString(m_dExtraLength, 2)
|
||||||
|
' Disegno il taglio
|
||||||
|
RefreshSquaring()
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SimulBtn_Click(sender As Object, e As RoutedEventArgs) Handles SimulBtn.Click
|
||||||
|
' Verifico ci sia un taglio valido
|
||||||
|
If Not m_bCutOk Then Return
|
||||||
|
' Salvo il progetto con le lavorazioni
|
||||||
|
EgtSetCurrentContext(m_CurrProjPage.CurrentProjectScene.GetCtx())
|
||||||
|
Dim sMchPath As String = m_MainWindow.GetTempDir() & "\" & "DirectProj.nge"
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.SaveFile(sMchPath, False)
|
||||||
|
' Predispongo passaggio a simulazione
|
||||||
|
m_bSimul = True
|
||||||
|
m_CurrProjPage.m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
|
m_CurrProjPage.CurrProjGrid.Visibility = Windows.Visibility.Hidden
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Remove(m_MainWindow.m_DirectCutPageUC)
|
||||||
|
m_MainWindow.m_PrevActivePage = MainWindow.Pages.DirectCut
|
||||||
|
m_CurrProjPage.CurrentProjectPageGrid.Children.Add(m_MainWindow.m_SimulationPage)
|
||||||
|
m_MainWindow.m_ActivePage = MainWindow.Pages.Simulation
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub OkBtn_Click(sender As Object, e As RoutedEventArgs) Handles OkBtn.Click
|
||||||
|
#If TRIAL Then
|
||||||
|
m_CurrProjPage.SetWarningMessage("Trial Version")
|
||||||
|
#Else
|
||||||
|
' Verifico non sia versione Ufficio
|
||||||
|
If m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.OFFICE_TYPE) Then
|
||||||
|
m_CurrProjPage.SetWarningMessage("Office Version")
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' Verifico ci sia un taglio valido
|
||||||
|
If Not m_bCutOk Then Return
|
||||||
|
' Salvo il progetto con le lavorazioni
|
||||||
|
Dim sMchPath As String = m_MainWindow.GetTempDir() & "\" & "DirectProj.nge"
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.SaveFile(sMchPath, False)
|
||||||
|
' Genero file CNC (lancio anche se errore in precedenza)
|
||||||
|
Dim sCncPath As String = m_MainWindow.GetCncDir() & "\DirectCut" & m_MainWindow.m_CurrentMachine.sIsoFileExt
|
||||||
|
Dim bOk As Boolean = EgtGenerate(sCncPath, "OmagCut ver." & m_MainWindow.GetVersion())
|
||||||
|
' Se errore in generazione, segnalo l'errore ed esco
|
||||||
|
If Not bOk Then
|
||||||
|
m_CurrProjPage.SetErrorMessage(EgtMsg(90314)) 'Errore nella generazione del programma CN
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' Download programma (eventuali errori sono segnalati dalla funzione)
|
||||||
|
If m_MainWindow.m_CNCommunication.SendProgram(sCncPath, 900) Then
|
||||||
|
' copio il progetto corrente come progetto in lavorazione
|
||||||
|
Dim sWrkPath As String = m_MainWindow.GetTempDir() & "\" & "WorkProj.nge"
|
||||||
|
My.Computer.FileSystem.CopyFile(sMchPath, sWrkPath, True)
|
||||||
|
' lancio eventuale lua post-trasmissione
|
||||||
|
m_MainWindow.ExecSentProgScript(True)
|
||||||
|
End If
|
||||||
|
#End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ExitBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExitBtn.Click
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsDirectCutUC.LeftButtonGrid.Children.Remove(Me)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Function CreateGridCut() As Boolean
|
||||||
|
' Verifico sia definito il punto iniziale e il grezzo
|
||||||
|
If Not m_bRawOk Then
|
||||||
|
m_bCutOk = False
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
' Spessore grezzo
|
||||||
|
Dim dRawHeight As Double = m_ptRawMax.z - m_ptRawMin.z
|
||||||
|
' Rimuovo eventuale vecchio pezzo per taglio diretto
|
||||||
|
EraseDirectCutPart()
|
||||||
|
' Disattivo eventuali lavorazioni presenti
|
||||||
|
DeactivateAllMachinings()
|
||||||
|
' Creo nuovo pezzo per il taglio diretto
|
||||||
|
Dim nPartId = EgtCreateGroup(GDB_ID.ROOT)
|
||||||
|
EgtSetName(nPartId, NAME_DIRECTCUT)
|
||||||
|
Dim nLayerId = EgtCreateGroup(nPartId)
|
||||||
|
EgtSetName(nLayerId, NAME_OUTLOOP)
|
||||||
|
' Creo il taglio parallelo alla lama
|
||||||
|
Dim ptStart As Point3d = m_ptTipP1
|
||||||
|
ptStart.z = 0
|
||||||
|
' Funzione che crea i tagli successivi al primo
|
||||||
|
MultiplyCut(nLayerId)
|
||||||
|
' Calcolo punto di inserimento nel grezzo
|
||||||
|
Dim ptMin, ptMax As Point3d
|
||||||
|
EgtGetBBoxGlob(nPartId, GDB_BB.STANDARD, ptMin, ptMax)
|
||||||
|
Dim ptIns As Point3d = ptMin + (m_ptTabOri - m_ptRawMin)
|
||||||
|
ptIns.z = dRawHeight
|
||||||
|
' Inserisco il pezzo nel grezzo
|
||||||
|
EgtAddPartToRawPart(nPartId, ptIns, m_MainWindow.m_CurrentProjectPageUC.m_nRawId)
|
||||||
|
' Inserisco la lavorazione
|
||||||
|
m_bCutOk = AddMachinings(nPartId) AndAlso UpdateAllMachiningsToolpaths()
|
||||||
|
EgtSetCurrPhase(1)
|
||||||
|
' Eventuale eliminazione Home finale
|
||||||
|
If Not m_MainWindow.m_CurrentMachine.bDirectCutsFinalHome Then
|
||||||
|
RemoveFinalHome()
|
||||||
|
End If
|
||||||
|
UpdateSimulOkBtn()
|
||||||
|
Return m_bCutOk
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Private Function MultiplyCut(nLayerId As Integer) As Boolean
|
||||||
|
' Recupero lo spessore del taglio della lama o del waterjet correntemente attiva
|
||||||
|
Dim nType As Integer = 0
|
||||||
|
EgtTdbGetCurrToolParam(MCH_TP.TYPE, nType)
|
||||||
|
Dim dThick As Double = 0
|
||||||
|
EgtTdbGetCurrToolParam(If(nType = MCH_TY.SAW_STD, MCH_TP.THICK, MCH_TP.DIAM), dThick)
|
||||||
|
' Ricalcolo lo spessore in base all'inclinazione
|
||||||
|
dThick = dThick / Math.Cos(m_dAngV * Math.PI / 180)
|
||||||
|
' Imposto angolo di rotazione a seconda del lato dei tagli paralleli
|
||||||
|
Dim dRotAngOX As Double = 90
|
||||||
|
' Recupero dati da interfaccia
|
||||||
|
Dim dDimPzX As Double = m_dDimX
|
||||||
|
Dim nNumPzX As Integer = m_nNumX
|
||||||
|
Dim dDimPzY As Double = m_dDimY
|
||||||
|
Dim nNumPzY As Integer = m_nNumY
|
||||||
|
' Definisco vettore di spostamento
|
||||||
|
Dim vtDelta As Vector3d
|
||||||
|
' Calcolo primo taglio parallelo
|
||||||
|
Dim ptStart As Point3d = m_ptTipP1
|
||||||
|
ptStart.z = 0
|
||||||
|
If dDimPzY <> 0 And nNumPzY > 0 And dDimPzX <> 0 And nNumPzX > 0 Then
|
||||||
|
Dim dLenX As Double = dThick + (dDimPzX + dThick) * nNumPzX
|
||||||
|
Dim nCutParaId = EgtCreateLinePDL(nLayerId, ptStart, m_dAngO, dLenX + 0.1)
|
||||||
|
' Imposto affondamento e angolo di fianco sul taglio
|
||||||
|
EgtSetInfo(nCutParaId, INFO_DEPTH, m_dDepth)
|
||||||
|
EgtSetInfo(nCutParaId, INFO_SIDE_ANGLE, m_dAngV)
|
||||||
|
' Allungo la geometria
|
||||||
|
EgtExtendCurveStartByLen(nCutParaId, m_dOffsetSquaring + m_dExtraLength)
|
||||||
|
EgtExtendCurveEndByLen(nCutParaId, m_dOffsetSquaring + +m_dExtraLength)
|
||||||
|
' Calcolo vettore di spostamento
|
||||||
|
vtDelta = Vector3d.FromPolar((dDimPzY + dThick), m_dAngO)
|
||||||
|
' Ruoto il vettore di traslazione
|
||||||
|
vtDelta.Rotate(Vector3d.Z_AX, dRotAngOX)
|
||||||
|
For Index As Integer = 1 To nNumPzY
|
||||||
|
Dim vtPerpMove As Vector3d = Index * vtDelta
|
||||||
|
' Creo copie
|
||||||
|
Dim nCut2Id = EgtCopyGlob(nCutParaId, nLayerId)
|
||||||
|
EgtMove(nCut2Id, vtPerpMove, GDB_RT.GLOB)
|
||||||
|
Next
|
||||||
|
' Calcolo primo taglio perpendicolare
|
||||||
|
Dim dLenY As Double = dThick + (dDimPzY + dThick) * nNumPzY
|
||||||
|
' Arretro il punto di partenza di uno spessore lama
|
||||||
|
Dim vtDeltaPos As Vector3d = Vector3d.FromPolar(dThick + 0.1, m_dAngO - 90)
|
||||||
|
Dim nCutPerpId = EgtCreateLinePDL(nLayerId, ptStart + vtDeltaPos, m_dAngO + 90, dLenY + 0.2)
|
||||||
|
' Imposto affondamento e angolo di fianco sul taglio
|
||||||
|
EgtSetInfo(nCutPerpId, INFO_DEPTH, m_dDepth)
|
||||||
|
EgtSetInfo(nCutPerpId, INFO_SIDE_ANGLE, m_dAngV)
|
||||||
|
' Allungo la geometria
|
||||||
|
EgtExtendCurveStartByLen(nCutPerpId, m_dOffsetSquaring + m_dExtraLength)
|
||||||
|
EgtExtendCurveEndByLen(nCutPerpId, m_dOffsetSquaring + +m_dExtraLength)
|
||||||
|
' Calcolo secondo vettore di spostamento
|
||||||
|
vtDelta = Vector3d.FromPolar((dDimPzX + dThick), m_dAngO)
|
||||||
|
For Index As Integer = 1 To nNumPzX
|
||||||
|
Dim vtPerpMove As Vector3d = vtDelta * Index
|
||||||
|
' Creo copie
|
||||||
|
Dim nCut3Id = EgtCopyGlob(nCutPerpId, nLayerId)
|
||||||
|
EgtMove(nCut3Id, vtPerpMove, GDB_RT.GLOB)
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Private Sub SetCoordVisibility(bShow As Boolean)
|
||||||
|
XcoordTxBl.Visibility = If(bShow, Windows.Visibility.Visible, Windows.Visibility.Hidden)
|
||||||
|
XcoordTxBx.Visibility = If(bShow, Windows.Visibility.Visible, Windows.Visibility.Hidden)
|
||||||
|
YcoordTxBl.Visibility = If(bShow, Windows.Visibility.Visible, Windows.Visibility.Hidden)
|
||||||
|
YcoordTxBx.Visibility = If(bShow, Windows.Visibility.Visible, Windows.Visibility.Hidden)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ShowCoord()
|
||||||
|
Dim ptText As Point3d = m_ptPrev
|
||||||
|
ptText.ToLoc(New Frame3d(m_ptTabOri))
|
||||||
|
XcoordTxBx.Text = LenToString(ptText.x, 2)
|
||||||
|
YcoordTxBx.Text = LenToString(ptText.y, 2)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Function SetMachineInCurrPos() As Boolean
|
||||||
|
' Recupero la posizione macchina
|
||||||
|
Dim dL1, dL2, dL3, dR1, dR2 As Double
|
||||||
|
If Not m_MainWindow.m_CNCommunication.GetAxesPositions(dL1, dL2, dL3, dR1, dR2) Then Return False
|
||||||
|
' Recupero il nome degli assi macchina
|
||||||
|
Dim sL1 As String = String.Empty
|
||||||
|
Dim sL2 As String = String.Empty
|
||||||
|
Dim sL3 As String = String.Empty
|
||||||
|
Dim sR1 As String = String.Empty
|
||||||
|
Dim sR2 As String = String.Empty
|
||||||
|
If Not m_MainWindow.m_CNCommunication.GetAxesNames(sL1, sL2, sL3, sR1, sR2) Then Return False
|
||||||
|
' Visualizzo macchina in posizione
|
||||||
|
EgtSetAxisPos(sL1, dL1)
|
||||||
|
EgtSetAxisPos(sL2, dL2)
|
||||||
|
EgtSetAxisPos(sL3, dL3)
|
||||||
|
EgtSetAxisPos(sR1, dR1)
|
||||||
|
EgtSetAxisPos(sR2, dR2)
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
End Class
|
||||||
|
|
||||||
@@ -199,12 +199,12 @@
|
|||||||
Visibility="Collapsed"
|
Visibility="Collapsed"
|
||||||
Grid.Column="2" Grid.Row="1"
|
Grid.Column="2" Grid.Row="1"
|
||||||
HorizontalAlignment="Right"
|
HorizontalAlignment="Right"
|
||||||
Width="60" Height="30" Margin="0,0,0,0"
|
Width="60" Height="30" Margin="0,0,0,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="Parameter2FTxBx"
|
<EgtWPFLib:EgtTextBox Name="Parameter2FTxBx"
|
||||||
Grid.Column="3" Grid.Row="1"
|
Grid.Column="3" Grid.Row="1"
|
||||||
HorizontalAlignment="Right"
|
HorizontalAlignment="Right"
|
||||||
Width="60" Height="30" Margin="0,0,0,0"
|
Width="60" Height="30" Margin="0,0,0,0" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<!-- Spessore aletta -->
|
<!-- Spessore aletta -->
|
||||||
|
|||||||
@@ -96,8 +96,14 @@ Public Class AlzFrontUC
|
|||||||
Dim LabelId As Integer = GDB_ID.NULL
|
Dim LabelId As Integer = GDB_ID.NULL
|
||||||
|
|
||||||
' definisco i valori delle altezza e degli angoli di spoglia per le alzatine e i frontalini (letti da file ini del programma)
|
' definisco i valori delle altezza e degli angoli di spoglia per le alzatine e i frontalini (letti da file ini del programma)
|
||||||
GetPrivateProfileString(S_ALZFRONT, K_ALZ_HEIGHT, "0", Parameter1ATxBx.Text, m_MainWindow.GetIniFile)
|
Dim sVal As String = String.Empty
|
||||||
GetPrivateProfileString(S_ALZFRONT, K_FRONT_HEIGHT, "0", Parameter1FTxBx.Text, m_MainWindow.GetIniFile)
|
Dim dVal As Double = 0
|
||||||
|
GetPrivateProfileString(S_ALZFRONT, K_ALZ_HEIGHT, "0", sVal, m_MainWindow.GetIniFile)
|
||||||
|
Utility.StringToDouble(sVal, dVal)
|
||||||
|
Parameter1ATxBx.Text = Utility.LenToString(dVal, 4)
|
||||||
|
GetPrivateProfileString(S_ALZFRONT, K_FRONT_HEIGHT, "0", sVal, m_MainWindow.GetIniFile)
|
||||||
|
Utility.StringToDouble(sVal, dVal)
|
||||||
|
Parameter1FTxBx.Text = Utility.LenToString(dVal, 4)
|
||||||
GetPrivateProfileString(S_ALZFRONT, K_ALZ_DELTA_ANG, "0", Parameter2ATxBx.Text, m_MainWindow.GetIniFile)
|
GetPrivateProfileString(S_ALZFRONT, K_ALZ_DELTA_ANG, "0", Parameter2ATxBx.Text, m_MainWindow.GetIniFile)
|
||||||
GetPrivateProfileString(S_ALZFRONT, K_FRONT_DELTA_ANG, "0", Parameter2FTxBx.Text, m_MainWindow.GetIniFile)
|
GetPrivateProfileString(S_ALZFRONT, K_FRONT_DELTA_ANG, "0", Parameter2FTxBx.Text, m_MainWindow.GetIniFile)
|
||||||
Parameter5TxBx.Text = Utility.LenToString(m_MainWindow.m_CurrentProjectPageUC.m_dRawHeight, 2)
|
Parameter5TxBx.Text = Utility.LenToString(m_MainWindow.m_CurrentProjectPageUC.m_dRawHeight, 2)
|
||||||
@@ -607,9 +613,9 @@ Public Class AlzFrontUC
|
|||||||
Private Sub ParameterA1TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter1ATxBx.EgtClosed
|
Private Sub ParameterA1TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter1ATxBx.EgtClosed
|
||||||
' Nuovo angolo di inclinazione
|
' Nuovo angolo di inclinazione
|
||||||
Dim dValue As Double
|
Dim dValue As Double
|
||||||
StringToDouble(Parameter1ATxBx.Text, dValue)
|
StringToLen(Parameter1ATxBx.Text, dValue)
|
||||||
' salvo il valore nel file ini e inserisco il valore nel file lua
|
' salvo il valore nel file ini e inserisco il valore nel file lua
|
||||||
WritePrivateProfileString("Alz&Front", "A_Height", Parameter1ATxBx.Text, m_MainWindow.GetIniFile())
|
WritePrivateProfileString("Alz&Front", "A_Height", DoubleToString(dValue, 3), m_MainWindow.GetIniFile())
|
||||||
' aggiorno il disegno
|
' aggiorno il disegno
|
||||||
LoadCurrentCompo()
|
LoadCurrentCompo()
|
||||||
End Sub
|
End Sub
|
||||||
@@ -618,9 +624,9 @@ Public Class AlzFrontUC
|
|||||||
Private Sub Parameter1FTxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter1FTxBx.EgtClosed
|
Private Sub Parameter1FTxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter1FTxBx.EgtClosed
|
||||||
' Nuovo angolo di inclinazione
|
' Nuovo angolo di inclinazione
|
||||||
Dim dValue As Double
|
Dim dValue As Double
|
||||||
StringToDouble(Parameter1FTxBx.Text, dValue)
|
StringToLen(Parameter1FTxBx.Text, dValue)
|
||||||
' salvo il valore nel file ini e inserisco il valore nel file lua
|
' salvo il valore nel file ini e inserisco il valore nel file lua
|
||||||
WritePrivateProfileString("Alz&Front", "F_Height", Parameter1FTxBx.Text, m_MainWindow.GetIniFile())
|
WritePrivateProfileString("Alz&Front", "F_Height", DoubleToString(dValue, 3), m_MainWindow.GetIniFile())
|
||||||
' aggiorno il disegno
|
' aggiorno il disegno
|
||||||
LoadCurrentCompo()
|
LoadCurrentCompo()
|
||||||
End Sub
|
End Sub
|
||||||
|
|||||||
@@ -75,6 +75,7 @@ Public Class CompoDimensionUC
|
|||||||
m_DrawPage.sCompoName.StartsWith("PBagno") Then
|
m_DrawPage.sCompoName.StartsWith("PBagno") Then
|
||||||
ShowInternalBtn(True)
|
ShowInternalBtn(True)
|
||||||
ShowAlzFrontBtn(bEnableAlzFront)
|
ShowAlzFrontBtn(bEnableAlzFront)
|
||||||
|
m_DrawPage.MessageGrid.Visibility = Visibility.Hidden
|
||||||
Else
|
Else
|
||||||
ShowInternalBtn(False)
|
ShowInternalBtn(False)
|
||||||
ShowAlzFrontBtn(False)
|
ShowAlzFrontBtn(False)
|
||||||
@@ -336,6 +337,7 @@ Public Class CompoDimensionUC
|
|||||||
Dim nCmpInfo As Integer = 0
|
Dim nCmpInfo As Integer = 0
|
||||||
If EgtGetInfo(nId, "ID", nCmpInfo) AndAlso nCmp = nCmpInfo Then
|
If EgtGetInfo(nId, "ID", nCmpInfo) AndAlso nCmp = nCmpInfo Then
|
||||||
EgtSetStatus(nId, GDB_ST.OFF)
|
EgtSetStatus(nId, GDB_ST.OFF)
|
||||||
|
UpdateInLoopReference(nCmp)
|
||||||
Exit While
|
Exit While
|
||||||
End If
|
End If
|
||||||
nId = EgtGetNextName(nId, "HoleLabels")
|
nId = EgtGetNextName(nId, "HoleLabels")
|
||||||
@@ -379,5 +381,42 @@ Public Class CompoDimensionUC
|
|||||||
EgtDraw()
|
EgtDraw()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub UpdateInLoopReference(nCmp As Integer)
|
||||||
|
' aggiorno il layer "FiloTop"
|
||||||
|
Dim nIdInLoop As Integer = EgtGetFirstNameInGroup(EgtGetFirstGroupInGroup(GDB_ID.ROOT), "InLoop")
|
||||||
|
While nIdInLoop <> GDB_ID.NULL
|
||||||
|
Dim nCmpInfoIL As Integer = 0
|
||||||
|
If EgtGetInfo(nIdInLoop, "ID", nCmpInfoIL) AndAlso nCmp = nCmpInfoIL Then
|
||||||
|
Dim nLayFiloTop As Integer = GDB_ID.NULL
|
||||||
|
EgtGetInfo(nIdInLoop, "FiloTopRef", nLayFiloTop)
|
||||||
|
If nLayFiloTop <> GDB_ID.NULL Then
|
||||||
|
Dim LocalList As New List(Of Integer) From {nIdInLoop}
|
||||||
|
m_DrawPage.m_FiloTopUC.CreateFiloTopPreView(LocalList)
|
||||||
|
EgtSetStatus(nLayFiloTop, GDB_ST.ON_)
|
||||||
|
Exit While
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
nIdInLoop = EgtGetNextName(nIdInLoop, "InLoop")
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' riceve la info "ID" della componente
|
||||||
|
Public Sub SetStatusVisibilityInLoopReference(nCmp As Integer, Status As GDB_ST)
|
||||||
|
' aggiorno il layer "FiloTop"
|
||||||
|
Dim nIdInLoop As Integer = EgtGetFirstNameInGroup(EgtGetFirstGroupInGroup(GDB_ID.ROOT), "InLoop")
|
||||||
|
While nIdInLoop <> GDB_ID.NULL
|
||||||
|
Dim nCmpInfoIL As Integer = 0
|
||||||
|
If EgtGetInfo(nIdInLoop, "ID", nCmpInfoIL) AndAlso nCmp = nCmpInfoIL Then
|
||||||
|
Dim nLayFiloTop As Integer = GDB_ID.NULL
|
||||||
|
EgtGetInfo(nIdInLoop, "FiloTopRef", nLayFiloTop)
|
||||||
|
If nLayFiloTop <> GDB_ID.NULL Then
|
||||||
|
EgtSetStatus(nLayFiloTop, Status)
|
||||||
|
Exit While
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
nIdInLoop = EgtGetNextName(nIdInLoop, "InLoop")
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
#End Region ' METHODS for InternalCompo
|
#End Region ' METHODS for InternalCompo
|
||||||
End Class
|
End Class
|
||||||
|
|||||||
@@ -24,6 +24,7 @@ Public Class CompoTrfData
|
|||||||
|
|
||||||
Private Sub OkBtn_Click(sender As Object, e As RoutedEventArgs) Handles OkBtn.Click
|
Private Sub OkBtn_Click(sender As Object, e As RoutedEventArgs) Handles OkBtn.Click
|
||||||
DialogResult = True
|
DialogResult = True
|
||||||
|
SaveData()
|
||||||
Close()
|
Close()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -32,7 +33,30 @@ Public Class CompoTrfData
|
|||||||
Close()
|
Close()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SaveData()
|
||||||
|
WritePrivateProfileString(S_TRF, K_ORDCODE, OrdCodeTxBx.Text, m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_TRF, K_ORDDESC, OrdDescTxBx.Text, m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_TRF, K_PARTCODE, PartCodeTxBx.Text, m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_TRF, K_MATCODE, MatCodeTxBx.Text, m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_TRF, K_SURFCODE, SurfCodeTxBx.Text, m_MainWindow.GetIniFile())
|
||||||
|
' prima di salvare lo spessore converto in mm e poi di nuovo in stringa
|
||||||
|
Dim dVal As Double = 0
|
||||||
|
StringToLen(ThicknessTxBx.Text, dVal)
|
||||||
|
WritePrivateProfileString(S_TRF, K_TRFTHICKNESS, DoubleToString(dVal, 4), m_MainWindow.GetIniFile())
|
||||||
|
End Sub
|
||||||
|
|
||||||
Friend Sub SetData(sOrdCode As String, sOrdDesc As String, sPartCode As String, sMatCode As String, sSurfCode As String, dTh As Double)
|
Friend Sub SetData(sOrdCode As String, sOrdDesc As String, sPartCode As String, sMatCode As String, sSurfCode As String, dTh As Double)
|
||||||
|
' se verifico che non sono stati iniziliazzti i campi allora provvedo a leggere il file ini del programma
|
||||||
|
If sOrdCode = "" And sOrdDesc = "" And sPartCode = "" And sMatCode = "" And sSurfCode = "" Then
|
||||||
|
GetPrivateProfileString(S_TRF, K_ORDCODE, sOrdCode, sOrdCode, m_MainWindow.GetIniFile())
|
||||||
|
GetPrivateProfileString(S_TRF, K_ORDDESC, sOrdDesc, sOrdDesc, m_MainWindow.GetIniFile())
|
||||||
|
GetPrivateProfileString(S_TRF, K_PARTCODE, sPartCode, sPartCode, m_MainWindow.GetIniFile())
|
||||||
|
GetPrivateProfileString(S_TRF, K_MATCODE, sMatCode, sMatCode, m_MainWindow.GetIniFile())
|
||||||
|
GetPrivateProfileString(S_TRF, K_SURFCODE, sSurfCode, sSurfCode, m_MainWindow.GetIniFile())
|
||||||
|
' recupero il dato dello spessore che deve essere in mm
|
||||||
|
dTh = GetPrivateProfileDouble(S_TRF, K_TRFTHICKNESS, dTh, m_MainWindow.GetIniFile())
|
||||||
|
End If
|
||||||
|
' inizializzo i campi della finestra
|
||||||
OrdCodeTxBx.Text = sOrdCode
|
OrdCodeTxBx.Text = sOrdCode
|
||||||
OrdDescTxBx.Text = sOrdDesc
|
OrdDescTxBx.Text = sOrdDesc
|
||||||
PartCodeTxBx.Text = sPartCode
|
PartCodeTxBx.Text = sPartCode
|
||||||
|
|||||||
@@ -64,7 +64,7 @@
|
|||||||
<ToggleButton Name="DimensionBtn" Grid.Column="0" Style="{DynamicResource OmagCut_YellowToggleButton}" Visibility="Collapsed"/>
|
<ToggleButton Name="DimensionBtn" Grid.Column="0" Style="{DynamicResource OmagCut_YellowToggleButton}" Visibility="Collapsed"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
<Grid Name="VariablesGrd" Grid.Row="1" Grid.ColumnSpan="2"/>
|
<Grid Name="VariablesGrd" Grid.Row="1" Grid.RowSpan="2" Grid.ColumnSpan="2"/>
|
||||||
|
|
||||||
<Grid Name="MessageGrid" Grid.Row="2" Grid.ColumnSpan="2">
|
<Grid Name="MessageGrid" Grid.Row="2" Grid.ColumnSpan="2">
|
||||||
<TextBlock Name="MessageTxBl" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="MessageTxBl" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
@@ -124,7 +124,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="PartNumTxBl" Grid.Column="0" Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"
|
<TextBlock Name="PartNumTxBl" Grid.Column="0" Style="{StaticResource OmagCut_CurrProjSummeryTextBlock}"
|
||||||
TextAlignment="Right"/>
|
TextAlignment="Right"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="PartNumTxBx" Grid.Column="1" Width="60"
|
<EgtWPFLib:EgtTextBox Name="PartNumTxBx" Grid.Column="1" Width="60" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -41,6 +41,9 @@ Public Class DrawPageUC
|
|||||||
Friend m_bDrawOk As Boolean = False
|
Friend m_bDrawOk As Boolean = False
|
||||||
Private m_bFirst As Boolean = True
|
Private m_bFirst As Boolean = True
|
||||||
|
|
||||||
|
Private m_SelListHole As New List(Of Integer)
|
||||||
|
Private m_DeselectListHole As New List(Of Integer)
|
||||||
|
|
||||||
' questa variabile serve per risalire al nome della componente che ospita i componenti interni att
|
' questa variabile serve per risalire al nome della componente che ospita i componenti interni att
|
||||||
Friend m_sMainCompo As String = String.Empty
|
Friend m_sMainCompo As String = String.Empty
|
||||||
|
|
||||||
@@ -360,6 +363,8 @@ Public Class DrawPageUC
|
|||||||
Dim nCmpInfo As Integer = 0
|
Dim nCmpInfo As Integer = 0
|
||||||
If EgtGetInfo(nHLId, "ID", nCmpInfo) AndAlso nCmp = nCmpInfo Then
|
If EgtGetInfo(nHLId, "ID", nCmpInfo) AndAlso nCmp = nCmpInfo Then
|
||||||
EgtSetStatus(nHLId, GDB_ST.ON_)
|
EgtSetStatus(nHLId, GDB_ST.ON_)
|
||||||
|
' nascondo eventuali FiloTop
|
||||||
|
m_CompoDimension.SetStatusVisibilityInLoopReference(nCmp, GDB_ST.OFF)
|
||||||
Exit While
|
Exit While
|
||||||
End If
|
End If
|
||||||
nHLId = EgtGetNextName(nHLId, "HoleLabels")
|
nHLId = EgtGetNextName(nHLId, "HoleLabels")
|
||||||
@@ -468,6 +473,8 @@ Public Class DrawPageUC
|
|||||||
EgtRemoveInfo(nLayId, INFO_DEPTH)
|
EgtRemoveInfo(nLayId, INFO_DEPTH)
|
||||||
EgtResetColor(nLayId)
|
EgtResetColor(nLayId)
|
||||||
End If
|
End If
|
||||||
|
m_DeselectListHole.Add(nLayId)
|
||||||
|
m_SelListHole.Remove(nLayId)
|
||||||
Else
|
Else
|
||||||
Dim sLayName As String = ""
|
Dim sLayName As String = ""
|
||||||
If EgtGetName(nLayId, sLayName) AndAlso sLayName = NAME_INLOOP Then
|
If EgtGetName(nLayId, sLayName) AndAlso sLayName = NAME_INLOOP Then
|
||||||
@@ -477,6 +484,8 @@ Public Class DrawPageUC
|
|||||||
EgtSetInfo(nLayId, INFO_OFFSET, m_FiloTopUC.FiloTopOffset)
|
EgtSetInfo(nLayId, INFO_OFFSET, m_FiloTopUC.FiloTopOffset)
|
||||||
EgtSetInfo(nLayId, INFO_DEPTH, m_FiloTopUC.FiloTopDepth)
|
EgtSetInfo(nLayId, INFO_DEPTH, m_FiloTopUC.FiloTopDepth)
|
||||||
EgtSetColor(nLayId, New Color3d(255, 255, 255))
|
EgtSetColor(nLayId, New Color3d(255, 255, 255))
|
||||||
|
m_SelListHole.Add(nLayId)
|
||||||
|
m_DeselectListHole.Remove(nLayId)
|
||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
@@ -484,6 +493,8 @@ Public Class DrawPageUC
|
|||||||
End If
|
End If
|
||||||
nId = EgtGetNextObjInSelWin()
|
nId = EgtGetNextObjInSelWin()
|
||||||
End While
|
End While
|
||||||
|
m_FiloTopUC.CreateFiloTopPreView(m_SelListHole)
|
||||||
|
m_FiloTopUC.EraseFiloTopPreview(m_DeselectListHole)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub OnShowDistanceVector(sender As Object, vtDist As Vector3d) Handles DrawScene.OnShowDistanceVector
|
Private Sub OnShowDistanceVector(sender As Object, vtDist As Vector3d) Handles DrawScene.OnShowDistanceVector
|
||||||
@@ -633,10 +644,17 @@ Public Class DrawPageUC
|
|||||||
m_CompoDimension.GetNameEdit(j).Text = m_CVars(i - 1).m_sName
|
m_CompoDimension.GetNameEdit(j).Text = m_CVars(i - 1).m_sName
|
||||||
m_CompoDimension.GetNameEdit(j).Visibility = Windows.Visibility.Visible
|
m_CompoDimension.GetNameEdit(j).Visibility = Windows.Visibility.Visible
|
||||||
m_CompoDimension.GetValueEdit(j).Text = m_CVars(i - 1).ToString()
|
m_CompoDimension.GetValueEdit(j).Text = m_CVars(i - 1).ToString()
|
||||||
|
'Dim dVal As Double
|
||||||
|
'StringToLen(m_CVars(i - 1).ToString(), dVal)
|
||||||
|
'm_CompoDimension.GetValueEdit(j).Text = LenToString(dVal, 3)
|
||||||
m_CompoDimension.GetValueEdit(j).Visibility = Windows.Visibility.Visible
|
m_CompoDimension.GetValueEdit(j).Visibility = Windows.Visibility.Visible
|
||||||
If m_CVars(i - 1).m_nType = 5 Then
|
If m_CVars(i - 1).m_nType = 5 Then
|
||||||
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).Keyboard = EgtTextBox.KeyboardType.Alphanumeric
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).Keyboard = EgtTextBox.KeyboardType.Alphanumeric
|
||||||
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).KeyboardDimension = 600
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).KeyboardDimension = 600
|
||||||
|
ElseIf m_CVars(i - 1).m_nType = 4 Then
|
||||||
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).Keyboard = EgtTextBox.KeyboardType.Calculator
|
||||||
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).IsLength = False
|
||||||
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).KeyboardDimension = 300
|
||||||
Else
|
Else
|
||||||
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).Keyboard = EgtTextBox.KeyboardType.Calculator
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).Keyboard = EgtTextBox.KeyboardType.Calculator
|
||||||
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).KeyboardDimension = 300
|
TryCast(m_CompoDimension.GetValueEdit(j), EgtTextBox).KeyboardDimension = 300
|
||||||
@@ -1162,8 +1180,10 @@ Public Class DrawPageUC
|
|||||||
Private Sub TrfDataBtn_Click(sender As Object, e As RoutedEventArgs) Handles TrfDataBtn.Click
|
Private Sub TrfDataBtn_Click(sender As Object, e As RoutedEventArgs) Handles TrfDataBtn.Click
|
||||||
If m_bTrfData Then
|
If m_bTrfData Then
|
||||||
Dim DlgTrfData As New CompoTrfData(m_MainWindow)
|
Dim DlgTrfData As New CompoTrfData(m_MainWindow)
|
||||||
|
' carico i dati appena salvati nella pagina
|
||||||
DlgTrfData.SetData(m_TrfOrderCode, m_TrfOrderDesc, m_TrfPartCode, m_TrfMatCode, m_TrfSurfCode, m_TrfThickness)
|
DlgTrfData.SetData(m_TrfOrderCode, m_TrfOrderDesc, m_TrfPartCode, m_TrfMatCode, m_TrfSurfCode, m_TrfThickness)
|
||||||
If DlgTrfData.ShowDialog() Then
|
If DlgTrfData.ShowDialog() Then
|
||||||
|
' recupero i dati salvati nella pagina
|
||||||
DlgTrfData.GetData(m_TrfOrderCode, m_TrfOrderDesc, m_TrfPartCode, m_TrfMatCode, m_TrfSurfCode, m_TrfThickness)
|
DlgTrfData.GetData(m_TrfOrderCode, m_TrfOrderDesc, m_TrfPartCode, m_TrfMatCode, m_TrfSurfCode, m_TrfThickness)
|
||||||
End If
|
End If
|
||||||
ElseIf m_bCsvData Then
|
ElseIf m_bCsvData Then
|
||||||
@@ -1242,6 +1262,8 @@ Public Class DrawPageUC
|
|||||||
Private Sub EngraveBtn_Click(sender As Object, e As RoutedEventArgs) Handles EngraveBtn.Click
|
Private Sub EngraveBtn_Click(sender As Object, e As RoutedEventArgs) Handles EngraveBtn.Click
|
||||||
m_SceneButtons.MeasureBtn.IsChecked = False
|
m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
If EngraveBtn.IsChecked Then
|
If EngraveBtn.IsChecked Then
|
||||||
|
' Aumento lo spazio disponibile per inserirei i parametri (tolgo spazio ad eventuali messaggi)
|
||||||
|
Grid.SetRowSpan(VariablesGrd, 2)
|
||||||
' Imposto modalità
|
' Imposto modalità
|
||||||
m_SideAngleUC.m_Mode = SideAngleUC.ModeOpt.ENGRAVE
|
m_SideAngleUC.m_Mode = SideAngleUC.ModeOpt.ENGRAVE
|
||||||
If m_ActiveComponentPage = Pages.CompoDimension Then
|
If m_ActiveComponentPage = Pages.CompoDimension Then
|
||||||
@@ -1273,6 +1295,7 @@ Public Class DrawPageUC
|
|||||||
EgtSetStatus(EgtGetFirstNameInGroup(PartId, COMPO_LAYER_QUOTATURE), GDB_ST.OFF)
|
EgtSetStatus(EgtGetFirstNameInGroup(PartId, COMPO_LAYER_QUOTATURE), GDB_ST.OFF)
|
||||||
EgtSetStatus(EgtGetFirstNameInGroup(PartId, COMPO_LAYER_ETICHETTE), GDB_ST.OFF)
|
EgtSetStatus(EgtGetFirstNameInGroup(PartId, COMPO_LAYER_ETICHETTE), GDB_ST.OFF)
|
||||||
Else
|
Else
|
||||||
|
Grid.SetRowSpan(VariablesGrd, 2)
|
||||||
VariablesGrd.Children.Remove(m_SideAngleUC)
|
VariablesGrd.Children.Remove(m_SideAngleUC)
|
||||||
If m_PrevSideAnglePage = Pages.CompoDimension Then
|
If m_PrevSideAnglePage = Pages.CompoDimension Then
|
||||||
VariablesGrd.Children.Add(m_CompoDimension)
|
VariablesGrd.Children.Add(m_CompoDimension)
|
||||||
@@ -1362,6 +1385,8 @@ Public Class DrawPageUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub FiloTopBtn_Click(sender As Object, e As RoutedEventArgs) Handles FiloTopBtn.Click
|
Private Sub FiloTopBtn_Click(sender As Object, e As RoutedEventArgs) Handles FiloTopBtn.Click
|
||||||
|
m_SelListHole.Clear()
|
||||||
|
m_DeselectListHole.Clear()
|
||||||
m_SceneButtons.MeasureBtn.IsChecked = False
|
m_SceneButtons.MeasureBtn.IsChecked = False
|
||||||
If FiloTopBtn.IsChecked Then
|
If FiloTopBtn.IsChecked Then
|
||||||
' Imposto modalità
|
' Imposto modalità
|
||||||
@@ -1467,7 +1492,10 @@ Public Class DrawPageUC
|
|||||||
Case 2 ' intero
|
Case 2 ' intero
|
||||||
Return m_nVal.ToString()
|
Return m_nVal.ToString()
|
||||||
Case 3 ' lunghezza
|
Case 3 ' lunghezza
|
||||||
Return DoubleToString(EgtToUiUnits(m_dVal), 4)
|
'Dim dVal As Double
|
||||||
|
'StringToLen(m_sVal, dVal)
|
||||||
|
Return LenToString(m_dVal, 4)
|
||||||
|
'Return DoubleToString(EgtToUiUnits(m_dVal), 4)
|
||||||
Case 4 ' double
|
Case 4 ' double
|
||||||
Return DoubleToString(m_dVal, 4)
|
Return DoubleToString(m_dVal, 4)
|
||||||
Case 5 ' stringa
|
Case 5 ' stringa
|
||||||
@@ -1492,12 +1520,13 @@ Public Class DrawPageUC
|
|||||||
End If
|
End If
|
||||||
Case 3 ' lunghezza
|
Case 3 ' lunghezza
|
||||||
Dim dVal As Double
|
Dim dVal As Double
|
||||||
If StringToDouble(sVal, dVal) Then
|
|
||||||
If bConvertUnits Then
|
If bConvertUnits Then
|
||||||
m_dVal = EgtFromUiUnits(dVal)
|
StringToLen(sVal, dVal)
|
||||||
Else
|
m_dVal = dVal
|
||||||
|
Return True
|
||||||
|
Else
|
||||||
|
StringToDouble(sVal, dVal)
|
||||||
m_dVal = dVal
|
m_dVal = dVal
|
||||||
End If
|
|
||||||
Return True
|
Return True
|
||||||
End If
|
End If
|
||||||
Case 4 ' double
|
Case 4 ' double
|
||||||
|
|||||||
@@ -41,7 +41,11 @@
|
|||||||
FontSize="{DynamicResource FontSize_LowerCaseCharacter}"/>
|
FontSize="{DynamicResource FontSize_LowerCaseCharacter}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="Parameter2TxBx" Grid.Column="1" Grid.Row="11" Width="90"
|
<EgtWPFLib:EgtTextBox Name="Parameter2TxBx" Grid.Column="1" Grid.Row="11" Width="90"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
<TextBlock Name="Parameter3TxBl" Grid.Row="12" Text="Arrotonda"
|
||||||
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"
|
||||||
|
FontSize="{DynamicResource FontSize_LowerCaseCharacter}"/>
|
||||||
|
<CheckBox Name="Parameter3ChBx" Grid.Row="12" Grid.Column="1" Style="{StaticResource OmagCut_CheckBox_Single}"
|
||||||
|
HorizontalAlignment="Center" Margin="0,0,6,0"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
</UserControl>
|
</UserControl>
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ Public Class FiloTopUC
|
|||||||
' Riferimento alla pagina che ha aperto SideAngleUC
|
' Riferimento alla pagina che ha aperto SideAngleUC
|
||||||
Private m_CallingPage As MainWindow.Pages
|
Private m_CallingPage As MainWindow.Pages
|
||||||
|
|
||||||
|
Private m_SelList As New List(Of Integer)
|
||||||
|
|
||||||
' Offset della sfilettatura
|
' Offset della sfilettatura
|
||||||
Private m_dFiloTopOffset As Double = 0
|
Private m_dFiloTopOffset As Double = 0
|
||||||
Friend ReadOnly Property FiloTopOffset As Double
|
Friend ReadOnly Property FiloTopOffset As Double
|
||||||
@@ -23,6 +25,13 @@ Public Class FiloTopUC
|
|||||||
End Get
|
End Get
|
||||||
End Property
|
End Property
|
||||||
|
|
||||||
|
' esegue l'arrotindamento sugli angoli del percorso utensile
|
||||||
|
Private m_bCornerradius As Boolean = False
|
||||||
|
Friend ReadOnly Property bCornerRadius As Boolean
|
||||||
|
Get
|
||||||
|
Return m_bCornerradius
|
||||||
|
End Get
|
||||||
|
End Property
|
||||||
|
|
||||||
Private Sub FiloTopUC_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
Private Sub FiloTopUC_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
' Imposto riferimenti ad altre pagine
|
' Imposto riferimenti ad altre pagine
|
||||||
@@ -43,14 +52,18 @@ Public Class FiloTopUC
|
|||||||
End If
|
End If
|
||||||
|
|
||||||
' Gestisco visualizzazione dei parametri
|
' Gestisco visualizzazione dei parametri
|
||||||
Parameter2TxBl.Visibility = Windows.Visibility.Visible
|
ParameterTxBl.Visibility = Windows.Visibility.Visible
|
||||||
Parameter2TxBx.Visibility = Windows.Visibility.Visible
|
Parameter2TxBx.Visibility = Windows.Visibility.Visible
|
||||||
|
Parameter3TxBl.Visibility = Windows.Visibility.Visible
|
||||||
|
|
||||||
' Aggiorno valori
|
' Aggiorno valori
|
||||||
m_dFiloTopOffset = GetPrivateProfileDouble( S_SIDES, K_FILOTOPOFFSET, 5, m_MainWindow.GetIniFile())
|
m_dFiloTopOffset = GetPrivateProfileDouble( S_SIDES, K_FILOTOPOFFSET, 5, m_MainWindow.GetIniFile())
|
||||||
ParameterTxBx.Text = LenToString( m_dFiloTopOffset, 3)
|
ParameterTxBx.Text = LenToString( m_dFiloTopOffset, 3)
|
||||||
m_dFiloTopDepth = GetPrivateProfileDouble( S_SIDES, K_FILOTOPDEPTH, 5, m_MainWindow.GetIniFile())
|
m_dFiloTopDepth = GetPrivateProfileDouble( S_SIDES, K_FILOTOPDEPTH, 5, m_MainWindow.GetIniFile())
|
||||||
Parameter2TxBx.Text = LenToString(m_dFiloTopDepth, 3)
|
Parameter2TxBx.Text = LenToString(m_dFiloTopDepth, 3)
|
||||||
|
m_bCornerradius = GetPrivateProfileInt(S_SIDES, K_ROUNDOFF, 0, m_MainWindow.GetIniFile()) <> 0
|
||||||
|
Parameter3ChBx.IsChecked = m_bCornerradius
|
||||||
|
m_SelList.Clear()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub FiloTopUC_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
Private Sub FiloTopUC_Unloaded(sender As Object, e As RoutedEventArgs) Handles Me.Unloaded
|
||||||
@@ -74,6 +87,8 @@ Public Class FiloTopUC
|
|||||||
End While
|
End While
|
||||||
nPartId = EgtGetNextPart(nPartId)
|
nPartId = EgtGetNextPart(nPartId)
|
||||||
End While
|
End While
|
||||||
|
' aggiorno la preview
|
||||||
|
CreateFiloTopPreView(m_SelList, False)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub Parameter2TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter2TxBx.EgtClosed
|
Private Sub Parameter2TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter2TxBx.EgtClosed
|
||||||
@@ -95,4 +110,161 @@ Public Class FiloTopUC
|
|||||||
End While
|
End While
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub Parameter3ChBx_Checked() Handles Parameter3ChBx.Click
|
||||||
|
' Assegno il valore
|
||||||
|
m_bCornerradius = Parameter3ChBx.IsChecked
|
||||||
|
WritePrivateProfileString(S_SIDES, K_ROUNDOFF, If(m_bCornerradius, "1", "0"), m_MainWindow.GetIniFile())
|
||||||
|
' Aggiorno le info del profilo
|
||||||
|
Dim nPartId As Integer = EgtGetFirstPart()
|
||||||
|
While nPartId <> GDB_ID.NULL
|
||||||
|
Dim nLayId As Integer = EgtGetFirstLayer(nPartId)
|
||||||
|
While nLayId <> GDB_ID.NULL
|
||||||
|
Dim sLayName As String = ""
|
||||||
|
If EgtGetName(nLayId, sLayName) AndAlso sLayName = NAME_INLOOP AndAlso EgtExistsInfo(nLayId, INFO_FILOTOP) Then
|
||||||
|
EgtSetInfo(nLayId, INFO_ROUNDOFF, If(m_bCornerradius, 1, 0))
|
||||||
|
End If
|
||||||
|
nLayId = EgtGetNextLayer(nLayId)
|
||||||
|
End While
|
||||||
|
nPartId = EgtGetNextPart(nPartId)
|
||||||
|
End While
|
||||||
|
' aggiorno la preview (False = blocco la lettura dei dati della componente)
|
||||||
|
CreateFiloTopPreView(m_SelList, False)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Public Sub CreateFiloTopPreView(SelList As List(Of Integer), Optional bReadInfo As Boolean = True)
|
||||||
|
m_SelList = SelList
|
||||||
|
If m_SelList.Count < 1 Then Return
|
||||||
|
Dim nPartId As Integer = EgtGetFirstPart()
|
||||||
|
While nPartId <> GDB_ID.NULL
|
||||||
|
Dim nLayId As Integer = EgtGetFirstLayer(nPartId)
|
||||||
|
While nLayId <> GDB_ID.NULL
|
||||||
|
Dim sLayName As String = ""
|
||||||
|
' verifico che lemento corrente appartenga all'elenco degli elementi selezionati
|
||||||
|
Dim bIsSelected As Boolean = m_SelList.Find(Function(value As Integer)
|
||||||
|
Return value = nLayId
|
||||||
|
End Function) <> 0
|
||||||
|
If EgtGetName(nLayId, sLayName) AndAlso sLayName = NAME_INLOOP AndAlso EgtExistsInfo(nLayId, INFO_FILOTOP) AndAlso bIsSelected Then
|
||||||
|
' ---------------------- Inizio GESTIONE PREVIEW percorso -------------------------------
|
||||||
|
Dim nLayFiloTop As Integer = GDB_ID.NULL
|
||||||
|
Dim nInLoopRef As Integer = GDB_ID.NULL
|
||||||
|
nLayFiloTop = EgtGetFirstNameInGroup(nPartId, "FiloTop")
|
||||||
|
EgtGetInfo(nLayFiloTop, "InLoopRef", nInLoopRef)
|
||||||
|
' verifico il Layer "FiloTop" sia associato all'InLoop corrente
|
||||||
|
While (nLayFiloTop <> GDB_ID.NULL AndAlso nInLoopRef <> nLayId)
|
||||||
|
nLayFiloTop = EgtGetNextName(nLayFiloTop, "FiloTop")
|
||||||
|
EgtGetInfo(nLayFiloTop, "InLoopRef", nInLoopRef)
|
||||||
|
End While
|
||||||
|
|
||||||
|
' se non esiste il Layer "FiloTop"
|
||||||
|
If nLayFiloTop = GDB_ID.NULL Then
|
||||||
|
' lo creo
|
||||||
|
nLayFiloTop = EgtCreateGroup(nPartId)
|
||||||
|
EgtSetName(nLayFiloTop, "FiloTop")
|
||||||
|
EgtSetInfo(nLayFiloTop, "InLoopRef", nLayId)
|
||||||
|
EgtSetInfo(nLayId, "FiloTopRef", nLayFiloTop)
|
||||||
|
End If
|
||||||
|
|
||||||
|
' carico i dati del filo top selezionato
|
||||||
|
If bReadInfo Then
|
||||||
|
EgtGetInfo(nLayFiloTop, INFO_OFFSET, m_dFiloTopOffset)
|
||||||
|
ParameterTxBx.Text = LenToString(m_dFiloTopOffset, 3)
|
||||||
|
EgtGetInfo(nLayFiloTop, INFO_DEPTH, m_dFiloTopDepth)
|
||||||
|
Parameter2TxBx.Text = LenToString(m_dFiloTopDepth, 3)
|
||||||
|
Dim nVal As Integer = If(m_bCornerradius, 1, 0)
|
||||||
|
EgtGetInfo(nLayFiloTop, INFO_ROUNDOFF, nVal)
|
||||||
|
Parameter3ChBx.IsChecked = If(nVal = 1, True, False)
|
||||||
|
m_bCornerradius = Parameter3ChBx.IsChecked
|
||||||
|
End If
|
||||||
|
|
||||||
|
' procedo alla creazione della curva
|
||||||
|
Dim nIdCompoCurve As Integer = GDB_ID.NULL
|
||||||
|
' cancello un eventuale curva composita creata in precedenza
|
||||||
|
nIdCompoCurve = EgtGetFirstNameInGroup(nLayFiloTop, "OffsetPreView")
|
||||||
|
If nIdCompoCurve <> GDB_ID.NULL Then
|
||||||
|
EgtErase(nIdCompoCurve)
|
||||||
|
End If
|
||||||
|
Dim nCompoCurve As New List(Of Integer)
|
||||||
|
' costruisco il percorso chiuso dati i lati di contorno
|
||||||
|
Dim nLine As Integer = EgtGetFirstInGroup(nLayId)
|
||||||
|
While nLine <> GDB_ID.NULL
|
||||||
|
nCompoCurve.Add(nLine)
|
||||||
|
nLine = EgtGetNext(nLine)
|
||||||
|
End While
|
||||||
|
Dim PtNearStart As Point3d
|
||||||
|
Dim nInfoRoundOff As Integer = If(m_bCornerradius, 1, 0)
|
||||||
|
|
||||||
|
nIdCompoCurve = EgtCreateCurveCompoByChain(nLayFiloTop, nCompoCurve.ToArray, PtNearStart, False)
|
||||||
|
EgtSetName(nIdCompoCurve, "OffsetPreView")
|
||||||
|
|
||||||
|
' salvo i dati nel layer FiloTop
|
||||||
|
EgtSetInfo(nLayFiloTop, INFO_OFFSET, m_dFiloTopOffset)
|
||||||
|
EgtSetInfo(nLayFiloTop, INFO_DEPTH, m_dFiloTopDepth)
|
||||||
|
EgtSetInfo(nLayFiloTop, INFO_ROUNDOFF, nInfoRoundOff)
|
||||||
|
|
||||||
|
Dim bOk As Boolean = False
|
||||||
|
' leggo che tipo di offset applicare (Round, Extend)
|
||||||
|
If nInfoRoundOff <> 1 Then
|
||||||
|
bOk = EgtOffsetCurve(nIdCompoCurve, -m_dFiloTopOffset, OFF_TYPE.EXTEND)
|
||||||
|
Else
|
||||||
|
bOk = EgtOffsetCurve(nIdCompoCurve, -m_dFiloTopOffset, OFF_TYPE.FILLET)
|
||||||
|
End If
|
||||||
|
|
||||||
|
' se la generazione della curva non va a buon fine
|
||||||
|
If Not bOk Then
|
||||||
|
EgtErase(nLayFiloTop)
|
||||||
|
EgtRemoveInfo(nLayId, "FiloTopRef")
|
||||||
|
EgtOutLog("Error in generation OffsetPreView in TopEgde ")
|
||||||
|
End If
|
||||||
|
' ---------------------- Fine GESTIONE PREVIEW percorso -------------------------------
|
||||||
|
End If
|
||||||
|
nLayId = EgtGetNextLayer(nLayId)
|
||||||
|
End While
|
||||||
|
nPartId = EgtGetNextPart(nPartId)
|
||||||
|
End While
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' riceve la lista dei LayerFiloTop che devono essere eliminati
|
||||||
|
Public Sub EraseFiloTopPreview(EraseList As List(Of Integer))
|
||||||
|
Dim m_EraseList As List(Of Integer) = EraseList
|
||||||
|
If m_EraseList.Count < 1 Then Return
|
||||||
|
Dim nPartId As Integer = EgtGetFirstPart()
|
||||||
|
While nPartId <> GDB_ID.NULL
|
||||||
|
Dim nLayId As Integer = EgtGetFirstLayer(nPartId)
|
||||||
|
While nLayId <> GDB_ID.NULL
|
||||||
|
Dim sLayName As String = ""
|
||||||
|
Dim bIsSelected As Boolean = m_EraseList.Find(Function(value As Integer)
|
||||||
|
Return value = nLayId
|
||||||
|
End Function) <> 0
|
||||||
|
If EgtGetName(nLayId, sLayName) AndAlso sLayName = NAME_INLOOP AndAlso bIsSelected Then
|
||||||
|
' ---------------------- Inizio GESTIONE PREVIEW percorso -------------------------------
|
||||||
|
Dim nLayFiloTop As Integer = GDB_ID.NULL
|
||||||
|
Dim nInLoopRef As Integer = GDB_ID.NULL
|
||||||
|
nLayFiloTop = EgtGetFirstNameInGroup(nPartId, "FiloTop")
|
||||||
|
EgtGetInfo(nLayFiloTop, "InLoopRef", nInLoopRef)
|
||||||
|
' cerco il Layer associato all'InLoop corrente
|
||||||
|
While (nLayFiloTop <> GDB_ID.NULL AndAlso nInLoopRef <> nLayId)
|
||||||
|
nLayFiloTop = EgtGetNextName(nLayFiloTop, "FiloTop")
|
||||||
|
EgtGetInfo(nLayFiloTop, "InLoopRef", nInLoopRef)
|
||||||
|
End While
|
||||||
|
|
||||||
|
' se non esiste il Layer
|
||||||
|
If nLayFiloTop = GDB_ID.NULL Then
|
||||||
|
' esco
|
||||||
|
Return
|
||||||
|
Else
|
||||||
|
' lo elimino
|
||||||
|
EgtErase(nLayFiloTop)
|
||||||
|
EraseList.Remove(nLayId)
|
||||||
|
End If
|
||||||
|
' ---------------------- Fine GESTIONE PREVIEW percorso -------------------------------
|
||||||
|
End If
|
||||||
|
nLayId = EgtGetNextLayer(nLayId)
|
||||||
|
End While
|
||||||
|
nPartId = EgtGetNextPart(nPartId)
|
||||||
|
End While
|
||||||
|
EgtDraw()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|||||||
@@ -49,7 +49,8 @@
|
|||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="0.5*"/>
|
<RowDefinition Height="0.5*"/>
|
||||||
<RowDefinition Height="0.5*"/>
|
<RowDefinition Height="0.5*"/>
|
||||||
<RowDefinition Height="8*"/>
|
<RowDefinition Height="7.25*"/>
|
||||||
|
<RowDefinition Height="0.75*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
@@ -57,7 +58,19 @@
|
|||||||
<ListBox Name="FileListBox" Grid.Row="1" Grid.RowSpan="2" ItemTemplate="{DynamicResource DataTemplateItem}"
|
<ListBox Name="FileListBox" Grid.Row="1" Grid.RowSpan="2" ItemTemplate="{DynamicResource DataTemplateItem}"
|
||||||
ItemsSource="{Binding ItemList}"/>
|
ItemsSource="{Binding ItemList}"/>
|
||||||
|
|
||||||
<Border Name="MessageBrd" Grid.Row="4" BorderThickness="0,1,0,0" BorderBrush="Gray">
|
<Grid Grid.Row="3" Margin="0,0,8,0">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="FindTxBx" Grid.Column="0"
|
||||||
|
Style="{DynamicResource OmagCut_LeftKeyboardTextBoxNoBorder}"/>
|
||||||
|
<Button Name="ClearFindBtn" Grid.Column="1" Style="{DynamicResource OmagCut_GradientBlueIconButton}" Margin="0,6,2,6">
|
||||||
|
<Image Source="{DynamicResource XImg}" Style="{StaticResource OmagCut_ButtonIcon}" Width="30" />
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<Border Name="MessageBrd" Grid.Row="5" BorderThickness="0,1,0,0" BorderBrush="Gray">
|
||||||
<TextBlock Name="MessageTxBx" TextAlignment="Center"
|
<TextBlock Name="MessageTxBx" TextAlignment="Center"
|
||||||
Style="{DynamicResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
Style="{DynamicResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
</Border>
|
</Border>
|
||||||
@@ -101,7 +114,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="PartNumTxBl" Grid.Column="0" Style="{DynamicResource OmagCut_CurrProjSummeryTextBlock}"
|
<TextBlock Name="PartNumTxBl" Grid.Column="0" Style="{DynamicResource OmagCut_CurrProjSummeryTextBlock}"
|
||||||
TextAlignment="Right"/>
|
TextAlignment="Right"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="PartNumTxBx" Grid.Column="1" Width="60"
|
<EgtWPFLib:EgtTextBox Name="PartNumTxBx" Grid.Column="1" Width="60" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
|
|||||||
@@ -297,6 +297,36 @@ Public Class ImportPageUC
|
|||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub FindTxBx_EgtClosed(sender As Object, e As EventArgs) Handles FindTxBx.EgtClosed
|
||||||
|
' Elimino spazi iniziali e finali
|
||||||
|
FindTxBx.Text = FindTxBx.Text.Trim()
|
||||||
|
' ricarico la lista dei file
|
||||||
|
LoadCurrDir()
|
||||||
|
Dim UpdateListFile As New List(Of IconListBoxItem)
|
||||||
|
' Se esiste un nome
|
||||||
|
If Not String.IsNullOrWhiteSpace(FindTxBx.Text) Then
|
||||||
|
For Each Item As IconListBoxItem In FileListBox.ItemsSource
|
||||||
|
If Item.Name.ToLower.Contains(FindTxBx.Text.ToLower) Then
|
||||||
|
UpdateListFile.Add(Item)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
If UpdateListFile.Count > 0 Then
|
||||||
|
FileListBox.ItemsSource = UpdateListFile
|
||||||
|
Else
|
||||||
|
FileListBox.ItemsSource = m_MainWindow.m_ImportItemList
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ClearFindBtn_Click() Handles ClearFindBtn.Click
|
||||||
|
' svuoto la text
|
||||||
|
FindTxBx.Text = ""
|
||||||
|
' ricarico la lista dei file
|
||||||
|
LoadCurrDir()
|
||||||
|
' e aggiorno la lista dei file
|
||||||
|
FileListBox.ItemsSource = m_MainWindow.m_ImportItemList
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Function ClearView() As Boolean
|
Private Function ClearView() As Boolean
|
||||||
' Pulisco il DB geometrico locale
|
' Pulisco il DB geometrico locale
|
||||||
EgtNewFile()
|
EgtNewFile()
|
||||||
@@ -809,7 +839,7 @@ Public Class ImportPageUC
|
|||||||
PartId = EgtGetNextPart(PartId)
|
PartId = EgtGetNextPart(PartId)
|
||||||
End While
|
End While
|
||||||
|
|
||||||
' identificativo univoico del gruppo di pezzi, se più di un pezzo
|
' identificativo univoico del gruppo di pezzi, se più di un "Repeat"
|
||||||
Dim sGUICode As New List(Of String)
|
Dim sGUICode As New List(Of String)
|
||||||
|
|
||||||
' Scrivo testi per nesting
|
' Scrivo testi per nesting
|
||||||
@@ -851,6 +881,7 @@ Public Class ImportPageUC
|
|||||||
EgtInsertFile(sTmpFile)
|
EgtInsertFile(sTmpFile)
|
||||||
|
|
||||||
Dim FirstOfImport As Integer = EgtGetNextPart(nFirst2Id)
|
Dim FirstOfImport As Integer = EgtGetNextPart(nFirst2Id)
|
||||||
|
If FirstOfImport = GDB_ID.NULL Then FirstOfImport = EgtGetFirstPart()
|
||||||
Dim Index As Integer = 1
|
Dim Index As Integer = 1
|
||||||
While FirstOfImport <> GDB_ID.NULL And Index <= sGUICode.Count
|
While FirstOfImport <> GDB_ID.NULL And Index <= sGUICode.Count
|
||||||
If Not String.IsNullOrEmpty(sGUICode(Index - 1)) Then
|
If Not String.IsNullOrEmpty(sGUICode(Index - 1)) Then
|
||||||
@@ -887,6 +918,7 @@ Public Class ImportPageUC
|
|||||||
' Passo al pezzo successivo
|
' Passo al pezzo successivo
|
||||||
nId = EgtGetNextPart(nId)
|
nId = EgtGetNextPart(nId)
|
||||||
End While
|
End While
|
||||||
|
|
||||||
' Ciclo sui pezzi inseriti
|
' Ciclo sui pezzi inseriti
|
||||||
nId = nFirstId
|
nId = nFirstId
|
||||||
While nId <> GDB_ID.NULL
|
While nId <> GDB_ID.NULL
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
d:DesignHeight="597.1" d:DesignWidth="255.9">
|
d:DesignHeight="636.9" d:DesignWidth="255.9">
|
||||||
|
|
||||||
<!-- Definizione della Grid Laterale -->
|
<!-- Definizione della Grid Laterale -->
|
||||||
<Grid Name="VariablesCompoGrid" Grid.RowSpan="2">
|
<Grid Name="VariablesCompoGrid" Grid.RowSpan="2">
|
||||||
@@ -28,7 +28,7 @@
|
|||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
<RowDefinition Height="0.2*"/>
|
<RowDefinition Height="0.2*"/>
|
||||||
<RowDefinition Height="4*"/>
|
<RowDefinition Height="5*"/>
|
||||||
<!--<RowDefinition Height="0.5*"/>
|
<!--<RowDefinition Height="0.5*"/>
|
||||||
<RowDefinition Height="0.5*"/>
|
<RowDefinition Height="0.5*"/>
|
||||||
<RowDefinition Height="0.5*"/>-->
|
<RowDefinition Height="0.5*"/>-->
|
||||||
@@ -56,7 +56,7 @@
|
|||||||
<TextBlock Name="Entity1" Grid.Row="1" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity1" Grid.Row="1" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A1" Grid.Column="1" Grid.Row="1" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A1" Grid.Column="1" Grid.Row="1" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A1TxBx" Grid.Column="2" Grid.Row="1" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A1TxBx" Grid.Column="2" Grid.Row="1" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H1TxBx" Grid.Column="3" Grid.Row="1" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H1TxBx" Grid.Column="3" Grid.Row="1" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -64,7 +64,7 @@
|
|||||||
<TextBlock Name="Entity2" Grid.Row="2" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity2" Grid.Row="2" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A2" Grid.Column="1" Grid.Row="2" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A2" Grid.Column="1" Grid.Row="2" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A2TxBx" Grid.Column="2" Grid.Row="2" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A2TxBx" Grid.Column="2" Grid.Row="2" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H2TxBx" Grid.Column="3" Grid.Row="2" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H2TxBx" Grid.Column="3" Grid.Row="2" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -72,7 +72,7 @@
|
|||||||
<TextBlock Name="Entity3" Grid.Row="3" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity3" Grid.Row="3" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A3" Grid.Column="1" Grid.Row="3" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A3" Grid.Column="1" Grid.Row="3" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A3TxBx" Grid.Column="2" Grid.Row="3" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A3TxBx" Grid.Column="2" Grid.Row="3" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H3TxBx" Grid.Column="3" Grid.Row="3" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H3TxBx" Grid.Column="3" Grid.Row="3" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -80,7 +80,7 @@
|
|||||||
<TextBlock Name="Entity4" Grid.Row="4" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity4" Grid.Row="4" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A4" Grid.Column="1" Grid.Row="4" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A4" Grid.Column="1" Grid.Row="4" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A4TxBx" Grid.Column="2" Grid.Row="4" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A4TxBx" Grid.Column="2" Grid.Row="4" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H4TxBx" Grid.Column="3" Grid.Row="4" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H4TxBx" Grid.Column="3" Grid.Row="4" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -88,7 +88,7 @@
|
|||||||
<TextBlock Name="Entity5" Grid.Row="5" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity5" Grid.Row="5" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A5" Grid.Column="1" Grid.Row="5" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A5" Grid.Column="1" Grid.Row="5" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A5TxBx" Grid.Column="2" Grid.Row="5" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A5TxBx" Grid.Column="2" Grid.Row="5" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H5TxBx" Grid.Column="3" Grid.Row="5" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H5TxBx" Grid.Column="3" Grid.Row="5" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -96,7 +96,7 @@
|
|||||||
<TextBlock Name="Entity6" Grid.Row="6" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity6" Grid.Row="6" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A6" Grid.Column="1" Grid.Row="6" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A6" Grid.Column="1" Grid.Row="6" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A6TxBx" Grid.Column="2" Grid.Row="6" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A6TxBx" Grid.Column="2" Grid.Row="6" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H6TxBx" Grid.Column="3" Grid.Row="6" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H6TxBx" Grid.Column="3" Grid.Row="6" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -104,7 +104,7 @@
|
|||||||
<TextBlock Name="Entity7" Grid.Row="7" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity7" Grid.Row="7" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A7" Grid.Column="1" Grid.Row="7" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A7" Grid.Column="1" Grid.Row="7" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A7TxBx" Grid.Column="2" Grid.Row="7" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A7TxBx" Grid.Column="2" Grid.Row="7" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H7TxBx" Grid.Column="3" Grid.Row="7" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H7TxBx" Grid.Column="3" Grid.Row="7" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -112,7 +112,7 @@
|
|||||||
<TextBlock Name="Entity8" Grid.Row="8" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity8" Grid.Row="8" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A8" Grid.Column="1" Grid.Row="8" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A8" Grid.Column="1" Grid.Row="8" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A8TxBx" Grid.Column="2" Grid.Row="8" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A8TxBx" Grid.Column="2" Grid.Row="8" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H8TxBx" Grid.Column="3" Grid.Row="8" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H8TxBx" Grid.Column="3" Grid.Row="8" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -120,7 +120,7 @@
|
|||||||
<TextBlock Name="Entity9" Grid.Row="9" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity9" Grid.Row="9" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A9" Grid.Column="1" Grid.Row="9" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A9" Grid.Column="1" Grid.Row="9" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A9TxBx" Grid.Column="2" Grid.Row="9" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A9TxBx" Grid.Column="2" Grid.Row="9" Width="60" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H9TxBx" Grid.Column="3" Grid.Row="9" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H9TxBx" Grid.Column="3" Grid.Row="9" Width="60"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
@@ -128,7 +128,7 @@
|
|||||||
<TextBlock Name="Entity10" Grid.Row="10" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="Entity10" Grid.Row="10" Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"/>
|
||||||
<CheckBox Name="A10" Grid.Column="1" Grid.Row="10" Height="30" Width="40" HorizontalAlignment="Right"
|
<CheckBox Name="A10" Grid.Column="1" Grid.Row="10" Height="30" Width="40" HorizontalAlignment="Right"
|
||||||
Margin="-20,0,0,0"/>
|
Margin="-20,0,0,0"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="A10TxBx" Grid.Column="2" Grid.Row="10" Width="60"
|
<EgtWPFLib:EgtTextBox Name="A10TxBx" Grid.Column="2" Grid.Row="10" Width="60" IsLength="False"
|
||||||
Margin="0,0,0,-2"
|
Margin="0,0,0,-2"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="H10TxBx" Grid.Column="3" Grid.Row="10" Width="60"
|
<EgtWPFLib:EgtTextBox Name="H10TxBx" Grid.Column="3" Grid.Row="10" Width="60"
|
||||||
@@ -143,10 +143,11 @@
|
|||||||
<ColumnDefinition Width="0.6*"/>
|
<ColumnDefinition Width="0.6*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="0.9*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="0.9*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="0.9*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="0.9*"/>
|
||||||
|
<RowDefinition Height="0.9*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<TextBlock Name="Parameter1TxBl" Grid.Row="0" Grid.ColumnSpan="2"
|
<TextBlock Name="Parameter1TxBl" Grid.Row="0" Grid.ColumnSpan="2"
|
||||||
@@ -168,7 +169,7 @@
|
|||||||
<UniformGrid Rows="1" Grid.Column="2" Grid.Row="1" Grid.ColumnSpan="2" Width="90" >
|
<UniformGrid Rows="1" Grid.Column="2" Grid.Row="1" Grid.ColumnSpan="2" Width="90" >
|
||||||
<EgtWPFLib:EgtTextBox Name="Parameter2aTxBx"
|
<EgtWPFLib:EgtTextBox Name="Parameter2aTxBx"
|
||||||
Grid.Column="2" Grid.Row="12"
|
Grid.Column="2" Grid.Row="12"
|
||||||
Width="40" Height="30"
|
Width="40" Height="30" IsLength="False"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="Parameter2bTxBx"
|
<EgtWPFLib:EgtTextBox Name="Parameter2bTxBx"
|
||||||
Grid.Column="3" Grid.Row="12"
|
Grid.Column="3" Grid.Row="12"
|
||||||
@@ -196,6 +197,16 @@
|
|||||||
Margin="0,0,0,-2"
|
Margin="0,0,0,-2"
|
||||||
Width="85" Height="30"
|
Width="85" Height="30"
|
||||||
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
<TextBlock Name="Parameter5TxBl" Grid.Row="4" Grid.ColumnSpan="2"
|
||||||
|
Text="Angolo"
|
||||||
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}"
|
||||||
|
FontSize="{DynamicResource FontSize_LowerCaseCharacter}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="Parameter5TxBx"
|
||||||
|
Grid.Column="2" Grid.ColumnSpan="2" Grid.Row="4"
|
||||||
|
Margin="0,0,0,-2"
|
||||||
|
Width="85" Height="30" IsLength="False"
|
||||||
|
Style="{StaticResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
<!--<TextBlock Name="Parameter1TxBl" Grid.Row="11" Text="Offset"
|
<!--<TextBlock Name="Parameter1TxBl" Grid.Row="11" Text="Offset"
|
||||||
|
|||||||
@@ -34,7 +34,9 @@ Public Class SideAngleUC
|
|||||||
Friend m_dDripOffset2 As Double = 0
|
Friend m_dDripOffset2 As Double = 0
|
||||||
Friend m_nEngrNbr2 As Integer = 1
|
Friend m_nEngrNbr2 As Integer = 1
|
||||||
Friend m_dDripDepth As Double = 10
|
Friend m_dDripDepth As Double = 10
|
||||||
|
Friend m_dEngraveDepth2 As Double = 15
|
||||||
Friend m_dDripShort As Double = 0
|
Friend m_dDripShort As Double = 0
|
||||||
|
Friend m_dEngraveAngle As Double = 0
|
||||||
|
|
||||||
Private CurrEntityDrip As DripEntity
|
Private CurrEntityDrip As DripEntity
|
||||||
|
|
||||||
@@ -105,6 +107,9 @@ Public Class SideAngleUC
|
|||||||
' Accorciamento
|
' Accorciamento
|
||||||
Parameter4TxBl.Visibility = Windows.Visibility.Hidden
|
Parameter4TxBl.Visibility = Windows.Visibility.Hidden
|
||||||
Parameter4TxBx.Visibility = Windows.Visibility.Hidden
|
Parameter4TxBx.Visibility = Windows.Visibility.Hidden
|
||||||
|
' Angolo
|
||||||
|
Parameter5TxBl.Visibility = Windows.Visibility.Hidden
|
||||||
|
Parameter5TxBx.Visibility = Windows.Visibility.Hidden
|
||||||
Else
|
Else
|
||||||
' se aggiungo gli ENGRAVE e i DRIP
|
' se aggiungo gli ENGRAVE e i DRIP
|
||||||
|
|
||||||
@@ -116,10 +121,12 @@ Public Class SideAngleUC
|
|||||||
GetAngleTxBxFromIndex(Index).Visibility = Windows.Visibility.Visible
|
GetAngleTxBxFromIndex(Index).Visibility = Windows.Visibility.Visible
|
||||||
GetHeelTxBxFromIndex(Index).Visibility = Windows.Visibility.Visible
|
GetHeelTxBxFromIndex(Index).Visibility = Windows.Visibility.Visible
|
||||||
Next
|
Next
|
||||||
|
|
||||||
' Offset
|
' Offset
|
||||||
Parameter1TxBl.Visibility = Windows.Visibility.Visible
|
Parameter1TxBl.Visibility = Windows.Visibility.Visible
|
||||||
Parameter1TxBx.Visibility = Windows.Visibility.Visible
|
Parameter1TxBx.Visibility = Windows.Visibility.Visible
|
||||||
Parameter2TxBl.Visibility = Windows.Visibility.Visible
|
Parameter2TxBl.Visibility = Windows.Visibility.Visible
|
||||||
|
|
||||||
' Offset2
|
' Offset2
|
||||||
If m_Mode <> ModeOpt.ENGRAVE Then
|
If m_Mode <> ModeOpt.ENGRAVE Then
|
||||||
Parameter2TxBx.Visibility = Windows.Visibility.Visible
|
Parameter2TxBx.Visibility = Windows.Visibility.Visible
|
||||||
@@ -130,14 +137,35 @@ Public Class SideAngleUC
|
|||||||
Parameter2aTxBx.Visibility = Windows.Visibility.Visible
|
Parameter2aTxBx.Visibility = Windows.Visibility.Visible
|
||||||
Parameter2bTxBx.Visibility = Windows.Visibility.Visible
|
Parameter2bTxBx.Visibility = Windows.Visibility.Visible
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' Affondamento
|
' Affondamento
|
||||||
Parameter3TxBl.Visibility = Windows.Visibility.Visible
|
Parameter3TxBl.Visibility = Windows.Visibility.Visible
|
||||||
Parameter3TxBx.Visibility = Windows.Visibility.Visible
|
Parameter3TxBx.Visibility = Windows.Visibility.Visible
|
||||||
|
|
||||||
' Accorciamento
|
' Accorciamento
|
||||||
|
If m_Mode = ModeOpt.ENGRAVE Then
|
||||||
|
' modifico il nome del messaggio
|
||||||
|
Parameter4TxBl.Text = EgtMsg(MSG_IMPORTPAGEUC + 11) & "2" ' Affondamento2
|
||||||
|
Parameter4TxBl.Visibility = Windows.Visibility.Visible
|
||||||
|
Parameter4TxBx.Visibility = Windows.Visibility.Visible
|
||||||
|
Else
|
||||||
Parameter4TxBl.Visibility = Windows.Visibility.Hidden
|
Parameter4TxBl.Visibility = Windows.Visibility.Hidden
|
||||||
Parameter4TxBx.Visibility = Windows.Visibility.Hidden
|
Parameter4TxBx.Visibility = Windows.Visibility.Hidden
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' Angolo
|
||||||
|
If m_Mode = ModeOpt.ENGRAVE Then
|
||||||
|
' modifico il nome del messaggio
|
||||||
|
Parameter5TxBl.Text = EgtMsg(MSG_IMPORTPAGEUC + 9) ' Angolo
|
||||||
|
Parameter5TxBl.Visibility = Windows.Visibility.Visible
|
||||||
|
Parameter5TxBx.Visibility = Windows.Visibility.Visible
|
||||||
|
Else
|
||||||
|
Parameter5TxBl.Visibility = Windows.Visibility.Hidden
|
||||||
|
Parameter5TxBx.Visibility = Windows.Visibility.Hidden
|
||||||
|
End If
|
||||||
|
|
||||||
|
End If
|
||||||
|
|
||||||
' Gestisco Checkbox e nomi in base al numero di lati inclinabili
|
' Gestisco Checkbox e nomi in base al numero di lati inclinabili
|
||||||
TxBlChBxView()
|
TxBlChBxView()
|
||||||
|
|
||||||
@@ -156,12 +184,14 @@ Public Class SideAngleUC
|
|||||||
m_nEngrNbr2 = GetPrivateProfileInt( S_SIDES, K_ENGRAVENUMBER2, 1, m_MainWindow.GetIniFile())
|
m_nEngrNbr2 = GetPrivateProfileInt( S_SIDES, K_ENGRAVENUMBER2, 1, m_MainWindow.GetIniFile())
|
||||||
m_dDripOffset2 = GetPrivateProfileDouble( S_SIDES, K_ENGRAVEOFFSET2, 0, m_MainWindow.GetIniFile())
|
m_dDripOffset2 = GetPrivateProfileDouble( S_SIDES, K_ENGRAVEOFFSET2, 0, m_MainWindow.GetIniFile())
|
||||||
m_dDripDepth = GetPrivateProfileDouble( S_SIDES, K_ENGRAVEDEPTH, 10, m_MainWindow.GetIniFile())
|
m_dDripDepth = GetPrivateProfileDouble( S_SIDES, K_ENGRAVEDEPTH, 10, m_MainWindow.GetIniFile())
|
||||||
m_dDripShort = GetPrivateProfileDouble( S_SIDES, K_ENGRAVESHORT, 0, m_MainWindow.GetIniFile())
|
m_dEngraveDepth2 = GetPrivateProfileDouble(S_SIDES, K_ENGRAVEDEPTH2, 0, m_MainWindow.GetIniFile())
|
||||||
|
m_dEngraveAngle = GetPrivateProfileDouble(S_SIDES, K_ENGRAVEANGLE, 0, m_MainWindow.GetIniFile())
|
||||||
Parameter1TxBx.Text = LenToString(m_dDripOffset, 3)
|
Parameter1TxBx.Text = LenToString(m_dDripOffset, 3)
|
||||||
Parameter2aTxBx.Text = m_nEngrNbr2.ToString()
|
Parameter2aTxBx.Text = m_nEngrNbr2.ToString()
|
||||||
Parameter2bTxBx.Text = LenToString( m_dDripOffset2, 3)
|
Parameter2bTxBx.Text = LenToString( m_dDripOffset2, 3)
|
||||||
Parameter3TxBx.Text = LenToString( m_dDripDepth, 3)
|
Parameter3TxBx.Text = LenToString( m_dDripDepth, 3)
|
||||||
Parameter4TxBx.Text = LenToString( m_dDripShort, 3)
|
Parameter4TxBx.Text = LenToString(m_dEngraveDepth2, 3)
|
||||||
|
Parameter5TxBx.Text = DoubleToString(m_dEngraveAngle, 3)
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' Aggiorno visualizzazione
|
' Aggiorno visualizzazione
|
||||||
@@ -489,7 +519,9 @@ Public Class SideAngleUC
|
|||||||
WritePrivateProfileString( S_SIDES, K_ENGRAVENUMBER2, m_nEngrNbr2.ToString(), m_MainWindow.GetIniFile())
|
WritePrivateProfileString( S_SIDES, K_ENGRAVENUMBER2, m_nEngrNbr2.ToString(), m_MainWindow.GetIniFile())
|
||||||
WritePrivateProfileString(S_SIDES, K_ENGRAVEOFFSET2, LenToString(m_dDripOffset2, 3), m_MainWindow.GetIniFile())
|
WritePrivateProfileString(S_SIDES, K_ENGRAVEOFFSET2, LenToString(m_dDripOffset2, 3), m_MainWindow.GetIniFile())
|
||||||
WritePrivateProfileString(S_SIDES, K_ENGRAVEDEPTH, LenToString(m_dDripDepth, 3), m_MainWindow.GetIniFile())
|
WritePrivateProfileString(S_SIDES, K_ENGRAVEDEPTH, LenToString(m_dDripDepth, 3), m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_SIDES, K_ENGRAVEDEPTH2, LenToString(m_dEngraveDepth2, 3), m_MainWindow.GetIniFile())
|
||||||
'WritePrivateProfileString( S_SIDES, K_ENGRAVESHORT, DoubleToString( m_dDripShort, 3), m_MainWindow.GetIniFile())
|
'WritePrivateProfileString( S_SIDES, K_ENGRAVESHORT, DoubleToString( m_dDripShort, 3), m_MainWindow.GetIniFile())
|
||||||
|
WritePrivateProfileString(S_SIDES, K_ENGRAVEANGLE, LenToString(m_dEngraveAngle, 3), m_MainWindow.GetIniFile())
|
||||||
End If
|
End If
|
||||||
|
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
@@ -635,7 +667,7 @@ Public Class SideAngleUC
|
|||||||
SideAngle.AddTextToLine(sEntityName, TextLayer, CurrLine, 20, dBBoxRad, True)
|
SideAngle.AddTextToLine(sEntityName, TextLayer, CurrLine, 20, dBBoxRad, True)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
' Funzione che crea le geometrie dei gocciolatoi
|
' Funzione che crea le geometrie dei gocciolatoi (NON UTILIZZATA)
|
||||||
Friend Sub CreateDripGeomOLD(nPartId As Integer)
|
Friend Sub CreateDripGeomOLD(nPartId As Integer)
|
||||||
' Recupero Id layer di contorno esterno
|
' Recupero Id layer di contorno esterno
|
||||||
Dim nOutLoopId = EgtGetFirstNameInGroup(nPartId, NAME_OUTLOOP)
|
Dim nOutLoopId = EgtGetFirstNameInGroup(nPartId, NAME_OUTLOOP)
|
||||||
@@ -830,6 +862,9 @@ Public Class SideAngleUC
|
|||||||
Dim nCrvId = EgtGetFirstInGroup(DripLayer)
|
Dim nCrvId = EgtGetFirstInGroup(DripLayer)
|
||||||
While nCrvId <> GDB_ID.NULL
|
While nCrvId <> GDB_ID.NULL
|
||||||
EgtOffsetCurve(nCrvId, -m_dDripOffset, OFF_TYPE.EXTEND)
|
EgtOffsetCurve(nCrvId, -m_dDripOffset, OFF_TYPE.EXTEND)
|
||||||
|
If m_Mode = ModeOpt.ENGRAVE Then
|
||||||
|
EgtSetInfo(nCrvId, INFO_DEPTH, m_dDripDepth)
|
||||||
|
End If
|
||||||
nCrvId = EgtGetNext(nCrvId)
|
nCrvId = EgtGetNext(nCrvId)
|
||||||
End While
|
End While
|
||||||
' Eventuali curve aggiuntive con offset2
|
' Eventuali curve aggiuntive con offset2
|
||||||
@@ -840,10 +875,16 @@ Public Class SideAngleUC
|
|||||||
For i As Integer = 1 To m_nEngrNbr2
|
For i As Integer = 1 To m_nEngrNbr2
|
||||||
Dim nNewId As Integer = EgtCopy(nCrvId, nCrvId, GDB_POS.AFTER)
|
Dim nNewId As Integer = EgtCopy(nCrvId, nCrvId, GDB_POS.AFTER)
|
||||||
EgtOffsetCurve(nNewId, -i * m_dDripOffset2, OFF_TYPE.EXTEND)
|
EgtOffsetCurve(nNewId, -i * m_dDripOffset2, OFF_TYPE.EXTEND)
|
||||||
|
If m_Mode = ModeOpt.ENGRAVE Then
|
||||||
|
EgtSetInfo(nNewId, INFO_DEPTH, m_dEngraveDepth2)
|
||||||
|
End If
|
||||||
Next
|
Next
|
||||||
nCrvId = nNextCrvId
|
nCrvId = nNextCrvId
|
||||||
End While
|
End While
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
Dim ListEngraveSideAng As New List(Of Integer)
|
||||||
|
|
||||||
If m_Mode = ModeOpt.DRIP Then
|
If m_Mode = ModeOpt.DRIP Then
|
||||||
' Esplodo nelle curve componenti
|
' Esplodo nelle curve componenti
|
||||||
nCrvId = EgtGetFirstInGroup(DripLayer)
|
nCrvId = EgtGetFirstInGroup(DripLayer)
|
||||||
@@ -863,14 +904,70 @@ Public Class SideAngleUC
|
|||||||
End While
|
End While
|
||||||
Else
|
Else
|
||||||
' Assegno colore e attributi
|
' Assegno colore e attributi
|
||||||
|
Dim nInd As Integer = 0
|
||||||
nCrvId = EgtGetFirstInGroup(DripLayer)
|
nCrvId = EgtGetFirstInGroup(DripLayer)
|
||||||
While nCrvId <> GDB_ID.NULL
|
While nCrvId <> GDB_ID.NULL
|
||||||
EgtSetColor(nCrvId, COL_MCH_DRIPCUT())
|
EgtSetColor(nCrvId, COL_MCH_DRIPCUT())
|
||||||
EgtSetInfo(nCrvId, INFO_DEPTH, m_dDripDepth)
|
'EgtSetInfo(nCrvId, INFO_DEPTH, m_dDripDepth)
|
||||||
EgtSetInfo(nCrvId, INFO_STRICT, If(m_dDripShort > EPS_SMALL, "3", "0"))
|
EgtSetInfo(nCrvId, INFO_STRICT, If(m_dDripShort > EPS_SMALL, "3", "0"))
|
||||||
|
If nInd = 0 Then
|
||||||
|
' solo se m_dEngraveAngle > 0
|
||||||
|
If Math.Abs(m_dEngraveAngle) > EPS_ANG_SMALL Then
|
||||||
|
' salvo l'Id della curva che deve essere manipolato separatamente
|
||||||
|
ListEngraveSideAng.Add(nCrvId)
|
||||||
|
Else
|
||||||
|
EgtRemoveInfo(nCrvId, INFO_SIDE_ANGLE)
|
||||||
|
EgtModifyCurveThickness(nCrvId, -m_dEngraveDepth2)
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
If nInd = m_nEngrNbr2 Then
|
||||||
|
nInd = -1
|
||||||
|
End If
|
||||||
|
EgtModifyCurveThickness(nCrvId, -m_dEngraveDepth2)
|
||||||
|
End If
|
||||||
|
nInd = nInd + 1
|
||||||
|
If nInd > m_nEngrNbr2 Then nInd = 0
|
||||||
nCrvId = EgtGetNext(nCrvId)
|
nCrvId = EgtGetNext(nCrvId)
|
||||||
End While
|
End While
|
||||||
End If
|
End If
|
||||||
|
SplitJointedSideEngrave(ListEngraveSideAng)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SplitJointedSideEngrave(ListEngraveSideAngId As List(Of Integer))
|
||||||
|
For Each nCrvId As Integer In ListEngraveSideAngId
|
||||||
|
' eventualmente separo il taglio inclinato
|
||||||
|
Dim dUs, dUe As Double
|
||||||
|
EgtCurveDomain(nCrvId, dUs, dUe)
|
||||||
|
Dim dU As Double = dUs
|
||||||
|
While dU < dUe ' + EPS_ZERO
|
||||||
|
Dim ptCurr As Point3d
|
||||||
|
EgtAtParamPoint(nCrvId, dU + 1, nCrvId, ptCurr)
|
||||||
|
' separa la curva in questo punto
|
||||||
|
Dim nNewCurvId As Integer = GDB_ID.NULL
|
||||||
|
If dUe > 1 Then
|
||||||
|
nNewCurvId = EgtSplitCurveAtPoint(nCrvId, ptCurr, GDB_RT.LOC)
|
||||||
|
Else
|
||||||
|
nNewCurvId = nCrvId
|
||||||
|
End If
|
||||||
|
EgtSetColor(nCrvId, COL_MCH_ONENGRAVE_ANG())
|
||||||
|
EgtSetInfo(nCrvId, INFO_SIDE_ANGLE, m_dEngraveAngle)
|
||||||
|
' recupero il vettore di estrusione della curva e la direzione della curva
|
||||||
|
Dim vtAux As Vector3d
|
||||||
|
EgtStartVector(nCrvId, vtAux)
|
||||||
|
Dim vtExtrusion As Vector3d
|
||||||
|
EgtCurveExtrusion(nCrvId, vtExtrusion)
|
||||||
|
' ruoto il vetottore nella nuova direzione
|
||||||
|
vtExtrusion.Rotate(vtAux, -m_dEngraveAngle)
|
||||||
|
' assegno il vettore di estrusione nella nuova direzione indicata (segno negativo perchè dentro il pezzo)
|
||||||
|
EgtModifyCurveExtrusion(nCrvId, vtExtrusion)
|
||||||
|
Dim ExtendFactor As Double = New Vector3d(0, 0, 1) * vtExtrusion
|
||||||
|
EgtModifyCurveThickness(nCrvId, -m_dDripDepth / ExtendFactor)
|
||||||
|
If dUe = 1 Then Exit While
|
||||||
|
nCrvId = nNewCurvId
|
||||||
|
' aggiorno i valori del dominio della curva che rimane
|
||||||
|
EgtCurveDomain(nCrvId, dUs, dUe)
|
||||||
|
End While
|
||||||
|
Next
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub PrevBtn_Click(sender As Object, e As RoutedEventArgs) Handles PrevBtn.Click
|
Private Sub PrevBtn_Click(sender As Object, e As RoutedEventArgs) Handles PrevBtn.Click
|
||||||
@@ -1304,11 +1401,25 @@ Public Class SideAngleUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub Parameter4TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter4TxBx.EgtClosed
|
Private Sub Parameter4TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter4TxBx.EgtClosed
|
||||||
If m_Mode = ModeOpt.DRIP Or m_Mode = ModeOpt.ENGRAVE Then
|
If m_Mode = ModeOpt.DRIP Then
|
||||||
' Recupero il valore
|
' Recupero il valore
|
||||||
StringToLen(Parameter4TxBx.Text, m_dDripShort)
|
StringToLen(Parameter4TxBx.Text, m_dDripShort)
|
||||||
' Creo le geometrie dei gocciolatoi
|
' Creo le geometrie dei gocciolatoi
|
||||||
RefreshSideAngleText()
|
RefreshSideAngleText()
|
||||||
|
ElseIf m_Mode = ModeOpt.ENGRAVE Then
|
||||||
|
' Recupero il valore
|
||||||
|
StringToLen(Parameter4TxBx.Text, m_dEngraveDepth2)
|
||||||
|
' Creo le geometrie dei gocciolatoi
|
||||||
|
RefreshSideAngleText()
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub Parameter5TxBx_EgtClosed(sender As Object, e As EventArgs) Handles Parameter5TxBx.EgtClosed
|
||||||
|
If m_Mode = ModeOpt.ENGRAVE Then
|
||||||
|
' Recupero il valore
|
||||||
|
StringToDouble(Parameter5TxBx.Text, m_dEngraveAngle)
|
||||||
|
' Creo le geometrie dei gocciolatoi
|
||||||
|
RefreshSideAngleText()
|
||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
|||||||
@@ -1,16 +1,48 @@
|
|||||||
<ResourceDictionary
|
<ResourceDictionary x:Class="EgtDictionary"
|
||||||
x:Class="EgtDictionary"
|
|
||||||
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:Project="clr-namespace:OmagCUT"
|
xmlns:Project="clr-namespace:OmagCUT"
|
||||||
|
xmlns:EgtWPFLib5="clr-namespace:EgtWPFLib5;assembly=EgtWPFLib5"
|
||||||
|
xmlns:EgtPHOTOLib="clr-namespace:EgtPHOTOLib;assembly=EgtPHOTOLib"
|
||||||
|
xmlns:EgtFloating="clr-namespace:EgtWPFLib5.EgtFloating;assembly=EgtWPFLib5"
|
||||||
xmlns:ControlExtensions="clr-namespace:OmagCUT.ControlExtensions">
|
xmlns:ControlExtensions="clr-namespace:OmagCUT.ControlExtensions">
|
||||||
|
|
||||||
|
<EgtWPFLib5:StatusBarVM x:Key="StatusBarVM"/>
|
||||||
|
<EgtWPFLib5:ShowPanelVM x:Key="ShowPanelVM"/>
|
||||||
|
<EgtWPFLib5:ViewPanelVM x:Key="ViewPanelVM"/>
|
||||||
|
<EgtWPFLib5:InstrumentPanelVM x:Key="InstrumentPanelVM"/>
|
||||||
|
|
||||||
|
<EgtPHOTOLib:ProjectSlabVM x:Key="ProjectSlabVM"/>
|
||||||
|
<EgtPHOTOLib:OptionPanelSlabVM x:Key="OptionPanelSlabVM"/>
|
||||||
|
<EgtPHOTOLib:ListPageSlabVM x:Key="ListPageSlabVM"/>
|
||||||
|
<EgtPHOTOLib:DetailPageSlabVM x:Key="DetailPageSlabVM"/>
|
||||||
|
<EgtPHOTOLib:SearchPanelSlabVM x:Key="SearchPanelSlabVM"/>
|
||||||
|
<EgtPHOTOLib:MyInstrumentPanelSlabVM x:Key="MyInstrumentPanelSlabVM"/>
|
||||||
|
|
||||||
|
<!--Colori predefiniti-->
|
||||||
|
<SolidColorBrush x:Key="Omag_Blue" Color="#FF095CA8" />
|
||||||
|
<SolidColorBrush x:Key="Omag_Yellow" Color="#FFFFCE5B" />
|
||||||
|
<SolidColorBrush x:Key="Omag_Red" Color="Red" />
|
||||||
|
<SolidColorBrush x:Key="Omag_Green" Color="LawnGreen" />
|
||||||
|
<SolidColorBrush x:Key="Omag_VeryLightGray" Color="#FFF2F2F2" />
|
||||||
|
<SolidColorBrush x:Key="Omag_LightGray" Color="LightGray" />
|
||||||
|
<SolidColorBrush x:Key="Omag_Gray" Color="#FF9E9E9E" />
|
||||||
|
<SolidColorBrush x:Key="Omag_DarkGray" Color="#FF444444" />
|
||||||
|
<SolidColorBrush x:Key="Omag_White" Color="#FFFFFFFF" />
|
||||||
|
<SolidColorBrush x:Key="Omag_Black" Color="#FF000000" />
|
||||||
|
|
||||||
|
<SolidColorBrush x:Key="EgaltechBlue1" Color="#FF095CA8" />
|
||||||
|
<SolidColorBrush x:Key="EgaltechWhite" Color="#FFFFFFFF" />
|
||||||
|
|
||||||
<!--Template che permette di andare a capo-->
|
<!--Template che permette di andare a capo-->
|
||||||
<DataTemplate x:Key="Button_DataTemplate_Wrap">
|
<DataTemplate x:Key="Button_DataTemplate_Wrap">
|
||||||
<TextBlock TextWrapping="Wrap" Text="{Binding}"/>
|
<TextBlock TextWrapping="Wrap" Text="{Binding}"/>
|
||||||
</DataTemplate>
|
</DataTemplate>
|
||||||
|
|
||||||
<!--ButtonBase-->
|
<!-- ______________________________________________________________________________________________________________________________________________ -->
|
||||||
|
|
||||||
|
<!-- Button Style -->
|
||||||
|
|
||||||
<Style TargetType="{x:Type Button}">
|
<Style TargetType="{x:Type Button}">
|
||||||
<Setter Property="FocusVisualStyle">
|
<Setter Property="FocusVisualStyle">
|
||||||
<Setter.Value>
|
<Setter.Value>
|
||||||
@@ -71,6 +103,43 @@
|
|||||||
</Setter>
|
</Setter>
|
||||||
</Style>
|
</Style>
|
||||||
|
|
||||||
|
<!--Template che permette di andare a capo-->
|
||||||
|
<DataTemplate x:Key="WrapButton_DataTemplate">
|
||||||
|
<TextBlock TextWrapping="WrapWithOverflow" Text="{Binding}"/>
|
||||||
|
</DataTemplate>
|
||||||
|
|
||||||
|
<Style x:Key="ToolBar_Button" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
<Setter Property="Width" Value="30"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="ToolBar_TextButton" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
<Setter Property="Width" Value="80"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="OptionPanel_Button" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="60"/>
|
||||||
|
<Setter Property="Width" Value="60"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="OptionPanel_TextButton" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="OptionPanel_TextWrapButton" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="ContentTemplate" Value="{StaticResource WrapButton_DataTemplate}" />
|
||||||
|
<Setter Property="TextBlock.TextAlignment" Value="Center"/>
|
||||||
|
<Setter Property="Height" Value="45"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="OptionPanel_NestingButton" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="60"/>
|
||||||
|
<Setter Property="Width" Value="60"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="CompoWindow_Button" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="40"/>
|
||||||
|
</Style>
|
||||||
|
<Style x:Key="EgtWPFLib5_InputButton" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
<Setter Property="Width" Value="60"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
<!-- ______________________________________________________________________________________________________________________ -->
|
<!-- ______________________________________________________________________________________________________________________ -->
|
||||||
|
|
||||||
<!--Template che permette di andare a capo-->
|
<!--Template che permette di andare a capo-->
|
||||||
@@ -375,6 +444,58 @@
|
|||||||
</Setter>
|
</Setter>
|
||||||
</Style>
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="ToolBar_ToggleButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
<Setter Property="Width" Value="30"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="ToolBar_TextToggleButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
<Setter Property="Width" Value="70"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="OptionPanel_ToggleButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
|
||||||
|
<Setter Property="Height" Value="30"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="OptionPanel_NestingToggleButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
|
||||||
|
<Setter Property="Height" Value="60"/>
|
||||||
|
<Setter Property="Width" Value="60"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="CompoWindow_ToggleButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
|
||||||
|
<Setter Property="Height" Value="40"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="CompoWindow_WrapToggleButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
|
||||||
|
<Setter Property="ContentTemplate" Value="{StaticResource WrapButton_DataTemplate}" />
|
||||||
|
<Setter Property="TextBlock.TextAlignment" Value="Center" />
|
||||||
|
<Setter Property="Height" Value="40"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="Option_ColorButton" TargetType="{x:Type Button}" BasedOn="{StaticResource {x:Type Button}}">
|
||||||
|
<Setter Property="Padding" Value="5"/>
|
||||||
|
<Setter Property="HorizontalContentAlignment" Value="Center"/>
|
||||||
|
<Setter Property="VerticalContentAlignment" Value="Center"/>
|
||||||
|
<Setter Property="TextBlock.TextAlignment" Value="Center"/>
|
||||||
|
<Style.Triggers>
|
||||||
|
<Trigger Property="IsMouseOver" Value="True">
|
||||||
|
<Setter Property="Background" Value="#FFB8C3CD"/>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="IsPressed" Value="True">
|
||||||
|
<Setter Property="OpacityMask" Value="#33FF0000"/>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="ToggleButton.IsChecked" Value="True">
|
||||||
|
<Setter Property="Background" Value="Transparent"/>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="IsEnabled" Value="False">
|
||||||
|
<Setter Property="Background" Value="#FFF4F4F4"/>
|
||||||
|
<Setter Property="BorderBrush" Value="#FFADB2B5"/>
|
||||||
|
<Setter Property="TextElement.Foreground" Value="#FF838383"/>
|
||||||
|
</Trigger>
|
||||||
|
</Style.Triggers>
|
||||||
|
</Style>
|
||||||
|
|
||||||
<!-- ______________________________________________________________________________________________________________________ -->
|
<!-- ______________________________________________________________________________________________________________________ -->
|
||||||
|
|
||||||
<!--TreeViewBase-->
|
<!--TreeViewBase-->
|
||||||
@@ -431,6 +552,32 @@
|
|||||||
</Setter>
|
</Setter>
|
||||||
</Style>
|
</Style>
|
||||||
|
|
||||||
|
<!-- ______________________________________________________________________________________________________________________________________________ -->
|
||||||
|
|
||||||
|
<!-- EgtCustomWindow -->
|
||||||
|
|
||||||
|
<Style TargetType="{x:Type EgtWPFLib5:EgtCustomWindow}" BasedOn="{StaticResource {x:Type EgtWPFLib5:EgtCustomWindow}}">
|
||||||
|
<Setter Property="TitleBarHeight" Value="32"/>
|
||||||
|
<Setter Property="TitleBarBrush" Value="{StaticResource Omag_LightGray}"/>
|
||||||
|
<Setter Property="BorderBrush" Value="{StaticResource Omag_Gray}"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<!-- ______________________________________________________________________________________________________________________________________________ -->
|
||||||
|
|
||||||
|
<!-- EgtFloatingPanel -->
|
||||||
|
|
||||||
|
<Style x:Key="ToolBar_EgtFloatingPanel" TargetType="{x:Type EgtFloating:EgtFloatingPanel}" BasedOn="{StaticResource {x:Type EgtFloating:EgtFloatingPanel}}">
|
||||||
|
<Setter Property="Background" Value="{StaticResource Omag_Gray}"/>
|
||||||
|
<Setter Property="BorderBrush" Value="{StaticResource Omag_Gray}"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<Style x:Key="Option_EgtFloatingPanel" TargetType="{x:Type EgtFloating:EgtFloatingPanel}" BasedOn="{StaticResource {x:Type EgtFloating:EgtFloatingPanel}}">
|
||||||
|
<Setter Property="IsToolBar" Value="False"/>
|
||||||
|
<Setter Property="TitleBarOrientation" Value="Vertical"/>
|
||||||
|
<Setter Property="Background" Value="{StaticResource Omag_Gray}"/>
|
||||||
|
<Setter Property="BorderBrush" Value="{StaticResource Omag_Gray}"/>
|
||||||
|
</Style>
|
||||||
|
|
||||||
<!-- ______________________________________________________________________________________________________________________ -->
|
<!-- ______________________________________________________________________________________________________________________ -->
|
||||||
|
|
||||||
</ResourceDictionary>
|
</ResourceDictionary>
|
||||||
|
|||||||
@@ -75,7 +75,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="AngleCutExtraLenTxBl" Grid.Column="0" Grid.Row="1"
|
<TextBlock Name="AngleCutExtraLenTxBl" Grid.Column="0" Grid.Row="1"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="AngleCutExtraLenTxBx" Grid.Column="1" Grid.Row="1" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="AngleCutExtraLenTxBx" Grid.Column="1" Grid.Row="1" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<TextBlock Name="ExtArcMinRadTxBl" Grid.Column="0" Grid.Row="2"
|
<TextBlock Name="ExtArcMinRadTxBl" Grid.Column="0" Grid.Row="2"
|
||||||
@@ -85,7 +85,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="IntArcMaxSideAngTxBl" Grid.Column="0" Grid.Row="3"
|
<TextBlock Name="IntArcMaxSideAngTxBl" Grid.Column="0" Grid.Row="3"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="IntArcMaxSideAngTxBx" Grid.Column="1" Grid.Row="3" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="IntArcMaxSideAngTxBx" Grid.Column="1" Grid.Row="3" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
|
||||||
<TextBlock Name="PreCutExitTxBl" Grid.Column="0" Grid.Row="4"
|
<TextBlock Name="PreCutExitTxBl" Grid.Column="0" Grid.Row="4"
|
||||||
@@ -184,22 +184,48 @@
|
|||||||
|
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
|
|
||||||
<!--Parametri WaterJet: 1 Parametro (se questo GroupBox attivo allora nascondo Fori/Fresatura)-->
|
<!--Parametri WaterJet: 5 Parametro (se questo GroupBox attivo allora nascondo Fori/Fresatura)-->
|
||||||
<GroupBox Name="WjsParamGpBx" Grid.Column="0" Grid.Row="0" Grid.ColumnSpan="2" Grid.RowSpan="1"
|
<GroupBox Name="WjsParamGpBx" Grid.Column="0" Grid.Row="0" Grid.ColumnSpan="2" Grid.RowSpan="4"
|
||||||
Style="{DynamicResource OmagCut_GroupBox}">
|
Style="{DynamicResource OmagCut_GroupBox}">
|
||||||
<Grid Grid.Column="3" Grid.Row="2">
|
<Grid Grid.Column="3" Grid.Row="2">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="2*"/>
|
<ColumnDefinition Width="145*"/>
|
||||||
<ColumnDefinition Width="2*"/>
|
<ColumnDefinition Width="23*"/>
|
||||||
|
<ColumnDefinition Width="169*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="*"/>
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<TextBlock Name="WjIntCutsTxBl" Grid.Row="1" Grid.ColumnSpan="2"
|
<TextBlock Name="WjIntCutsTxBl" Grid.Column="0" Grid.Row="0" Grid.ColumnSpan="3"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Margin="10,0,0,10" VerticalAlignment="Bottom" />
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Margin="10,0,10,0" />
|
||||||
<CheckBox Name="WjIntCutsChBx" Grid.Row="1" Grid.ColumnSpan="2" Style="{StaticResource OmagCut_CheckBox_Single}"
|
<CheckBox Name="WjIntCutsChBx" Grid.Column="2" Grid.Row="0" Style="{StaticResource OmagCut_CheckBox_Single}"
|
||||||
HorizontalAlignment="Right" Margin="0,0,10,0"/>
|
HorizontalAlignment="Right" Margin="10,0,10,0"/>
|
||||||
|
|
||||||
|
<TextBlock Name="HolesDiameterWJTxBl" Grid.Column="0" Grid.Row="1"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Grid.ColumnSpan="2" Margin="10,0,10,0"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="HolesDiameterWJTxBx" Grid.Column="2" Grid.Row="1" Margin="10,0,10,0"
|
||||||
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
|
<TextBlock Name="HolesOffsetWJTxBl" Grid.Column="0" Grid.Row="2"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Grid.ColumnSpan="2" Margin="10,0,10,0"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="HolesOffsetWJTxBx" Grid.Column="2" Grid.Row="2" Margin="10,0,10,0"
|
||||||
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
|
<TextBlock Name="MinRadiusWJTxBl" Grid.Column="0" Grid.Row="3"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Grid.ColumnSpan="2" Margin="10,0,10,0"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="MinRadiusWJTxBx" Grid.Column="2" Grid.Row="3" Margin="10,0,10,0"
|
||||||
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
|
<TextBlock Name="OneHoleInCornerWJTxBl" Grid.Column="0" Grid.Row="4" Grid.ColumnSpan="3"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Margin="10,0,10,0" />
|
||||||
|
<CheckBox Name="OneHoleInCornerWJChBx" Grid.Column="2" Grid.Row="4" Style="{StaticResource OmagCut_CheckBox_Single}"
|
||||||
|
HorizontalAlignment="Right" Margin="10,0,10,0"/>
|
||||||
|
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
@@ -712,7 +738,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
<TextBlock Name="CfrPercTxBl" Grid.Column="0" Grid.Row="1"
|
<TextBlock Name="CfrPercTxBl" Grid.Column="0" Grid.Row="1"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="CfrPercTxBx" Grid.Column="1" Grid.Row="1" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CfrPercTxBx" Grid.Column="1" Grid.Row="1" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
@@ -801,19 +827,23 @@
|
|||||||
<Grid Grid.Column="0" Grid.Row="8">
|
<Grid Grid.Column="0" Grid.Row="8">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="2.5*"/>
|
<ColumnDefinition Width="2.5*"/>
|
||||||
<ColumnDefinition Width="5*"/>
|
<ColumnDefinition Width="2.5*"/>
|
||||||
<ColumnDefinition Width="2*"/>
|
<ColumnDefinition Width="4.5*"/>
|
||||||
|
<ColumnDefinition Width="1.8*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Button x:Name="SawProbingBtn"
|
<Button x:Name="SawProbingBtn"
|
||||||
Style="{DynamicResource OmagCut_YellowGradientYellowIconButton}">
|
Style="{DynamicResource OmagCut_YellowGradientYellowIconButton}">
|
||||||
<Image Source="{DynamicResource SawProbeImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>
|
<Image Source="{DynamicResource SawProbeImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>
|
||||||
</Button>
|
</Button>
|
||||||
|
<Button x:Name="ExecLuaBtn" Grid.Column="1"
|
||||||
|
Style="{DynamicResource OmagCut_YellowGradientYellowIconButton}">
|
||||||
|
<Image Source="{DynamicResource PlayImg}" Style="{StaticResource OmagCut_ScaleButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<TextBlock Name="UseLaserOriginTxBl" Grid.Column="2"
|
||||||
<TextBlock Name="UseLaserOriginTxBl" Grid.Column="1"
|
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" />
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" />
|
||||||
<CheckBox Name="UseLaserOriginChBx" Style="{DynamicResource OmagCut_CheckBox_Single}" Grid.Column="2"
|
<CheckBox Name="UseLaserOriginChBx" Style="{DynamicResource OmagCut_CheckBox_Single}" Grid.Column="3"
|
||||||
HorizontalAlignment="Right" Margin="10,0,10,0"/>
|
HorizontalAlignment="Right" Margin="0,0,10,0"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -37,14 +37,24 @@ Public Class AlarmsPageUC
|
|||||||
CurrWJetCmBx.ItemsSource = m_WaterJetList
|
CurrWJetCmBx.ItemsSource = m_WaterJetList
|
||||||
AuxiliaryToolCmBx.ItemsSource = m_AuxToolTypeList
|
AuxiliaryToolCmBx.ItemsSource = m_AuxToolTypeList
|
||||||
|
|
||||||
|
' Variabile che accorcia il riferimento alla macchina corrente
|
||||||
|
m_CurrentMachine = m_MainWindow.m_CurrentMachine
|
||||||
|
|
||||||
' Assegno lista ad elenco materiali
|
' Assegno lista ad elenco materiali
|
||||||
MaterialsLstBx.ItemsSource = m_MainWindow.m_CurrentMachine.Materials
|
MaterialsLstBx.ItemsSource = m_CurrentMachine.Materials
|
||||||
|
|
||||||
' Se non è impostato il controllo numerico, nascondo il bottone di tastatura lama
|
' Se non è impostato il controllo numerico, nascondo il bottone di tastatura lama
|
||||||
If GetPrivateProfileInt(S_NUMERICALCONTROL, K_TYPE, 0, m_MainWindow.GetMachIniFile()) = 0 Then
|
If GetPrivateProfileInt(S_NUMERICALCONTROL, K_TYPE, 0, m_MainWindow.GetMachIniFile()) = 0 Then
|
||||||
SawProbingBtn.Visibility = Windows.Visibility.Hidden
|
SawProbingBtn.Visibility = Windows.Visibility.Hidden
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' Se esiste un file lua valido allora mostro il pulsante per l'esecuzione dello script
|
||||||
|
If Not String.IsNullOrEmpty(GetExecLuaFile()) And
|
||||||
|
ExecLuaBtn.Visibility = Visibility.Visible Then
|
||||||
|
Else
|
||||||
|
ExecLuaBtn.Visibility = Visibility.Hidden
|
||||||
|
End If
|
||||||
|
|
||||||
' Imposto i messaggi letti dal file dei messaggi
|
' Imposto i messaggi letti dal file dei messaggi
|
||||||
CurrSawTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 1)
|
CurrSawTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 1)
|
||||||
AuxiliaryToolTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 2)
|
AuxiliaryToolTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 2)
|
||||||
@@ -82,6 +92,12 @@ Public Class AlarmsPageUC
|
|||||||
TmWidthTxBl.Text = EgtMsg( 91064) ' Larghezza
|
TmWidthTxBl.Text = EgtMsg( 91064) ' Larghezza
|
||||||
WJsParamGpBx.Header = EgtMsg( 91058) ' Parametri waterjet
|
WJsParamGpBx.Header = EgtMsg( 91058) ' Parametri waterjet
|
||||||
WjIntCutsTxBl.Text = EgtMsg(90930) ' Sempre sugli interni
|
WjIntCutsTxBl.Text = EgtMsg(90930) ' Sempre sugli interni
|
||||||
|
'-- INIZIO -- nuovi parametri per preforo lavello
|
||||||
|
HolesDiameterWJTxBl.Text = "Diameter"
|
||||||
|
HolesOffsetWJTxBl.Text = "Offset"
|
||||||
|
MinRadiusWJTxBl.Text = "Min Radius"
|
||||||
|
OneHoleInCornerWJTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 26)
|
||||||
|
'-- FINE -- nuovi parametri per preforo lavello
|
||||||
NestingParamGpBx.Header = EgtMsg(MSG_ALARMSPAGEUC + 31) ' Nesting
|
NestingParamGpBx.Header = EgtMsg(MSG_ALARMSPAGEUC + 31) ' Nesting
|
||||||
AlignTxBl.Text = EgtMsg(90932) ' Allineato
|
AlignTxBl.Text = EgtMsg(90932) ' Allineato
|
||||||
GhigliottinaTxBl.Text = EgtMsg(91066) ' Ghigliottina
|
GhigliottinaTxBl.Text = EgtMsg(91066) ' Ghigliottina
|
||||||
@@ -116,8 +132,6 @@ Public Class AlarmsPageUC
|
|||||||
Private Sub AlarmsPage_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
Private Sub AlarmsPage_Loaded(sender As Object, e As RoutedEventArgs) Handles Me.Loaded
|
||||||
|
|
||||||
If m_bFirst Then
|
If m_bFirst Then
|
||||||
' Variabile che accorcia il riferimento alla macchina corrente
|
|
||||||
m_CurrentMachine = m_MainWindow.m_CurrentMachine
|
|
||||||
|
|
||||||
' in assenza dell'uscita H1 nascondo i parametri lama
|
' in assenza dell'uscita H1 nascondo i parametri lama
|
||||||
If EgtGetHeadId("H1") = GDB_ID.NULL Then
|
If EgtGetHeadId("H1") = GDB_ID.NULL Then
|
||||||
@@ -331,6 +345,16 @@ Public Class AlarmsPageUC
|
|||||||
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_MILLING_ON_SINKS, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_MILLING_ON_SINKS, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
WjIntCutsChBx.IsChecked =
|
WjIntCutsChBx.IsChecked =
|
||||||
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_MILLING_ON_SINKS, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_MILLING_ON_SINKS, 0, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
|
' Lavorazione preforo lavello con WaterJet
|
||||||
|
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_HOLES_DIAMITERWJ, 0, m_MainWindow.GetMachIniFile())
|
||||||
|
HolesDiameterWJTxBx.Text = LenToString(dVal, 2)
|
||||||
|
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_HOLES_OFFSETWJ, 0, m_MainWindow.GetMachIniFile())
|
||||||
|
HolesOffsetWJTxBx.Text = LenToString(dVal, 2)
|
||||||
|
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_MIN_RADIUSWJ, 0, m_MainWindow.GetMachIniFile())
|
||||||
|
MinRadiusWJTxBx.Text = LenToString(dVal, 2)
|
||||||
|
OneHoleInCornerWJChBx.IsChecked =
|
||||||
|
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_DRILLINGWJ_ON_CORNERS, 1, m_MainWindow.GetMachIniFile()) <> 0)
|
||||||
|
|
||||||
' Leggo accorciamento angoli con fresa
|
' Leggo accorciamento angoli con fresa
|
||||||
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_MACH_MILLING_SHORTENING, 0, m_MainWindow.GetMachIniFile())
|
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_MACH_MILLING_SHORTENING, 0, m_MainWindow.GetMachIniFile())
|
||||||
ShortTxBx.Text = LenToString(dVal, 2)
|
ShortTxBx.Text = LenToString(dVal, 2)
|
||||||
@@ -343,7 +367,7 @@ Public Class AlarmsPageUC
|
|||||||
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_MACH_ENGRAVING_WIDTH, 0, m_MainWindow.GetMachIniFile())
|
dVal = GetPrivateProfileDouble(S_MACH_NEST, K_MACH_ENGRAVING_WIDTH, 0, m_MainWindow.GetMachIniFile())
|
||||||
TmWidthTxBx.Text = LenToString(dVal, 2)
|
TmWidthTxBx.Text = LenToString(dVal, 2)
|
||||||
' Flag per movimento in home alla fine dei tagli diretti
|
' Flag per movimento in home alla fine dei tagli diretti
|
||||||
FinalHomeChBx.IsChecked = m_MainWindow.m_CurrentMachine.bDirectCutsFinalHome
|
FinalHomeChBx.IsChecked = m_CurrentMachine.bDirectCutsFinalHome
|
||||||
' Leggo tagli ridotti per interferenza in nesting
|
' Leggo tagli ridotti per interferenza in nesting
|
||||||
CompleteCutsChBx.IsChecked =
|
CompleteCutsChBx.IsChecked =
|
||||||
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_REDUCEDCUT, 0, m_MainWindow.GetMachIniFile()) = 0)
|
(GetPrivateProfileInt(S_MACH_NEST, K_MACH_REDUCEDCUT, 0, m_MainWindow.GetMachIniFile()) = 0)
|
||||||
@@ -365,7 +389,7 @@ Public Class AlarmsPageUC
|
|||||||
AdditionalTableTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 36) & " " & GetCurrentTable().ToString()
|
AdditionalTableTxBl.Text = EgtMsg(MSG_ALARMSPAGEUC + 36) & " " & GetCurrentTable().ToString()
|
||||||
End If
|
End If
|
||||||
' Leggo altezza sovratavola
|
' Leggo altezza sovratavola
|
||||||
dVal = m_MainWindow.m_CurrentMachine.dAdditionalTable
|
dVal = m_CurrentMachine.dAdditionalTable
|
||||||
AdditionalTableTxBx.Text = LenToString(dVal, 2)
|
AdditionalTableTxBx.Text = LenToString(dVal, 2)
|
||||||
' Leggo soglia e tolleranza per contorno grezzo da foto
|
' Leggo soglia e tolleranza per contorno grezzo da foto
|
||||||
ThresholdTxBx.Text = m_MainWindow.m_Camera.Threshold.ToString()
|
ThresholdTxBx.Text = m_MainWindow.m_Camera.Threshold.ToString()
|
||||||
@@ -439,7 +463,7 @@ Public Class AlarmsPageUC
|
|||||||
CurrWaterJettingTxBx.Text = m_CurrentMachine.sCurrWaterJetting
|
CurrWaterJettingTxBx.Text = m_CurrentMachine.sCurrWaterJetting
|
||||||
CurrWaterJettingTxBl.Visibility = Windows.Visibility.Visible
|
CurrWaterJettingTxBl.Visibility = Windows.Visibility.Visible
|
||||||
CurrWaterJettingTxBx.Visibility = Windows.Visibility.Visible
|
CurrWaterJettingTxBx.Visibility = Windows.Visibility.Visible
|
||||||
If m_MainWindow.m_CurrentMachine.bFromDBWaterJet Then
|
If m_CurrentMachine.bFromDBWaterJet Then
|
||||||
CurrWaterJettingTxBx.SetValue(Grid.ColumnSpanProperty, 1)
|
CurrWaterJettingTxBx.SetValue(Grid.ColumnSpanProperty, 1)
|
||||||
CurrWaterJettingTxBx.SetValue(MarginProperty, New Thickness(CurrWaterJettingTxBx.Margin.Left,
|
CurrWaterJettingTxBx.SetValue(MarginProperty, New Thickness(CurrWaterJettingTxBx.Margin.Left,
|
||||||
CurrWaterJettingTxBx.Margin.Top,
|
CurrWaterJettingTxBx.Margin.Top,
|
||||||
@@ -578,6 +602,33 @@ Public Class AlarmsPageUC
|
|||||||
String.Compare(sMchTool, m_CurrentMachine.sCurrSaw, True) <> 0 Then
|
String.Compare(sMchTool, m_CurrentMachine.sCurrSaw, True) <> 0 Then
|
||||||
m_CurrentMachine.sCurrSawing = String.Empty
|
m_CurrentMachine.sCurrSawing = String.Empty
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
'Dim sVal As String = String.Empty
|
||||||
|
'Dim dVal As Double = 0
|
||||||
|
'If m_CurrentMachine.GetUserNote("FsevLength", sVal, m_CurrentMachine.sCurrSawing, false) Then
|
||||||
|
' StringToDouble(sVal, dVal)
|
||||||
|
' m_CurrentMachine.SetFsevLength(dVal)
|
||||||
|
'End If
|
||||||
|
'If m_CurrentMachine.GetUserNote("FsevPerc", sVal, m_CurrentMachine.sCurrSawing, false) Then
|
||||||
|
' StringToDouble(sVal, dVal)
|
||||||
|
' m_CurrentMachine.SetFsevPerc(dVal)
|
||||||
|
'End If
|
||||||
|
|
||||||
|
Dim sVal As String = String.Empty
|
||||||
|
Dim dVal As Double = 0
|
||||||
|
If m_CurrentMachine.GetUserNote("FsevLength", sVal, m_CurrentMachine.sCurrSaw) Then
|
||||||
|
StringToDouble(sVal, dVal)
|
||||||
|
m_CurrentMachine.SetFsevLength(dVal)
|
||||||
|
End If
|
||||||
|
If m_CurrentMachine.GetUserNote("FsevPerc", sVal, m_CurrentMachine.sCurrSaw) Then
|
||||||
|
StringToDouble(sVal, dVal)
|
||||||
|
m_CurrentMachine.SetFsevPerc(dVal)
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Leggo parametri per variazione feed in tagli aggiornati in funzione della lama
|
||||||
|
CfrLenTxBx.Text = LenToString(m_CurrentMachine.dFsevLength, 3)
|
||||||
|
CfrPercTxBx.Text = DoubleToString(m_CurrentMachine.dFsevPerc, 0)
|
||||||
|
|
||||||
' Aggiorno utensili per lavoro in corso
|
' Aggiorno utensili per lavoro in corso
|
||||||
m_MainWindow.m_WorkInProgressPageUC.UpdateTools()
|
m_MainWindow.m_WorkInProgressPageUC.UpdateTools()
|
||||||
' aggiorno la lista delle lavorazioni
|
' aggiorno la lista delle lavorazioni
|
||||||
@@ -893,6 +944,35 @@ Public Class AlarmsPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' -- INIZIO -- nuovi parametri per prefori WaterJet
|
||||||
|
Private Sub HolesDiameterWJTxBx_Click(sender As Object, e As EventArgs) Handles HolesDiameterWJTxBx.EgtClosed
|
||||||
|
Dim dVal As Double = 0
|
||||||
|
StringToLen(HolesDiameterWJTxBx.Text, dVal)
|
||||||
|
WritePrivateProfileString(S_MACH_NEST, K_HOLES_DIAMITERWJ, DoubleToString(dVal, 2), m_MainWindow.GetMachIniFile())
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub HolesOffsetWJTxBx_Click(sender As Object, e As EventArgs) Handles HolesOffsetWJTxBx.EgtClosed
|
||||||
|
Dim dVal As Double = 0
|
||||||
|
StringToLen(HolesOffsetWJTxBx.Text, dVal)
|
||||||
|
WritePrivateProfileString(S_MACH_NEST, K_HOLES_OFFSETWJ, DoubleToString(dVal, 2), m_MainWindow.GetMachIniFile())
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub MinRadiusWJTxBx_Click(sender As Object, e As EventArgs) Handles MinRadiusWJTxBx.EgtClosed
|
||||||
|
Dim dVal As Double = 0
|
||||||
|
StringToLen(MinRadiusWJTxBx.Text, dVal)
|
||||||
|
WritePrivateProfileString(S_MACH_NEST, K_MIN_RADIUSWJ, DoubleToString(dVal, 2), m_MainWindow.GetMachIniFile())
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub OneHoleInCornerWJChBx_Click(sender As Object, e As EventArgs) Handles OneHoleInCornerWJChBx.Click
|
||||||
|
If OneHoleInCornerWJChBx.IsChecked() Then
|
||||||
|
WritePrivateProfileString(S_MACH_NEST, K_MACH_DRILLINGWJ_ON_CORNERS, "1", m_MainWindow.GetMachIniFile())
|
||||||
|
Else
|
||||||
|
WritePrivateProfileString(S_MACH_NEST, K_MACH_DRILLINGWJ_ON_CORNERS, "0", m_MainWindow.GetMachIniFile())
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' -- FINE -- nuovi parametri per prefori WaterJet
|
||||||
|
|
||||||
Private Sub TmEnableChBx_Click(sender As Object, e As RoutedEventArgs) Handles TmEnableChBx.Click
|
Private Sub TmEnableChBx_Click(sender As Object, e As RoutedEventArgs) Handles TmEnableChBx.Click
|
||||||
If TmEnableChBx.IsChecked() Then
|
If TmEnableChBx.IsChecked() Then
|
||||||
WritePrivateProfileString(S_MACH_NEST, K_MACH_ENGRAVING_WITHMILL, "1", m_MainWindow.GetMachIniFile())
|
WritePrivateProfileString(S_MACH_NEST, K_MACH_ENGRAVING_WITHMILL, "1", m_MainWindow.GetMachIniFile())
|
||||||
@@ -915,9 +995,9 @@ Public Class AlarmsPageUC
|
|||||||
|
|
||||||
Private Sub FinalHomeChBx_Click(sender As Object, e As RoutedEventArgs) Handles FinalHomeChBx.Click
|
Private Sub FinalHomeChBx_Click(sender As Object, e As RoutedEventArgs) Handles FinalHomeChBx.Click
|
||||||
If FinalHomeChBx.IsChecked() Then
|
If FinalHomeChBx.IsChecked() Then
|
||||||
m_MainWindow.m_CurrentMachine.bDirectCutsFinalHome = True
|
m_CurrentMachine.bDirectCutsFinalHome = True
|
||||||
Else
|
Else
|
||||||
m_MainWindow.m_CurrentMachine.bDirectCutsFinalHome = False
|
m_CurrentMachine.bDirectCutsFinalHome = False
|
||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -959,7 +1039,7 @@ Public Class AlarmsPageUC
|
|||||||
Private Sub AdditionalTableTxBx_EgtClosed(sender As Object, e As EventArgs) Handles AdditionalTableTxBx.EgtClosed
|
Private Sub AdditionalTableTxBx_EgtClosed(sender As Object, e As EventArgs) Handles AdditionalTableTxBx.EgtClosed
|
||||||
Dim dVal As Double = 0
|
Dim dVal As Double = 0
|
||||||
StringToLen(AdditionalTableTxBx.Text, dVal)
|
StringToLen(AdditionalTableTxBx.Text, dVal)
|
||||||
m_MainWindow.m_CurrentMachine.dAdditionalTable = dVal
|
m_CurrentMachine.dAdditionalTable = dVal
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub NewMatBtn_Click(sender As Object, e As RoutedEventArgs) Handles NewMatBtn.Click
|
Private Sub NewMatBtn_Click(sender As Object, e As RoutedEventArgs) Handles NewMatBtn.Click
|
||||||
@@ -1083,9 +1163,13 @@ Public Class AlarmsPageUC
|
|||||||
Case 3
|
Case 3
|
||||||
Dim nResult As Short = m_CN.DGeneralFunctions_WriteCncMode(0)
|
Dim nResult As Short = m_CN.DGeneralFunctions_WriteCncMode(0)
|
||||||
EgtOutLog("Impostata modalità automatica: esito " & nResult.ToString)
|
EgtOutLog("Impostata modalità automatica: esito " & nResult.ToString)
|
||||||
|
Case 4
|
||||||
|
' FANUC - Manual:7, Edit:1
|
||||||
|
Dim nResult As Short = m_CN.DGeneralFunctions_WriteCncMode(7)
|
||||||
|
EgtOutLog("Impostata modalità manuale: esito " & nResult.ToString)
|
||||||
End Select
|
End Select
|
||||||
' Recupero file LUA
|
' Recupero file LUA
|
||||||
EgtLuaExecFile(m_MainWindow.m_CurrentMachine.sMachDir() & "\DirectCmd\SawProbing.lua")
|
EgtLuaExecFile(m_CurrentMachine.sMachDir() & "\DirectCmd\SawProbing.lua")
|
||||||
' Recupero utensile da tastare
|
' Recupero utensile da tastare
|
||||||
Dim ToolForProbing As ToolPos = ChooseToolForProbing()
|
Dim ToolForProbing As ToolPos = ChooseToolForProbing()
|
||||||
If IsNothing(ToolForProbing) OrElse String.IsNullOrWhiteSpace(ToolForProbing.m_ToolName) Then Return
|
If IsNothing(ToolForProbing) OrElse String.IsNullOrWhiteSpace(ToolForProbing.m_ToolName) Then Return
|
||||||
@@ -1124,7 +1208,7 @@ Public Class AlarmsPageUC
|
|||||||
' Modifico stringa per inserire i newline
|
' Modifico stringa per inserire i newline
|
||||||
CmdString = CmdString.Replace("<br/>", Environment.NewLine)
|
CmdString = CmdString.Replace("<br/>", Environment.NewLine)
|
||||||
' Creo file...
|
' Creo file...
|
||||||
Dim FilePath As String = m_MainWindow.GetCncDir() & "\SawProbing" & m_MainWindow.m_CurrentMachine.sIsoFileExt
|
Dim FilePath As String = m_MainWindow.GetCncDir() & "\SawProbing" & m_CurrentMachine.sIsoFileExt
|
||||||
' ...e ci scrivo
|
' ...e ci scrivo
|
||||||
Dim Writer As New IO.StreamWriter(FilePath, False)
|
Dim Writer As New IO.StreamWriter(FilePath, False)
|
||||||
Writer.Write(CmdString)
|
Writer.Write(CmdString)
|
||||||
@@ -1148,6 +1232,11 @@ Public Class AlarmsPageUC
|
|||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
' Se fanuc passo in modalità AUTO e attivo
|
||||||
|
If m_MainWindow.m_CNCommunication.m_nNCType = 4 Then
|
||||||
|
Dim nResult As Short = m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_WriteCncMode(0)
|
||||||
|
EgtOutLog("Impostata modalità automatica: esito " & nResult.ToString)
|
||||||
|
End If
|
||||||
' Aspetto e lo avvio
|
' Aspetto e lo avvio
|
||||||
System.Threading.Thread.Sleep(300)
|
System.Threading.Thread.Sleep(300)
|
||||||
m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_CycleStart()
|
m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_CycleStart()
|
||||||
@@ -1197,6 +1286,10 @@ Public Class AlarmsPageUC
|
|||||||
Dim bRead As Boolean = False
|
Dim bRead As Boolean = False
|
||||||
Dim SawDiameterNameVar As String = String.Empty
|
Dim SawDiameterNameVar As String = String.Empty
|
||||||
GetPrivateProfileString(S_MACH_PROBING, K_SAWDIAMETER, "", SawDiameterNameVar, m_MainWindow.GetMachIniFile())
|
GetPrivateProfileString(S_MACH_PROBING, K_SAWDIAMETER, "", SawDiameterNameVar, m_MainWindow.GetMachIniFile())
|
||||||
|
' Se utensile non lama, allora la variabile in cui leggo il dato potrebbe essere differente
|
||||||
|
If Not ToolForProbing.m_IsSaw Then
|
||||||
|
GetPrivateProfileString(S_MACH_PROBING, K_TOOLLENGTH, SawDiameterNameVar, SawDiameterNameVar, m_MainWindow.GetMachIniFile())
|
||||||
|
End If
|
||||||
m_MainWindow.m_CNCommunication.m_CN.n_DReadELS_handle = 0
|
m_MainWindow.m_CNCommunication.m_CN.n_DReadELS_handle = 0
|
||||||
For I As Integer = 0 To 20
|
For I As Integer = 0 To 20
|
||||||
' Devo rileggere la variabile ad ogni ciclo
|
' Devo rileggere la variabile ad ogni ciclo
|
||||||
@@ -1205,7 +1298,10 @@ Public Class AlarmsPageUC
|
|||||||
If m_MainWindow.m_CNCommunication.m_CN.n_DReadELS_handle = 3 Then
|
If m_MainWindow.m_CNCommunication.m_CN.n_DReadELS_handle = 3 Then
|
||||||
bRead = True
|
bRead = True
|
||||||
Dim dVal As Double = m_MainWindow.m_CNCommunication.m_CN.d_DReadELS_value
|
Dim dVal As Double = m_MainWindow.m_CNCommunication.m_CN.d_DReadELS_value
|
||||||
|
' Se fanuc il dato è in mm (NON MICRON)
|
||||||
|
If m_MainWindow.m_CNCommunication.m_nNCType <> 4 Then
|
||||||
dVal = dVal / 1000
|
dVal = dVal / 1000
|
||||||
|
End If
|
||||||
MsgBoxStateInfo.LoadingPrBr_Value = 100
|
MsgBoxStateInfo.LoadingPrBr_Value = 100
|
||||||
' Tastatura conclusa con successo
|
' Tastatura conclusa con successo
|
||||||
Dim sOut As String = EgtMsg(MSG_DIRECTCUTPAGEUC + 43) & " : " & DoubleToString(dVal, 1)
|
Dim sOut As String = EgtMsg(MSG_DIRECTCUTPAGEUC + 43) & " : " & DoubleToString(dVal, 1)
|
||||||
@@ -1252,9 +1348,9 @@ Public Class AlarmsPageUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Function ChooseToolForProbing() As ToolPos
|
Private Function ChooseToolForProbing() As ToolPos
|
||||||
Select Case m_MainWindow.m_CurrentMachine.MountedToolConfig
|
Select Case m_CurrentMachine.MountedToolConfig
|
||||||
Case CurrentMachine.MountedToolConfigs.SAW
|
Case CurrentMachine.MountedToolConfigs.SAW
|
||||||
Return New ToolPos(m_MainWindow.m_CurrentMachine.sCurrSaw, "T100", True)
|
Return New ToolPos(m_CurrentMachine.sCurrSaw, "T100", True)
|
||||||
Case CurrentMachine.MountedToolConfigs.SAWANDAUXTOOL, CurrentMachine.MountedToolConfigs.MANUALTOOLCHANGER, CurrentMachine.MountedToolConfigs.TOOLCHANGER
|
Case CurrentMachine.MountedToolConfigs.SAWANDAUXTOOL, CurrentMachine.MountedToolConfigs.MANUALTOOLCHANGER, CurrentMachine.MountedToolConfigs.TOOLCHANGER
|
||||||
Dim ChooseTool As New ChooseToolWD(m_MainWindow)
|
Dim ChooseTool As New ChooseToolWD(m_MainWindow)
|
||||||
If ChooseTool.ShowDialog Then
|
If ChooseTool.ShowDialog Then
|
||||||
@@ -1300,4 +1396,36 @@ Public Class AlarmsPageUC
|
|||||||
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ExecLuaBtn_Click(sender As Object, e As RoutedEventArgs) Handles ExecLuaBtn.Click
|
||||||
|
Dim sExecFile As String = GetExecLuaFile()
|
||||||
|
' Eseguo file LUA e recupero risultato
|
||||||
|
Dim nErr As Integer = 999
|
||||||
|
EgtLuaExecFile(sExecFile)
|
||||||
|
EgtLuaGetGlobIntVar("ELS.ERR", nErr)
|
||||||
|
' Reset lua
|
||||||
|
EgtLuaResetGlobVar("ELS")
|
||||||
|
' Verifico condizioni di errore
|
||||||
|
If nErr Then
|
||||||
|
' Errore...
|
||||||
|
EgtOutLog("Error executing file: " & sExecFile & ", ELS.ERR=" & nErr.ToString)
|
||||||
|
' Error executing script
|
||||||
|
Dim MsgBoxError As New EgtMsgBox(m_MainWindow, "", EgtMsg(90259), EgtMsgBox.Buttons.OK, EgtMsgBox.Icons.NULL)
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' Recupero il percorso del file lua da eseguire
|
||||||
|
Private Function GetExecLuaFile() As String
|
||||||
|
Dim sFile As String = String.Empty
|
||||||
|
If GetPrivateProfileString(S_EXECLUA, K_FILESCRIPT_LUA, "", sFile, m_MainWindow.GetMachIniFile()) <> 0 Then
|
||||||
|
' Sistemo nome file
|
||||||
|
sFile = sFile.Trim()
|
||||||
|
If Not sFile.EndsWith(".lua") Then sFile = sFile & ".lua"
|
||||||
|
' Creo path
|
||||||
|
Dim sPath As String = m_CurrentMachine.sMachDir() & "\Scripts\" & sFile
|
||||||
|
If File.Exists(sPath) Then Return sPath
|
||||||
|
End If
|
||||||
|
Return String.Empty
|
||||||
|
End Function
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|||||||
@@ -77,6 +77,9 @@ Public Class CurrentMachine
|
|||||||
Private m_bPolishingWheel As Boolean = False
|
Private m_bPolishingWheel As Boolean = False
|
||||||
Private m_bWaterJet As Boolean = False
|
Private m_bWaterJet As Boolean = False
|
||||||
|
|
||||||
|
' Flag che indica se gesire l'inversione del taglio nei tagli singoli
|
||||||
|
Private m_bEnableInvetrt As Boolean = True
|
||||||
|
|
||||||
' Abilitazione DB WaterJet
|
' Abilitazione DB WaterJet
|
||||||
Private m_bFromDBWaterJet As Boolean = False
|
Private m_bFromDBWaterJet As Boolean = False
|
||||||
|
|
||||||
@@ -609,6 +612,18 @@ Public Class CurrentMachine
|
|||||||
If WritePrivateProfileString(S_MACH_MACH, K_CURRSAWING, value, sMachIniFile) Then
|
If WritePrivateProfileString(S_MACH_MACH, K_CURRSAWING, value, sMachIniFile) Then
|
||||||
m_sCurrSawing = value
|
m_sCurrSawing = value
|
||||||
m_MainWindow.m_CurrentProjectPageUC.MachiningTxBx.Text = value
|
m_MainWindow.m_CurrentProjectPageUC.MachiningTxBx.Text = value
|
||||||
|
'' aggiorno il file ini della macchina con i valori correnti della lavorazione
|
||||||
|
'Dim sVal As String = String.Empty
|
||||||
|
'Dim dVal As Double = m_dFsevLength
|
||||||
|
'If GetUserNote("FsevLength", sVal, m_sCurrSawing, False) Then
|
||||||
|
' StringToDouble(sVal, dVal)
|
||||||
|
' SetFsevLength(dVal)
|
||||||
|
'End If
|
||||||
|
'dVal = m_dFsevPerc
|
||||||
|
'If GetUserNote("FsevPerc", sVal, m_sCurrSawing, False) Then
|
||||||
|
' StringToDouble(sVal, m_dFsevPerc)
|
||||||
|
' SetFsevPerc(dVal)
|
||||||
|
'End If
|
||||||
End If
|
End If
|
||||||
End Set
|
End Set
|
||||||
End Property
|
End Property
|
||||||
@@ -740,6 +755,12 @@ Public Class CurrentMachine
|
|||||||
End Get
|
End Get
|
||||||
End Property
|
End Property
|
||||||
|
|
||||||
|
Friend ReadOnly Property bEnableInvert As Boolean
|
||||||
|
Get
|
||||||
|
Return m_bEnableInvetrt
|
||||||
|
End Get
|
||||||
|
End Property
|
||||||
|
|
||||||
Friend Property dAdditionalTable As Double
|
Friend Property dAdditionalTable As Double
|
||||||
Get
|
Get
|
||||||
Select Case GetCurrentTable()
|
Select Case GetCurrentTable()
|
||||||
@@ -752,6 +773,7 @@ Public Class CurrentMachine
|
|||||||
End Select
|
End Select
|
||||||
End Get
|
End Get
|
||||||
Set(value As Double)
|
Set(value As Double)
|
||||||
|
Dim dValue As Double = 0
|
||||||
Select Case GetCurrentTable()
|
Select Case GetCurrentTable()
|
||||||
Case 3
|
Case 3
|
||||||
If Math.Abs(value - m_dTab3AdditionalTable) > EPS_SMALL And
|
If Math.Abs(value - m_dTab3AdditionalTable) > EPS_SMALL And
|
||||||
@@ -760,6 +782,11 @@ Public Class CurrentMachine
|
|||||||
m_dTab3AdditionalTable = value
|
m_dTab3AdditionalTable = value
|
||||||
' Aggiorno il progetto corrente
|
' Aggiorno il progetto corrente
|
||||||
m_MainWindow.m_CurrentProjectPageUC.AdjustAdditionalTable()
|
m_MainWindow.m_CurrentProjectPageUC.AdjustAdditionalTable()
|
||||||
|
' salvo il valore della sovratavola nel progetto
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_TAB3_ADDITIONALTABLE, dValue)
|
||||||
|
If Math.Abs(dValue - value) > EPS_SMALL Then
|
||||||
|
EgtSetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_TAB3_ADDITIONALTABLE, value)
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
Case 2
|
Case 2
|
||||||
If Math.Abs(value - m_dTab2AdditionalTable) > EPS_SMALL And
|
If Math.Abs(value - m_dTab2AdditionalTable) > EPS_SMALL And
|
||||||
@@ -768,6 +795,11 @@ Public Class CurrentMachine
|
|||||||
m_dTab2AdditionalTable = value
|
m_dTab2AdditionalTable = value
|
||||||
' Aggiorno il progetto corrente
|
' Aggiorno il progetto corrente
|
||||||
m_MainWindow.m_CurrentProjectPageUC.AdjustAdditionalTable()
|
m_MainWindow.m_CurrentProjectPageUC.AdjustAdditionalTable()
|
||||||
|
' salvo il valore della sovratavola nel progetto
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_TAB2_ADDITIONALTABLE, dValue)
|
||||||
|
If Math.Abs(dValue - value) > EPS_SMALL Then
|
||||||
|
EgtSetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_TAB2_ADDITIONALTABLE, value)
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
Case Else
|
Case Else
|
||||||
If Math.Abs(value - m_dAdditionalTable) > EPS_SMALL And
|
If Math.Abs(value - m_dAdditionalTable) > EPS_SMALL And
|
||||||
@@ -776,6 +808,11 @@ Public Class CurrentMachine
|
|||||||
m_dAdditionalTable = value
|
m_dAdditionalTable = value
|
||||||
' Aggiorno il progetto corrente
|
' Aggiorno il progetto corrente
|
||||||
m_MainWindow.m_CurrentProjectPageUC.AdjustAdditionalTable()
|
m_MainWindow.m_CurrentProjectPageUC.AdjustAdditionalTable()
|
||||||
|
' salvo il valore della sovratavola nel progetto
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_ADDITIONALTABLE, dValue)
|
||||||
|
If Math.Abs(dValue - value) > EPS_SMALL Then
|
||||||
|
EgtSetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_ADDITIONALTABLE, value)
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
End Select
|
End Select
|
||||||
End Set
|
End Set
|
||||||
@@ -845,9 +882,18 @@ Public Class CurrentMachine
|
|||||||
Set(value As Double)
|
Set(value As Double)
|
||||||
If WritePrivateProfileString(S_NEST, K_MACH_CUTFSEVLEN, DoubleToString(value, 3), sMachIniFile) Then
|
If WritePrivateProfileString(S_NEST, K_MACH_CUTFSEVLEN, DoubleToString(value, 3), sMachIniFile) Then
|
||||||
m_dFsevLength = value
|
m_dFsevLength = value
|
||||||
|
' salvo il dato nelle UserNote della lavorazione
|
||||||
|
'MdbSetCurrMachiningUserNote("FsevLength", m_dFsevLength.ToString, sCurrSawing, false)
|
||||||
|
' salvo il dato nelle UserNote dell'utensile
|
||||||
|
TdbSetCurrToolUserNote("FsevLength", m_dFsevLength.ToString, sCurrSaw)
|
||||||
End If
|
End If
|
||||||
End Set
|
End Set
|
||||||
End Property
|
End Property
|
||||||
|
Friend Sub SetFsevLength(value As Double)
|
||||||
|
If WritePrivateProfileString(S_NEST, K_MACH_CUTFSEVLEN, DoubleToString(value, 3), sMachIniFile) Then
|
||||||
|
m_dFsevLength = value
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
Friend Property dFsevPerc As Double
|
Friend Property dFsevPerc As Double
|
||||||
Get
|
Get
|
||||||
@@ -856,9 +902,18 @@ Public Class CurrentMachine
|
|||||||
Set(value As Double)
|
Set(value As Double)
|
||||||
If WritePrivateProfileString(S_NEST, K_MACH_CUTFSEVPERC, DoubleToString(value, 3), sMachIniFile) Then
|
If WritePrivateProfileString(S_NEST, K_MACH_CUTFSEVPERC, DoubleToString(value, 3), sMachIniFile) Then
|
||||||
m_dFsevPerc = value
|
m_dFsevPerc = value
|
||||||
|
'' salvo il dato nelle UserNote della lavorazione
|
||||||
|
'MdbSetCurrMachiningUserNote("FsevPerc", m_dFsevPerc.ToString, sCurrSawing)
|
||||||
|
' salvo il dato nelle UserNote dell'utensile
|
||||||
|
TdbSetCurrToolUserNote("FsevPerc", m_dFsevPerc.ToString, sCurrSaw)
|
||||||
End If
|
End If
|
||||||
End Set
|
End Set
|
||||||
End Property
|
End Property
|
||||||
|
Friend Sub SetFsevPerc(value As Double)
|
||||||
|
If WritePrivateProfileString(S_NEST, K_MACH_CUTFSEVPERC, DoubleToString(value, 3), sMachIniFile) Then
|
||||||
|
m_dFsevPerc = value
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
Friend ReadOnly Property ToolChangerNbr As Integer
|
Friend ReadOnly Property ToolChangerNbr As Integer
|
||||||
Get
|
Get
|
||||||
@@ -1154,6 +1209,8 @@ Public Class CurrentMachine
|
|||||||
m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.ENABLE_WJ)
|
m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.ENABLE_WJ)
|
||||||
' possibilità di definire attacco speciale per materiali ceramici
|
' possibilità di definire attacco speciale per materiali ceramici
|
||||||
m_bSawingSpecialLeadIn = (GetPrivateProfileInt(S_MACHININGS, K_SAWINGSPECIALLEADIN, 0, sMachIniFile) > 0)
|
m_bSawingSpecialLeadIn = (GetPrivateProfileInt(S_MACHININGS, K_SAWINGSPECIALLEADIN, 0, sMachIniFile) > 0)
|
||||||
|
' mantengo la direzione del taglio definita nel taglio diretto
|
||||||
|
m_bEnableInvetrt = (GetPrivateProfileInt(S_DIRECTCUTS, K_ENABLEINVERT, 1, sMachIniFile) <> 0)
|
||||||
|
|
||||||
' Leggo utensili correnti
|
' Leggo utensili correnti
|
||||||
' lama
|
' lama
|
||||||
@@ -1249,6 +1306,7 @@ Public Class CurrentMachine
|
|||||||
|
|
||||||
' Leggo dati per feed ridotta all'inizio/fine dei tagli
|
' Leggo dati per feed ridotta all'inizio/fine dei tagli
|
||||||
m_bFsevEnable = (GetPrivateProfileInt(S_NEST, K_MACH_CUTFSEVENABLE, 0, sMachIniFile) <> 0)
|
m_bFsevEnable = (GetPrivateProfileInt(S_NEST, K_MACH_CUTFSEVENABLE, 0, sMachIniFile) <> 0)
|
||||||
|
' sposto la lettura nel DB delle lavorazioni della lama corrente!
|
||||||
m_dFsevLength = GetPrivateProfileDouble(S_NEST, K_MACH_CUTFSEVLEN, 0, sMachIniFile)
|
m_dFsevLength = GetPrivateProfileDouble(S_NEST, K_MACH_CUTFSEVLEN, 0, sMachIniFile)
|
||||||
m_dFsevPerc = GetPrivateProfileDouble(S_NEST, K_MACH_CUTFSEVPERC, 0, sMachIniFile)
|
m_dFsevPerc = GetPrivateProfileDouble(S_NEST, K_MACH_CUTFSEVPERC, 0, sMachIniFile)
|
||||||
|
|
||||||
@@ -1304,6 +1362,29 @@ Public Class CurrentMachine
|
|||||||
m_nEnableBarCodeReader = GetPrivateProfileInt(S_MACH_BARCODEREADER, K_ENABLEBCR, 0, sMachIniFile)
|
m_nEnableBarCodeReader = GetPrivateProfileInt(S_MACH_BARCODEREADER, K_ENABLEBCR, 0, sMachIniFile)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' Per il controllo FANUC al momento dell'inizializzazione del CN devono essere lette alcune variabili
|
||||||
|
Public Sub InitFANUC(CN_Generic As CN_generico)
|
||||||
|
' Leggo ritardo tra reset e send per NUM
|
||||||
|
m_nResetSendDelay = GetPrivateProfileInt(S_NCFANUC, K_RESETSENDDELAY, 1000, sMachIniFile)
|
||||||
|
' Leggo ritardo tra reset e send per NUM
|
||||||
|
m_nThreadSleep = GetPrivateProfileInt(S_NCFANUC, K_THREADSLEEP, 150, sMachIniFile)
|
||||||
|
' Leggo i dati strettamente correlati alla comunicazione NC-PC
|
||||||
|
Dim CN As CN_generico = CN_Generic
|
||||||
|
' Leggo l'indirizzo in cui scrivere lo stato macchina
|
||||||
|
Dim dAddNcMode As String = CN.s_addr_set_nc_mode
|
||||||
|
GetPrivateProfileString(S_NCFANUC, K_SETNCMODE, CN.s_addr_set_nc_mode, CN.s_addr_set_nc_mode, sMachIniFile)
|
||||||
|
' Leggo primo indirizzo libero delle variabili di tipo intero
|
||||||
|
CN.n_Base_addr_int_vars = GetPrivateProfileInt(S_NCFANUC, K_BASEADDRINT, CN.n_Base_addr_int_vars, sMachIniFile)
|
||||||
|
' Leggo primo indirizzo libero delle variabili di tipo bit
|
||||||
|
CN.n_Base_addr_byte_for_bits_vars = GetPrivateProfileInt(S_NCFANUC, K_BASEADDRBIT, CN.n_Base_addr_byte_for_bits_vars, sMachIniFile)
|
||||||
|
' Leggo numero di variabili di tipo intero
|
||||||
|
CN.n_num_var_int_to_read = CShort(GetPrivateProfileInt(S_NCFANUC, K_NUMVARINT, CInt(CN.n_num_var_int_to_read), sMachIniFile))
|
||||||
|
' Leggo numero di varibili di tipo bit
|
||||||
|
CN.n_num_var_byte_for_bits_to_read = CShort(GetPrivateProfileInt(S_NCFANUC, K_NUMVARBIT, CInt(CN.n_num_var_byte_for_bits_to_read), sMachIniFile))
|
||||||
|
' Leggo variabile abilitata alla gestione di FeedHold
|
||||||
|
GetPrivateProfileString(S_NCFANUC, K_SETNCMODE, CN.s_addr_feedhold, CN.s_addr_feedhold, sMachIniFile)
|
||||||
|
End Sub
|
||||||
|
|
||||||
Public Sub LoadWJMaterial(Optional bIsStart As Boolean = False)
|
Public Sub LoadWJMaterial(Optional bIsStart As Boolean = False)
|
||||||
Dim TempCurrMat As Material = CurrMat
|
Dim TempCurrMat As Material = CurrMat
|
||||||
' Svuoto l'attuale lista di materiali
|
' Svuoto l'attuale lista di materiali
|
||||||
@@ -1311,7 +1392,7 @@ Public Class CurrentMachine
|
|||||||
' Leggo valori da file Data e li carico nelle proprietà
|
' Leggo valori da file Data e li carico nelle proprietà
|
||||||
Dim sFilePath As String = sMachDir & "\" & MACHININGS_DIR & "\" & WATERJETDB_FILE
|
Dim sFilePath As String = sMachDir & "\" & MACHININGS_DIR & "\" & WATERJETDB_FILE
|
||||||
Dim Local_MaterialList = New ObservableCollection(Of EgtWPFLib5.WjMaterial)
|
Dim Local_MaterialList = New ObservableCollection(Of EgtWPFLib5.WjMaterial)
|
||||||
Local_MaterialList = EgtWPFLib5.WaterjetDbWindowVM.LoadWjMaterials(sFilePath)
|
Local_MaterialList = WaterjetDbWindowVM_OmagCUT.LoadWjMaterials(sFilePath)
|
||||||
' definisco la lista delle qualità (solo se è vuota)
|
' definisco la lista delle qualità (solo se è vuota)
|
||||||
If m_Qualities.Count < 1 Then
|
If m_Qualities.Count < 1 Then
|
||||||
m_Qualities.Add("Q1")
|
m_Qualities.Add("Q1")
|
||||||
@@ -1342,7 +1423,7 @@ Public Class CurrentMachine
|
|||||||
' Leggo valori da file Data e li carico nelle proprietà
|
' Leggo valori da file Data e li carico nelle proprietà
|
||||||
Dim sFilePath As String = sMachDir & "\" & MACHININGS_DIR & "\" & WATERJETDB_FILE
|
Dim sFilePath As String = sMachDir & "\" & MACHININGS_DIR & "\" & WATERJETDB_FILE
|
||||||
Dim Local_MaterialList = New ObservableCollection(Of EgtWPFLib5.WjMaterial)
|
Dim Local_MaterialList = New ObservableCollection(Of EgtWPFLib5.WjMaterial)
|
||||||
Local_MaterialList = EgtWPFLib5.WaterjetDbWindowVM.LoadWjMaterials(sFilePath)
|
Local_MaterialList = WaterjetDbWindowVM_OmagCUT.LoadWjMaterials(sFilePath)
|
||||||
Dim sItems() As String = sCurMat.Split("."c)
|
Dim sItems() As String = sCurMat.Split("."c)
|
||||||
If sItems.Count > 1 Then
|
If sItems.Count > 1 Then
|
||||||
Dim sMat As String = sItems(0)
|
Dim sMat As String = sItems(0)
|
||||||
@@ -1367,9 +1448,148 @@ Public Class CurrentMachine
|
|||||||
If bFound Then Exit For
|
If bFound Then Exit For
|
||||||
Next
|
Next
|
||||||
End If
|
End If
|
||||||
Return dMaxThick
|
' il valore resituito è già nell'unità corrente del programma -> converto il dato in mm
|
||||||
|
Dim dValmm As Double = 0
|
||||||
|
StringToLen(DoubleToString(dMaxThick, 3), dValmm)
|
||||||
|
Return dValmm
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
#Region "USERNOTE"
|
||||||
|
|
||||||
|
' recupero le note UserNote associate alla LAVORAZIONE Machining
|
||||||
|
Friend Function MdbGetCurrMachiningUserNote(Machining As String) As String
|
||||||
|
Dim UserNotes As String = String.Empty
|
||||||
|
' lavorazione corrente
|
||||||
|
Dim CurrMach As String = String.Empty
|
||||||
|
EgtMdbGetCurrMachiningParam(MCH_MP.NAME, CurrMach)
|
||||||
|
' Imposto utensile lama corrente
|
||||||
|
If Not String.IsNullOrWhiteSpace(Machining) AndAlso EgtMdbSetCurrMachining(Machining) Then
|
||||||
|
' leggo nel db corrente della lavorazione questa info
|
||||||
|
EgtMdbGetCurrMachiningParam(MCH_MP.USERNOTES, UserNotes)
|
||||||
|
' reimposto lavorazione corrente
|
||||||
|
EgtMdbSetCurrMachining(CurrMach)
|
||||||
|
End If
|
||||||
|
Return UserNotes
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' recupero le note UserNote associate all'UTENSILE Tool
|
||||||
|
Friend Function TdbGetCurrToolUserNote(Tool As String) As String
|
||||||
|
Dim UserNotes As String = String.Empty
|
||||||
|
' lavorazione corrente
|
||||||
|
Dim CurrTool As String = String.Empty
|
||||||
|
EgtTdbGetCurrToolParam(MCH_TP.NAME, CurrTool)
|
||||||
|
' Imposto utensile lama corrente
|
||||||
|
If Not String.IsNullOrWhiteSpace(Tool) AndAlso EgtTdbSetCurrTool(Tool) Then
|
||||||
|
' leggo nel db corrente della lavorazione questa info
|
||||||
|
EgtTdbGetCurrToolParam(MCH_TP.USERNOTES, UserNotes)
|
||||||
|
' reimposto lavorazione corrente
|
||||||
|
EgtTdbSetCurrTool(CurrTool)
|
||||||
|
End If
|
||||||
|
Return UserNotes
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' imposta il nuovo valore in UserNote della LAVORAZIONE Machining
|
||||||
|
Friend Sub MdbSetCurrMachiningUserNote(sKeyUserNote As String, sValUserNote As String, Machining As String)
|
||||||
|
' lavorazione corrente
|
||||||
|
Dim CurrMach As String = String.Empty
|
||||||
|
EgtMdbGetCurrMachiningParam(MCH_MP.NAME, CurrMach)
|
||||||
|
' Imposto utensile lama corrente
|
||||||
|
If Not String.IsNullOrWhiteSpace(Machining) AndAlso EgtMdbSetCurrMachining(Machining) Then
|
||||||
|
Dim UserNotes As String = String.Empty
|
||||||
|
' salvo nel db corrente della lavorazione questa info → devo gestire l'inserimento: sovrascrivo NON ESEGUE un APPEND delle info
|
||||||
|
EgtMdbSetCurrMachiningParam(MCH_MP.USERNOTES, AssembUserNote(sKeyUserNote, sValUserNote, Machining))
|
||||||
|
EgtMdbSaveCurrMachining()
|
||||||
|
EgtMdbSave()
|
||||||
|
' reimposto lavorazione corrente
|
||||||
|
EgtMdbSetCurrMachining(CurrMach)
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' imposta il nuovo valore in UserNote dell'UTENSILE Tool
|
||||||
|
Friend Sub TdbSetCurrToolUserNote(sKeyUserNote As String, sValUserNote As String, Tool As String)
|
||||||
|
' lavorazione corrente
|
||||||
|
Dim CurrTool As String = String.Empty
|
||||||
|
EgtTdbGetCurrToolParam(MCH_TP.NAME, CurrTool)
|
||||||
|
' Imposto utensile lama corrente
|
||||||
|
If Not String.IsNullOrWhiteSpace(Tool) AndAlso EgtTdbSetCurrTool(Tool) Then
|
||||||
|
Dim UserNotes As String = String.Empty
|
||||||
|
' salvo nel db corrente della lavorazione questa info → devo gestire l'inserimento: sovrascrivo NON ESEGUE un APPEND delle info
|
||||||
|
EgtTdbSetCurrToolParam(MCH_TP.USERNOTES, AssembUserNote(sKeyUserNote, sValUserNote, Tool))
|
||||||
|
EgtTdbSaveCurrTool()
|
||||||
|
EgtTdbSave()
|
||||||
|
' reimposto lavorazione corrente
|
||||||
|
EgtTdbSetCurrTool(Tool)
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' separa la le note UserNote della LAVORAZIONE
|
||||||
|
Private Function SplitUserNoteMachinig(Machining As String) As String()
|
||||||
|
Dim sUserNotes As String = MdbGetCurrMachiningUserNote(Machining)
|
||||||
|
If String.IsNullOrEmpty(sUserNotes) Then Return Nothing
|
||||||
|
Dim sItems As String() = sUserNotes.Split(";"c)
|
||||||
|
Return sItems
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' separa la le note UserNote della LAVORAZIONE
|
||||||
|
Private Function SplitUserNoteTool(Tool As String) As String()
|
||||||
|
Dim sUserNotes As String = TdbGetCurrToolUserNote(Tool)
|
||||||
|
If String.IsNullOrEmpty(sUserNotes) Then Return Nothing
|
||||||
|
Dim sItems As String() = sUserNotes.Split(";"c)
|
||||||
|
Return sItems
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' recupera il valore della associato alla chiave per la lavorazione oppure utensile (bIsToolNote)
|
||||||
|
Friend Function GetUserNote(sKeyUserNote As String, ByRef sValUserNote As String, sName As String, Optional bIsToolNote As Boolean = True) As Boolean
|
||||||
|
Dim sUserNotesList As String() = Nothing
|
||||||
|
If bIsToolNote Then
|
||||||
|
sUserNotesList = SplitUserNoteTool(sName)
|
||||||
|
Else
|
||||||
|
sUserNotesList = SplitUserNoteMachinig(sName)
|
||||||
|
End If
|
||||||
|
If IsNothing(sUserNotesList) Then Return False
|
||||||
|
For Index As Integer = 0 To sUserNotesList.Count - 1
|
||||||
|
Dim sNote As String() = sUserNotesList(Index).Split("="c)
|
||||||
|
If sNote.Count = 2 AndAlso sNote(0).Trim = sKeyUserNote Then
|
||||||
|
sValUserNote = sNote(1).Trim
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
|
' ricostruisce la stringa UserNote da salvare
|
||||||
|
Friend Function AssembUserNote(sKeyUserNote As String, sValUserNote As String, sName As String, Optional bIsToolNote As Boolean = True) As String
|
||||||
|
Dim sUserNotes As String = String.Empty
|
||||||
|
Dim sUserNotesList As String() = Nothing
|
||||||
|
If bIsToolNote Then
|
||||||
|
sUserNotesList = SplitUserNoteTool(sName)
|
||||||
|
Else
|
||||||
|
sUserNotesList = SplitUserNoteMachinig(sName)
|
||||||
|
End If
|
||||||
|
Dim bExists As Boolean = False
|
||||||
|
If Not IsNothing(sUserNotesList) Then
|
||||||
|
For Index As Integer = 0 To sUserNotesList.Count - 1
|
||||||
|
Dim sNote As String() = sUserNotesList(Index).Split("="c)
|
||||||
|
If sNote.Count = 2 AndAlso sNote(0).Trim = sKeyUserNote Then
|
||||||
|
sUserNotesList(Index) = sKeyUserNote & "=" & sValUserNote
|
||||||
|
bExists = True
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
' riassemblo la stringa
|
||||||
|
For Each Item As String In sUserNotesList
|
||||||
|
If Not String.IsNullOrWhiteSpace(Item) Then
|
||||||
|
sUserNotes &= Item & ";"
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
If Not bExists Then
|
||||||
|
sUserNotes &= sKeyUserNote & "=" & sValUserNote & ";"
|
||||||
|
End If
|
||||||
|
Return sUserNotes
|
||||||
|
End Function
|
||||||
|
|
||||||
|
#End Region ' USERNOTE
|
||||||
|
|
||||||
Friend Function IsVacuumMovePossible() As Boolean
|
Friend Function IsVacuumMovePossible() As Boolean
|
||||||
' Recupero diametro lama corrente
|
' Recupero diametro lama corrente
|
||||||
EgtTdbSetCurrTool(sCurrSaw)
|
EgtTdbSetCurrTool(sCurrSaw)
|
||||||
|
|||||||
@@ -34,16 +34,21 @@
|
|||||||
<ColumnDefinition Width="1.5*"/>
|
<ColumnDefinition Width="1.5*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<Button Name="AutoBtn" Grid.Column="0"
|
<ToggleButton Name="AutoBtn" Grid.Column="0"
|
||||||
Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
Style="{DynamicResource OmagCut_GradientYellowIconToggleButton}"
|
||||||
<Button Name="ManualBtn" Grid.Column="1"
|
Foreground="White"/>
|
||||||
Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
<ToggleButton Name="ManualBtn" Grid.Column="1"
|
||||||
<Button Name="MDIBtn" Grid.Column="2"
|
Style="{DynamicResource OmagCut_GradientYellowIconToggleButton}"
|
||||||
Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
Foreground="White"/>
|
||||||
<Button Name="SingleBtn" Grid.Column="3"
|
<ToggleButton Name="MDIBtn" Grid.Column="2"
|
||||||
Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
Style="{DynamicResource OmagCut_GradientYellowIconToggleButton}"
|
||||||
<Button Name="HomeBtn" Grid.Column="4"
|
Foreground="White"/>
|
||||||
Style="{DynamicResource OmagCut_RightGrayGradientYellowTextButton}"/>
|
<ToggleButton Name="SingleBtn" Grid.Column="3"
|
||||||
|
Style="{DynamicResource OmagCut_GradientYellowIconToggleButton}"
|
||||||
|
Foreground="White"/>
|
||||||
|
<ToggleButton Name="HomeBtn" Grid.Column="4"
|
||||||
|
Style="{DynamicResource OmagCut_GradientYellowIconToggleButton}"
|
||||||
|
Foreground="White"/>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
|
|||||||
@@ -8,6 +8,8 @@ Public Class MachineCNPageUC
|
|||||||
Private m_bFirst As Boolean = True
|
Private m_bFirst As Boolean = True
|
||||||
Private m_ButtonPower As New List(Of MachineButton)
|
Private m_ButtonPower As New List(Of MachineButton)
|
||||||
|
|
||||||
|
Private m_nCurrMode As Integer = 0
|
||||||
|
|
||||||
Private Sub TestingPage_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
Private Sub TestingPage_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
StartBtn.Content = EgtMsg(MSG_MACHINECNPAGEUC + 1)
|
StartBtn.Content = EgtMsg(MSG_MACHINECNPAGEUC + 1)
|
||||||
StopBtn.Content = EgtMsg(MSG_MACHINECNPAGEUC + 2)
|
StopBtn.Content = EgtMsg(MSG_MACHINECNPAGEUC + 2)
|
||||||
@@ -51,6 +53,9 @@ Public Class MachineCNPageUC
|
|||||||
PartProgTransferGpBx.Visibility = Windows.Visibility.Hidden
|
PartProgTransferGpBx.Visibility = Windows.Visibility.Hidden
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' gestione visuliazzazione ToggleButton Auto/Sinlge/Mdi/Manula/Home
|
||||||
|
SetCncMode()
|
||||||
|
|
||||||
'------ NUOVI BOTTONI ----------
|
'------ NUOVI BOTTONI ----------
|
||||||
' Lettura configurazione bottoni (per impostare l'uso del Joystick) da Ini di macchina
|
' Lettura configurazione bottoni (per impostare l'uso del Joystick) da Ini di macchina
|
||||||
m_ButtonPower.Clear()
|
m_ButtonPower.Clear()
|
||||||
@@ -98,6 +103,53 @@ Public Class MachineCNPageUC
|
|||||||
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub SetCncMode()
|
||||||
|
Dim Mode As Integer = m_nCurrMode
|
||||||
|
Select Case Mode
|
||||||
|
Case 0
|
||||||
|
' Auoto
|
||||||
|
MDIConfirmBtn.IsEnabled = False
|
||||||
|
AutoBtn.IsChecked = True
|
||||||
|
SingleBtn.IsChecked = False
|
||||||
|
MDIBtn.IsChecked = False
|
||||||
|
ManualBtn.IsChecked = False
|
||||||
|
HomeBtn.IsChecked = False
|
||||||
|
Case 1
|
||||||
|
' Single
|
||||||
|
MDIConfirmBtn.IsEnabled = False
|
||||||
|
AutoBtn.IsChecked = False
|
||||||
|
SingleBtn.IsChecked = True
|
||||||
|
MDIBtn.IsChecked = False
|
||||||
|
ManualBtn.IsChecked = False
|
||||||
|
HomeBtn.IsChecked = False
|
||||||
|
Case 2
|
||||||
|
' Mdi
|
||||||
|
MDIConfirmBtn.IsEnabled = True
|
||||||
|
AutoBtn.IsChecked = False
|
||||||
|
SingleBtn.IsChecked = False
|
||||||
|
MDIBtn.IsChecked = True
|
||||||
|
ManualBtn.IsChecked = False
|
||||||
|
HomeBtn.IsChecked = False
|
||||||
|
Case 7
|
||||||
|
' Manual
|
||||||
|
MDIConfirmBtn.IsEnabled = False
|
||||||
|
AutoBtn.IsChecked = False
|
||||||
|
SingleBtn.IsChecked = False
|
||||||
|
MDIBtn.IsChecked = False
|
||||||
|
ManualBtn.IsChecked = True
|
||||||
|
HomeBtn.IsChecked = False
|
||||||
|
Case 8
|
||||||
|
' Home
|
||||||
|
MDIConfirmBtn.IsEnabled = False
|
||||||
|
AutoBtn.IsChecked = False
|
||||||
|
SingleBtn.IsChecked = False
|
||||||
|
MDIBtn.IsChecked = False
|
||||||
|
ManualBtn.IsChecked = False
|
||||||
|
HomeBtn.IsChecked = True
|
||||||
|
End Select
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub StartBtn_Click(sender As Object, e As RoutedEventArgs) Handles StartBtn.Click
|
Private Sub StartBtn_Click(sender As Object, e As RoutedEventArgs) Handles StartBtn.Click
|
||||||
If m_MainWindow.m_CNCommunication.m_nNCType = 3 AndAlso m_MainWindow.m_CNCommunication.m_CN.m_IsSiemensOne Then
|
If m_MainWindow.m_CNCommunication.m_nNCType = 3 AndAlso m_MainWindow.m_CNCommunication.m_CN.m_IsSiemensOne Then
|
||||||
Dim sDBVarPath As String = ""
|
Dim sDBVarPath As String = ""
|
||||||
@@ -278,4 +330,9 @@ Public Class MachineCNPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Friend Sub CncModeChange(nMode As Integer)
|
||||||
|
m_nCurrMode = nMode
|
||||||
|
SetCncMode()
|
||||||
|
End Sub
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|||||||
@@ -145,12 +145,12 @@ Public Class MachinePageUC
|
|||||||
m_ActiveMachinePage = MachinePages.Alarms
|
m_ActiveMachinePage = MachinePages.Alarms
|
||||||
Case MachinePages.WaterJet
|
Case MachinePages.WaterJet
|
||||||
' Verifica ed eventuale salvataggio Db Waterjet
|
' Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
AlarmsBtn.IsChecked = False
|
AlarmsBtn.IsChecked = False
|
||||||
WaterJetBtn.IsChecked = True
|
WaterJetBtn.IsChecked = True
|
||||||
Return
|
Return
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
' passo alla pagina Dati Macchina
|
' passo alla pagina Dati Macchina
|
||||||
@@ -215,12 +215,12 @@ Public Class MachinePageUC
|
|||||||
m_ActiveMachinePage = MachinePages.ToolsDb
|
m_ActiveMachinePage = MachinePages.ToolsDb
|
||||||
Case MachinePages.WaterJet
|
Case MachinePages.WaterJet
|
||||||
'Verifica ed eventuale salvataggio Db Waterjet
|
'Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
ToolsDBBtn.IsChecked = False
|
ToolsDBBtn.IsChecked = False
|
||||||
WaterJetBtn.IsChecked = True
|
WaterJetBtn.IsChecked = True
|
||||||
Return
|
Return
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
' passo alla pagina Dati Macchina
|
' passo alla pagina Dati Macchina
|
||||||
@@ -285,12 +285,12 @@ Public Class MachinePageUC
|
|||||||
m_ActiveMachinePage = MachinePages.MachiningDb
|
m_ActiveMachinePage = MachinePages.MachiningDb
|
||||||
Case MachinePages.WaterJet
|
Case MachinePages.WaterJet
|
||||||
' Verifica ed eventuale salvataggio Db Waterjet
|
' Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
MachiningDBBtn.IsChecked = False
|
MachiningDBBtn.IsChecked = False
|
||||||
WaterJetBtn.IsChecked = True
|
WaterJetBtn.IsChecked = True
|
||||||
Return
|
Return
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
' passo alla pagina Dati Macchina
|
' passo alla pagina Dati Macchina
|
||||||
@@ -358,12 +358,12 @@ Public Class MachinePageUC
|
|||||||
PolishingsBtn.IsChecked = True
|
PolishingsBtn.IsChecked = True
|
||||||
Case MachinePages.WaterJet
|
Case MachinePages.WaterJet
|
||||||
' Verifica ed eventuale salvataggio Db Waterjet
|
' Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
PolishingsBtn.IsChecked = False
|
PolishingsBtn.IsChecked = False
|
||||||
WaterJetBtn.IsChecked = True
|
WaterJetBtn.IsChecked = True
|
||||||
Return
|
Return
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
' passo alla pagina Dati Macchina
|
' passo alla pagina Dati Macchina
|
||||||
@@ -513,12 +513,12 @@ Public Class MachinePageUC
|
|||||||
m_ActiveMachinePage = MachinePages.MachineCN
|
m_ActiveMachinePage = MachinePages.MachineCN
|
||||||
Case MachinePages.WaterJet
|
Case MachinePages.WaterJet
|
||||||
' Verifica ed eventuale salvataggio Db Waterjet
|
' Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
TestingPageBtn.IsChecked = False
|
TestingPageBtn.IsChecked = False
|
||||||
WaterJetBtn.IsChecked = True
|
WaterJetBtn.IsChecked = True
|
||||||
Return
|
Return
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
' passo alla pagina Dati Macchina
|
' passo alla pagina Dati Macchina
|
||||||
@@ -593,12 +593,12 @@ Public Class MachinePageUC
|
|||||||
m_ActiveMachinePage = MachinePages.Statistics
|
m_ActiveMachinePage = MachinePages.Statistics
|
||||||
Case MachinePages.WaterJet
|
Case MachinePages.WaterJet
|
||||||
' Verifica ed eventuale salvataggio Db Waterjet
|
' Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
StatisticsBtn.IsChecked = False
|
StatisticsBtn.IsChecked = False
|
||||||
WaterJetBtn.IsChecked = True
|
WaterJetBtn.IsChecked = True
|
||||||
Return
|
Return
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
' passo alla pagina Dati Macchina
|
' passo alla pagina Dati Macchina
|
||||||
|
|||||||
@@ -248,16 +248,16 @@ Public Class MachineStatusUC
|
|||||||
dL3 = ptTip.z
|
dL3 = ptTip.z
|
||||||
End If
|
End If
|
||||||
' Visualizzazione
|
' Visualizzazione
|
||||||
Axis1TxBx.Text = LenToString(dL1, -3)
|
Axis1TxBx.Text = LenToString(dL1, -3, True)
|
||||||
Axis2TxBx.Text = LenToString(dL2, -3)
|
Axis2TxBx.Text = LenToString(dL2, -3, True)
|
||||||
Axis3TxBx.Text = LenToString(dL3, -3)
|
Axis3TxBx.Text = LenToString(dL3, -3, True)
|
||||||
Axis4TxBx.Text = DoubleToString(dR1, -3)
|
Axis4TxBx.Text = DoubleToString(dR1, -3)
|
||||||
Axis5TxBx.Text = DoubleToString(dR2, -3)
|
Axis5TxBx.Text = DoubleToString(dR2, -3)
|
||||||
If m_AxesNumber >= 6 Then Axis6TxBx.Text = DoubleToString(dA6, -3)
|
If m_AxesNumber >= 6 Then Axis6TxBx.Text = DoubleToString(dA6, -3)
|
||||||
If m_AxesNumber >= 7 Then Axis7TxBx.Text = LenToString(dA7, -3)
|
If m_AxesNumber >= 7 Then Axis7TxBx.Text = LenToString(dA7, -3, True)
|
||||||
If m_AxesNumber >= 8 Then Axis8TxBx.Text = LenToString(dA8, -3)
|
If m_AxesNumber >= 8 Then Axis8TxBx.Text = LenToString(dA8, -3, True)
|
||||||
If m_AxesNumber >= 9 Then Axis9TxBx.Text = LenToString(dA9, -3)
|
If m_AxesNumber >= 9 Then Axis9TxBx.Text = LenToString(dA9, -3, True)
|
||||||
If m_AxesNumber >= 10 Then Axis10TxBx.Text = LenToString(dA10, -3)
|
If m_AxesNumber >= 10 Then Axis10TxBx.Text = LenToString(dA10, -3, True)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Sub DisplayPositionDelta()
|
Sub DisplayPositionDelta()
|
||||||
@@ -265,22 +265,22 @@ Public Class MachineStatusUC
|
|||||||
Dim dL1, dL2, dL3, dR1, dR2, dA6, dA7, dA8, dA9, dA10 As Double
|
Dim dL1, dL2, dL3, dR1, dR2, dA6, dA7, dA8, dA9, dA10 As Double
|
||||||
m_MainWindow.m_CNCommunication.GetAxesDeltas(dL1, dL2, dL3, dR1, dR2, dA6, dA7, dA8, dA9, dA10)
|
m_MainWindow.m_CNCommunication.GetAxesDeltas(dL1, dL2, dL3, dR1, dR2, dA6, dA7, dA8, dA9, dA10)
|
||||||
' Visualizzazione
|
' Visualizzazione
|
||||||
DeltaAxis1TxBx.Text = LenToString(dL1, -3)
|
DeltaAxis1TxBx.Text = LenToString(dL1, -3, True)
|
||||||
DeltaAxis2TxBx.Text = LenToString(dL2, -3)
|
DeltaAxis2TxBx.Text = LenToString(dL2, -3, True)
|
||||||
DeltaAxis3TxBx.Text = LenToString(dL3, -3)
|
DeltaAxis3TxBx.Text = LenToString(dL3, -3, True)
|
||||||
DeltaAxis4TxBx.Text = DoubleToString(dR1, -3)
|
DeltaAxis4TxBx.Text = DoubleToString(dR1, -3)
|
||||||
DeltaAxis5TxBx.Text = DoubleToString(dR2, -3)
|
DeltaAxis5TxBx.Text = DoubleToString(dR2, -3)
|
||||||
If m_AxesNumber >= 6 Then DeltaAxis6TxBx.Text = DoubleToString(dA6, -3)
|
If m_AxesNumber >= 6 Then DeltaAxis6TxBx.Text = DoubleToString(dA6, -3)
|
||||||
If m_AxesNumber >= 7 Then DeltaAxis7TxBx.Text = LenToString(dA7, -3)
|
If m_AxesNumber >= 7 Then DeltaAxis7TxBx.Text = LenToString(dA7, -3, True)
|
||||||
If m_AxesNumber >= 8 Then DeltaAxis8TxBx.Text = LenToString(dA8, -3)
|
If m_AxesNumber >= 8 Then DeltaAxis8TxBx.Text = LenToString(dA8, -3, True)
|
||||||
If m_AxesNumber >= 9 Then DeltaAxis9TxBx.Text = LenToString(dA9, -3)
|
If m_AxesNumber >= 9 Then DeltaAxis9TxBx.Text = LenToString(dA9, -3, True)
|
||||||
If m_AxesNumber >= 10 Then DeltaAxis10TxBx.Text = LenToString(dA10, -3)
|
If m_AxesNumber >= 10 Then DeltaAxis10TxBx.Text = LenToString(dA10, -3, True)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Sub DisplayFeed()
|
Sub DisplayFeed()
|
||||||
Dim dRealFeed As Double = m_CN.d_DInterpo_Prog_Feed * m_CN.d_DInterpo_Feed_override / 100
|
Dim dRealFeed As Double = m_CN.d_DInterpo_Prog_Feed * m_CN.d_DInterpo_Feed_override / 100
|
||||||
'Feed = DoubleToString(dRealFeed, 0)
|
'Feed = DoubleToString(dRealFeed, 0)
|
||||||
FeedTxBx.Text = LenToString(dRealFeed, 0)
|
FeedTxBx.Text = LenToString(dRealFeed, 0, True)
|
||||||
'FeedOverride = DoubleToString(m_CN.d_DInterpo_Feed_override, 0) & "%"
|
'FeedOverride = DoubleToString(m_CN.d_DInterpo_Feed_override, 0) & "%"
|
||||||
Dim dFeedOverride As Double = m_CN.d_DInterpo_Feed_override
|
Dim dFeedOverride As Double = m_CN.d_DInterpo_Feed_override
|
||||||
FeedOverrideTxBx.Text = DoubleToString(dFeedOverride, 0) & "%"
|
FeedOverrideTxBx.Text = DoubleToString(dFeedOverride, 0) & "%"
|
||||||
@@ -304,6 +304,8 @@ Public Class MachineStatusUC
|
|||||||
If m_MainWindow.m_CNCommunication.m_nNCType = 3 AndAlso m_MainWindow.m_CNCommunication.m_CN.m_IsSiemensOne Then
|
If m_MainWindow.m_CNCommunication.m_nNCType = 3 AndAlso m_MainWindow.m_CNCommunication.m_CN.m_IsSiemensOne Then
|
||||||
dSpindlePower = m_CN.d_data(0)
|
dSpindlePower = m_CN.d_data(0)
|
||||||
dSpindleOvr = m_CN.d_data(1)
|
dSpindleOvr = m_CN.d_data(1)
|
||||||
|
ElseIf m_MainWindow.m_CNCommunication.m_nNCType = 4 Then
|
||||||
|
dSpindlePower = m_CN.d_spindle_power / 1000
|
||||||
Else
|
Else
|
||||||
dSpindlePower = m_CN.d_spindle_power
|
dSpindlePower = m_CN.d_spindle_power
|
||||||
dSpindleOvr = If(m_CN.bPowerOvr > 0, m_CN.d_spindle_power / m_CN.bPowerOvr * 100, 0)
|
dSpindleOvr = If(m_CN.bPowerOvr > 0, m_CN.d_spindle_power / m_CN.bPowerOvr * 100, 0)
|
||||||
|
|||||||
@@ -246,7 +246,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="SideAngleTxBl" Grid.Column="2" Grid.Row="3" Grid.RowSpan="3"
|
<TextBlock Name="SideAngleTxBl" Grid.Column="2" Grid.Row="3" Grid.RowSpan="3"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="3" Grid.Row="3" Grid.RowSpan="3" Margin="0,0,15,0"
|
<EgtWPFLib:EgtTextBox Name="SideAngleTxBx" Grid.Column="3" Grid.Row="3" Grid.RowSpan="3" Margin="0,0,15,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<TextBlock Name="StepTypeTxBl" Grid.Column="0" Grid.Row="6" Grid.RowSpan="3"
|
<TextBlock Name="StepTypeTxBl" Grid.Column="0" Grid.Row="6" Grid.RowSpan="3"
|
||||||
@@ -576,7 +576,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="ForwardAngleTxBl" Grid.Column="0" Grid.Row="6" Grid.RowSpan="3"
|
<TextBlock Name="ForwardAngleTxBl" Grid.Column="0" Grid.Row="6" Grid.RowSpan="3"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="ForwardAngleTxBx" Grid.Column="1" Grid.Row="6" Grid.RowSpan="3"
|
<EgtWPFLib:EgtTextBox Name="ForwardAngleTxBx" Grid.Column="1" Grid.Row="6" Grid.RowSpan="3" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_MachLeftCalculatorTextBoxInBorder}" />
|
Style="{DynamicResource OmagCut_MachLeftCalculatorTextBoxInBorder}" />
|
||||||
|
|
||||||
<Border Name="LiHoleBrd" Grid.Column="0" Grid.Row="9" Grid.ColumnSpan="4" Grid.RowSpan="6"
|
<Border Name="LiHoleBrd" Grid.Column="0" Grid.Row="9" Grid.ColumnSpan="4" Grid.RowSpan="6"
|
||||||
@@ -605,12 +605,12 @@
|
|||||||
|
|
||||||
<TextBlock Name="LpTurnsTxBl" Grid.Column="0" Grid.Row="1" Grid.RowSpan="2"
|
<TextBlock Name="LpTurnsTxBl" Grid.Column="0" Grid.Row="1" Grid.RowSpan="2"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="LpTurnsTxBx" Grid.Column="1" Grid.Row="1"
|
<EgtWPFLib:EgtTextBox Name="LpTurnsTxBx" Grid.Column="1" Grid.Row="1" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_MachLeftCalculatorTextBoxInBorder}" />
|
Style="{DynamicResource OmagCut_MachLeftCalculatorTextBoxInBorder}" />
|
||||||
|
|
||||||
<TextBlock Name="HpTurnsTxBl" Grid.Column="2" Grid.Row="1"
|
<TextBlock Name="HpTurnsTxBl" Grid.Column="2" Grid.Row="1"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="HpTurnsTxBx" Grid.Column="3" Grid.Row="1"
|
<EgtWPFLib:EgtTextBox Name="HpTurnsTxBx" Grid.Column="3" Grid.Row="1" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_MachLeftCalculatorTextBoxInBorder}" />
|
Style="{DynamicResource OmagCut_MachLeftCalculatorTextBoxInBorder}" />
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
@@ -725,7 +725,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="SpeedTxBl" Grid.Column="0"
|
<TextBlock Name="SpeedTxBl" Grid.Column="0"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="SpeedTxBx" Grid.Column="1"
|
<EgtWPFLib:EgtTextBox Name="SpeedTxBx" Grid.Column="1" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_MachToolCalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_MachToolCalculatorTextBox}" />
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -899,11 +899,11 @@ Public Class MachiningDbPageUC
|
|||||||
For Each Material As MachiningMaterial In m_MaterialsList
|
For Each Material As MachiningMaterial In m_MaterialsList
|
||||||
If m_MainWindow.m_CurrentMachine.bWaterJet And m_MainWindow.m_CurrentMachine.bFromDBWaterJet Then
|
If m_MainWindow.m_CurrentMachine.bWaterJet And m_MainWindow.m_CurrentMachine.bFromDBWaterJet Then
|
||||||
If Material.bIsActive Then
|
If Material.bIsActive Then
|
||||||
sMaterialString += Material.nId.ToString & "." & Material.nSubId.ToString & "," & DoubleToString(Material.dMinThickness, 0) & "," & DoubleToString(Material.dMaxThickness, 0) & ";"
|
sMaterialString += Material.nId.ToString & "." & Material.nSubId.ToString & "," & DoubleToString(Material.dMinThickness, 3) & "," & DoubleToString(Material.dMaxThickness, 3) & ";"
|
||||||
End If
|
End If
|
||||||
Else
|
Else
|
||||||
If Material.bIsActive Then
|
If Material.bIsActive Then
|
||||||
sMaterialString += Material.nId.ToString & "," & DoubleToString(Material.dMinThickness, 0) & "," & DoubleToString(Material.dMaxThickness, 0) & ";"
|
sMaterialString += Material.nId.ToString & "," & DoubleToString(Material.dMinThickness, 3) & "," & DoubleToString(Material.dMaxThickness, 3) & ";"
|
||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
Next
|
Next
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
<!-- Definizione del ToolHolderUc -->
|
<!-- Definizione del ToolHolderUc -->
|
||||||
<Grid>
|
<Grid>
|
||||||
<Image Source="/Resources/ToolChangerPos.png"/>
|
<Image Source="/Resources/ToolChangerPos.png"/>
|
||||||
<ToggleButton Name="Tool" Width="50" Height="50" Margin="22,40,26,8" Background="#7FB4B4B4">
|
<ToggleButton Name="Tool" Width="50" Height="50" Margin="62,10,16,10" Background="#7FB4B4B4">
|
||||||
<ToggleButton.Template>
|
<ToggleButton.Template>
|
||||||
<ControlTemplate TargetType="{x:Type ToggleButton}">
|
<ControlTemplate TargetType="{x:Type ToggleButton}">
|
||||||
<Grid>
|
<Grid>
|
||||||
@@ -25,7 +25,7 @@
|
|||||||
|
|
||||||
</ToggleButton.Template>
|
</ToggleButton.Template>
|
||||||
</ToggleButton>
|
</ToggleButton>
|
||||||
<TextBlock Name="PositionNameTxBl" Height="22" Width="68" FontSize="16" Margin="12,16,41,61"/>
|
<TextBlock Name="PositionNameTxBl" Height="22" Width="50" FontSize="16" Margin="20,40,70,53"/>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</UserControl>
|
</UserControl>
|
||||||
|
|||||||
@@ -281,12 +281,12 @@
|
|||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<TextBlock Name="SpeedTxBl" Grid.Column="0" Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
<TextBlock Name="SpeedTxBl" Grid.Column="0" Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="SpeedTxBx" Grid.Column="1"
|
<EgtWPFLib:EgtTextBox Name="SpeedTxBx" Grid.Column="1" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBoxInGroupBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBoxInGroupBox}" />
|
||||||
|
|
||||||
<TextBlock Name="MaxSpeedTxBl" Grid.Column="2"
|
<TextBlock Name="MaxSpeedTxBl" Grid.Column="2"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="MaxSpeedTxBx" Grid.Column="3"
|
<EgtWPFLib:EgtTextBox Name="MaxSpeedTxBx" Grid.Column="3" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBoxInGroupBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBoxInGroupBox}" />
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
@@ -384,7 +384,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="MaxAbsorptionTxBl" Grid.Column="0"
|
<TextBlock Name="MaxAbsorptionTxBl" Grid.Column="0"
|
||||||
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Grid.ColumnSpan="1" ScrollViewer.VerticalScrollBarVisibility="Disabled" TextWrapping="Wrap"/>
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}" Grid.ColumnSpan="1" ScrollViewer.VerticalScrollBarVisibility="Disabled" TextWrapping="Wrap"/>
|
||||||
<EgtWPFLib:EgtTextBox Name="MaxAbsorptionTxBx" Grid.Column="1"
|
<EgtWPFLib:EgtTextBox Name="MaxAbsorptionTxBx" Grid.Column="1" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_LeftCalculatorTextBoxInBorder}" />
|
Style="{DynamicResource OmagCut_LeftCalculatorTextBoxInBorder}" />
|
||||||
|
|
||||||
<TextBlock Name="MinFeedTxBl" Grid.Column="2" Style="{DynamicResource OmagCut_ToolsDBTextBlock}" />
|
<TextBlock Name="MinFeedTxBl" Grid.Column="2" Style="{DynamicResource OmagCut_ToolsDBTextBlock}" />
|
||||||
|
|||||||
@@ -162,6 +162,7 @@
|
|||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<TextBlock Text="{Binding Thickness_Msg}" Grid.Column="0" HorizontalAlignment="Center"
|
<TextBlock Text="{Binding Thickness_Msg}" Grid.Column="0" HorizontalAlignment="Center"
|
||||||
@@ -185,12 +186,19 @@
|
|||||||
<TextBlock Text="{Binding QExtra_Msg}" Grid.Column="6" HorizontalAlignment="Center"
|
<TextBlock Text="{Binding QExtra_Msg}" Grid.Column="6" HorizontalAlignment="Center"
|
||||||
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"
|
||||||
FontSize="{DynamicResource FontSize_GroupBoxHeader}"/>
|
FontSize="{DynamicResource FontSize_GroupBoxHeader}"/>
|
||||||
|
<TextBlock Text="{Binding AngComp_Msg}" Grid.Column="7" HorizontalAlignment="Center"
|
||||||
|
Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"
|
||||||
|
FontSize="{DynamicResource FontSize_GroupBoxHeader}"/>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
</GroupBox.Header>
|
</GroupBox.Header>
|
||||||
|
|
||||||
<!--Definizione della Grid dei parametri delle lavorazioni-->
|
<!--Definizione della Grid dei parametri delle lavorazioni-->
|
||||||
<Grid Grid.Column="2">
|
<Grid Grid.Column="2">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="308*"/>
|
||||||
|
<ColumnDefinition Width="73*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="7*"/>
|
<RowDefinition Height="7*"/>
|
||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
@@ -201,7 +209,7 @@
|
|||||||
ItemsSource="{Binding Path=SelectedItem.ParamList , ElementName=SubMaterialsLstBx}"
|
ItemsSource="{Binding Path=SelectedItem.ParamList , ElementName=SubMaterialsLstBx}"
|
||||||
SelectedItem="{Binding Path=SelectedItem.SelWjParam , ElementName=SubMaterialsLstBx}"
|
SelectedItem="{Binding Path=SelectedItem.SelWjParam , ElementName=SubMaterialsLstBx}"
|
||||||
Margin="0,0,0,0"
|
Margin="0,0,0,0"
|
||||||
Grid.RowSpan="2">
|
Grid.RowSpan="2" Grid.ColumnSpan="2">
|
||||||
<ListBox.ItemTemplate>
|
<ListBox.ItemTemplate>
|
||||||
<DataTemplate>
|
<DataTemplate>
|
||||||
<Grid Width="700">
|
<Grid Width="700">
|
||||||
@@ -213,6 +221,7 @@
|
|||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
<ColumnDefinition Width="1*"/>
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
<EgtWPFLib:EgtTextBox Text="{Binding Thickness}" Grid.Column="0"
|
<EgtWPFLib:EgtTextBox Text="{Binding Thickness}" Grid.Column="0"
|
||||||
@@ -229,13 +238,14 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorParamWjTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorParamWjTextBox}" />
|
||||||
<EgtWPFLib:EgtTextBox Text="{Binding QExtra}" Grid.Column="6"
|
<EgtWPFLib:EgtTextBox Text="{Binding QExtra}" Grid.Column="6"
|
||||||
Style="{DynamicResource OmagCut_CalculatorParamWjTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorParamWjTextBox}" />
|
||||||
|
<EgtWPFLib:EgtTextBox Text="{Binding dAngComp}" Grid.Column="7" IsLength="False"
|
||||||
|
Style="{DynamicResource OmagCut_CalculatorParamWjTextBox}" />
|
||||||
</Grid>
|
</Grid>
|
||||||
</DataTemplate>
|
</DataTemplate>
|
||||||
</ListBox.ItemTemplate>
|
</ListBox.ItemTemplate>
|
||||||
</ListBox>
|
</ListBox>
|
||||||
|
|
||||||
<UniformGrid Grid.Row="2" Columns="9" Grid.ColumnSpan="3">
|
<UniformGrid Grid.Row="2" Columns="9" Grid.ColumnSpan="2">
|
||||||
<Button Name="NewParamBtn" Grid.Column="0"
|
<Button Name="NewParamBtn" Grid.Column="0"
|
||||||
Command="{Binding NewWjParamCommand}"
|
Command="{Binding NewWjParamCommand}"
|
||||||
Content="{Binding New_Msg}"
|
Content="{Binding New_Msg}"
|
||||||
|
|||||||
@@ -8,18 +8,26 @@ Public Class WaterJetPageUC
|
|||||||
|
|
||||||
' Riferimento alla MainWindow
|
' Riferimento alla MainWindow
|
||||||
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Private m_refWaterjetDbWindowVM As EgtWPFLib5.WaterjetDbWindowVM
|
Private m_refWaterjetDbWindowVM As WaterjetDbWindowVM_OmagCUT
|
||||||
Private m_sOrigNewMaterial As String = String.Empty
|
Private m_sOrigNewMaterial As String = String.Empty
|
||||||
Private m_sOrigNewSubMaterial As String = String.Empty
|
Private m_sOrigNewSubMaterial As String = String.Empty
|
||||||
|
|
||||||
Private Sub WaterJetPage_Initialized(sender As Object, e As EventArgs)
|
Private Sub WaterJetPage_Initialized(sender As Object, e As EventArgs)
|
||||||
m_refWaterjetDbWindowVM = New EgtWPFLib5.WaterjetDbWindowVM(m_MainWindow.m_CurrentMachine.sMachDir)
|
m_refWaterjetDbWindowVM = New WaterjetDbWindowVM_OmagCUT(m_MainWindow.m_CurrentMachine.sMachDir)
|
||||||
|
'----------------------------------------------------------------------------------------
|
||||||
|
' TEMPORANEO - se dati in INCH e richiesta di frazioni eseguo la conversione in frazione!
|
||||||
|
ConvertParamListValueToFracrion()
|
||||||
|
'----------------------------------------------------------------------------------------
|
||||||
Me.DataContext = m_refWaterjetDbWindowVM
|
Me.DataContext = m_refWaterjetDbWindowVM
|
||||||
EgtWPFLib.Utility.MainWindow = m_MainWindow
|
EgtWPFLib.Utility.MainWindow = m_MainWindow
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Public Sub WaterJetPage_Reinitialize()
|
Public Sub WaterJetPage_Reinitialize()
|
||||||
m_refWaterjetDbWindowVM = New EgtWPFLib5.WaterjetDbWindowVM(m_MainWindow.m_CurrentMachine.sMachDir)
|
m_refWaterjetDbWindowVM = New WaterjetDbWindowVM_OmagCUT(m_MainWindow.m_CurrentMachine.sMachDir)
|
||||||
|
'----------------------------------------------------------------------------------------
|
||||||
|
' TEMPORANEO - se dati in INCH e richiesta di frazioni eseguo la conversione in frazione!
|
||||||
|
ConvertParamListValueToFracrion()
|
||||||
|
'----------------------------------------------------------------------------------------
|
||||||
Me.DataContext = m_refWaterjetDbWindowVM
|
Me.DataContext = m_refWaterjetDbWindowVM
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -51,5 +59,48 @@ Public Class WaterJetPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ConvertParamListValueToFracrion()
|
||||||
|
' TEMPORANEO - se dati in INCH e richiesta di frazioni eseguo la conversione in frazione!
|
||||||
|
Dim Index1 As Integer = 0
|
||||||
|
For Index1 = 0 To m_refWaterjetDbWindowVM.MaterialList.Count - 1
|
||||||
|
Dim Index2 As Integer = 0
|
||||||
|
For Index2 = 0 To m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList.Count - 1
|
||||||
|
Dim Index3 As Integer = 0
|
||||||
|
For Index3 = 0 To m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList.Count - 1
|
||||||
|
Dim dThickness As Double
|
||||||
|
Dim dQ1 As Double
|
||||||
|
Dim dQ2 As Double
|
||||||
|
Dim dQ3 As Double
|
||||||
|
Dim dQ4 As Double
|
||||||
|
Dim dQ5 As Double
|
||||||
|
Dim dQExtra As Double
|
||||||
|
Dim dAngComp As Double
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).Thickness, dThickness)
|
||||||
|
Dim sVal As String = LenToString(dThickness, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetThickness(sVal)
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).Q1, dQ1)
|
||||||
|
sVal = LenToString(dQ1, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetQ1(sVal)
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).Q2, dQ2)
|
||||||
|
sVal = LenToString(dQ2, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetQ2(sVal)
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).Q3, dQ3)
|
||||||
|
sVal = LenToString(dQ3, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetQ3(sVal)
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).Q4, dQ4)
|
||||||
|
sVal = LenToString(dQ4, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetQ4(sVal)
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).Q5, dQ5)
|
||||||
|
sVal = LenToString(dQ5, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetQ5(sVal)
|
||||||
|
StringToLen(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).QExtra, dQExtra)
|
||||||
|
sVal = LenToString(dQExtra, 3)
|
||||||
|
m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).SetQExtra(sVal)
|
||||||
|
StringToDouble(m_refWaterjetDbWindowVM.MaterialList(Index1).SubMaterialList(Index2).ParamList(Index3).dAngComp, dAngComp)
|
||||||
|
Next
|
||||||
|
Next
|
||||||
|
Next
|
||||||
|
End Sub
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|
||||||
|
|||||||
@@ -445,6 +445,12 @@ Public Class WaterjetDbWindowVM
|
|||||||
End Get
|
End Get
|
||||||
End Property
|
End Property
|
||||||
|
|
||||||
|
Public ReadOnly Property AngComp_Msg As String
|
||||||
|
Get
|
||||||
|
Return "Ang"
|
||||||
|
End Get
|
||||||
|
End Property
|
||||||
|
|
||||||
Public ReadOnly Property New_Msg As String
|
Public ReadOnly Property New_Msg As String
|
||||||
Get
|
Get
|
||||||
Return "Nuovo"
|
Return "Nuovo"
|
||||||
@@ -516,7 +522,14 @@ Public Class WaterjetDbWindowVM
|
|||||||
StringToDouble(sParams(4), dQ4)
|
StringToDouble(sParams(4), dQ4)
|
||||||
StringToDouble(sParams(5), dQ5)
|
StringToDouble(sParams(5), dQ5)
|
||||||
StringToDouble(sParams(6), dQExtra)
|
StringToDouble(sParams(6), dQExtra)
|
||||||
QParamList.Add(New WjParam(QInd, dThickness, dQ1, dQ2, dQ3, dQ4, dQ5, dQExtra, m_refWaterPageV))
|
Dim LocalWjParam As New WjParam(QInd, dThickness, dQ1, dQ2, dQ3, dQ4, dQ5, dQExtra, m_refWaterPageV)
|
||||||
|
QParamList.Add(LocalWjParam)
|
||||||
|
' leggo il nuovo parametro di correzione conicità (di default il parametro è 0)
|
||||||
|
If sParams.Length() >= 8 Then
|
||||||
|
Dim dAngCompo As Double
|
||||||
|
StringToDouble(sParams(7), dAngCompo)
|
||||||
|
LocalWjParam.dAngComp = dAngCompo
|
||||||
|
End If
|
||||||
End If
|
End If
|
||||||
QInd += 1
|
QInd += 1
|
||||||
End While
|
End While
|
||||||
@@ -868,6 +881,17 @@ Public Class WjParam
|
|||||||
End Set
|
End Set
|
||||||
End Property
|
End Property
|
||||||
|
|
||||||
|
' angolo di compensazione conicità getto: 01/02/2023 ver 2.5b1
|
||||||
|
Private m_dAngComp As Double = 0
|
||||||
|
Public Property dAngComp As Double
|
||||||
|
Get
|
||||||
|
Return m_dAngComp
|
||||||
|
End Get
|
||||||
|
Set(value As Double)
|
||||||
|
m_dAngComp = value
|
||||||
|
End Set
|
||||||
|
End Property
|
||||||
|
|
||||||
Public ReadOnly Property ParamLstBx_Width As Double
|
Public ReadOnly Property ParamLstBx_Width As Double
|
||||||
Get
|
Get
|
||||||
Return m_refWaterPageV.ParamsGpBx.ActualWidth - 20
|
Return m_refWaterPageV.ParamsGpBx.ActualWidth - 20
|
||||||
|
|||||||
@@ -0,0 +1,61 @@
|
|||||||
|
Imports System.Collections.ObjectModel
|
||||||
|
Imports System.IO
|
||||||
|
Imports EgtUILib
|
||||||
|
Imports EgtWPFLib5
|
||||||
|
Imports EgtWPFLib
|
||||||
|
|
||||||
|
' nuova libreria EgtWPFLib5 ver 2.4g1
|
||||||
|
Public Class WaterjetDbWindowVM_OmagCUT
|
||||||
|
Inherits EgtWPFLib5.WaterjetDbWindowVM
|
||||||
|
|
||||||
|
Public Function CloseWaterjetDb_OmagCut(MainWindow As Window) As SaveWndBtnEnum
|
||||||
|
If bIsModified Then
|
||||||
|
Dim SaveWjDbWnd As New EgtMsgBox(MainWindow, "", EgtMsg(31759), EgtMsgBox.Buttons.YES_NO_CANCEL, EgtMsgBox.Icons.NULL)
|
||||||
|
Select Case SaveWjDbWnd.m_nPressedBtn
|
||||||
|
Case 1 ' Yes
|
||||||
|
WriteWaterjetDb()
|
||||||
|
bIsModified = False
|
||||||
|
Return SaveWndBtnEnum.YES
|
||||||
|
Case 2 ' No
|
||||||
|
Return SaveWndBtnEnum.NO
|
||||||
|
Case Else ' Cancel
|
||||||
|
Return SaveWndBtnEnum.CANCEL
|
||||||
|
End Select
|
||||||
|
Else
|
||||||
|
Dim bExitFor As Boolean = False
|
||||||
|
For Each Material As EgtWPFLib5.WjMaterial In MaterialList
|
||||||
|
If Not IsNothing(Material.SubMaterialList) Then
|
||||||
|
For Each SubMaterial As EgtWPFLib5.WjSubMaterial In Material.SubMaterialList
|
||||||
|
If Not IsNothing(SubMaterial.ParamList) Then
|
||||||
|
For Each QParam As EgtWPFLib5.WjParam In SubMaterial.ParamList
|
||||||
|
bExitFor = QParam.IsModified()
|
||||||
|
If bExitFor Then Exit For
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
If bExitFor Then Exit For
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
If bExitFor Then Exit For
|
||||||
|
Next
|
||||||
|
If bExitFor Then
|
||||||
|
Dim SaveWjDbWnd As New EgtMsgBox(MainWindow, "", EgtMsg(31759), EgtMsgBox.Buttons.YES_NO_CANCEL, EgtMsgBox.Icons.NULL)
|
||||||
|
Select Case SaveWjDbWnd.m_nPressedBtn
|
||||||
|
Case 1 ' Yes
|
||||||
|
WriteWaterjetDb()
|
||||||
|
bIsModified = False
|
||||||
|
Return SaveWndBtnEnum.YES
|
||||||
|
Case 2 ' No
|
||||||
|
Return SaveWndBtnEnum.NO
|
||||||
|
Case Else ' Cancel
|
||||||
|
Return SaveWndBtnEnum.CANCEL
|
||||||
|
End Select
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
Return SaveWndBtnEnum.YES
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Sub New(sMachDir As String)
|
||||||
|
MyBase.New(sMachDir)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
End Class
|
||||||
@@ -2,6 +2,7 @@
|
|||||||
Imports System.Collections.ObjectModel
|
Imports System.Collections.ObjectModel
|
||||||
Imports EgtUILib
|
Imports EgtUILib
|
||||||
Imports EgtWPFLib
|
Imports EgtWPFLib
|
||||||
|
Imports EgtPHOTOLib
|
||||||
Imports System.ComponentModel
|
Imports System.ComponentModel
|
||||||
Imports System.Threading
|
Imports System.Threading
|
||||||
Imports System.Windows.Threading
|
Imports System.Windows.Threading
|
||||||
@@ -37,6 +38,8 @@ Class MainWindow
|
|||||||
Friend m_MachinePageUC As MachinePageUC
|
Friend m_MachinePageUC As MachinePageUC
|
||||||
Friend m_OptionsPageUC As OptionsPageUC
|
Friend m_OptionsPageUC As OptionsPageUC
|
||||||
|
|
||||||
|
Friend m_IsClosingApplication As Integer = 0
|
||||||
|
|
||||||
' Dichiarazione variabili direttori
|
' Dichiarazione variabili direttori
|
||||||
Private m_sExeRoot As String = String.Empty
|
Private m_sExeRoot As String = String.Empty
|
||||||
Private m_sDataRoot As String = String.Empty
|
Private m_sDataRoot As String = String.Empty
|
||||||
@@ -302,7 +305,7 @@ Class MainWindow
|
|||||||
GetPrivateProfileString(S_MACH, K_CURRMACH, "", m_sCurrMachine, m_sIniFile)
|
GetPrivateProfileString(S_MACH, K_CURRMACH, "", m_sCurrMachine, m_sIniFile)
|
||||||
' Impostazione path MachIni file
|
' Impostazione path MachIni file
|
||||||
m_sMachIniFile = m_sMachinesRoot & "\" & m_sCurrMachine & "\" & m_sCurrMachine & ".ini"
|
m_sMachIniFile = m_sMachinesRoot & "\" & m_sCurrMachine & "\" & m_sCurrMachine & ".ini"
|
||||||
' Impostazione path KitIni file
|
' Impostazione path Kit file
|
||||||
m_sKitsFile = m_sMachinesRoot & "\" & m_sCurrMachine & "\" & MACHININGS_DIR & "\" & KITS_FILE
|
m_sKitsFile = m_sMachinesRoot & "\" & m_sCurrMachine & "\" & MACHININGS_DIR & "\" & KITS_FILE
|
||||||
' Imposto tipo di chiave
|
' Imposto tipo di chiave
|
||||||
#If TRIAL Then
|
#If TRIAL Then
|
||||||
@@ -320,11 +323,13 @@ Class MainWindow
|
|||||||
Dim sNestKey As String = ""
|
Dim sNestKey As String = ""
|
||||||
EgtUILib.GetPrivateProfileString(S_LICENCE, K_NESTKEY, "", sNestKey, sLicFile)
|
EgtUILib.GetPrivateProfileString(S_LICENCE, K_NESTKEY, "", sNestKey, sLicFile)
|
||||||
EgtSetNestKey(sNestKey)
|
EgtSetNestKey(sNestKey)
|
||||||
|
Dim bNetHwKey As Boolean = ( GetPrivateProfileInt(S_GENERAL, K_NETKEY, 0, m_sIniFile) = 1)
|
||||||
|
EgtSetNetHwKey( bNetHwKey)
|
||||||
' Verifico abilitazione nesting automatico
|
' Verifico abilitazione nesting automatico
|
||||||
m_bAutoNest = Not String.IsNullOrWhiteSpace(sNestKey)
|
m_bAutoNest = Not String.IsNullOrWhiteSpace(sNestKey)
|
||||||
' Recupero opzioni della chiave
|
' Recupero opzioni della chiave
|
||||||
Dim bKey As Boolean = EgtGetKeyLevel(9423, 2406, 1, m_nKeyLevel) And
|
Dim bKey As Boolean = EgtGetKeyLevel(9423, 2504, 1, m_nKeyLevel) And
|
||||||
EgtGetKeyOptions(9423, 2406, 1, m_nKeyOptions)
|
EgtGetKeyOptions(9423, 2504, 1, m_nKeyOptions)
|
||||||
' Verifico abilitazione prodotto
|
' Verifico abilitazione prodotto
|
||||||
Dim bProd As Boolean = GetKeyOption(KEY_OPT.CUT_BASE)
|
Dim bProd As Boolean = GetKeyOption(KEY_OPT.CUT_BASE)
|
||||||
' Inizializzazione generale di EgtInterface
|
' Inizializzazione generale di EgtInterface
|
||||||
@@ -498,6 +503,64 @@ Class MainWindow
|
|||||||
AddHandler m_ProdLineTimer.Tick, AddressOf OnProdLine
|
AddHandler m_ProdLineTimer.Tick, AddressOf OnProdLine
|
||||||
' Imposto riferimento a funzione delle textbox che disattiva scene in libreria
|
' Imposto riferimento a funzione delle textbox che disattiva scene in libreria
|
||||||
EgtWPFLib.EgtTextBox.m_refScenesIsEnabled = AddressOf IsEnabledScenes
|
EgtWPFLib.EgtTextBox.m_refScenesIsEnabled = AddressOf IsEnabledScenes
|
||||||
|
|
||||||
|
' --------------------------------- SLAB DB -------------------------------------------------------
|
||||||
|
If GetPrivateProfileInt(S_SCRAPS, K_ENABLESCRAPS, 0, GetIniFile()) <> 0 Then
|
||||||
|
' leggo il direttorio in cui cercare il database delle lastre
|
||||||
|
Dim PhotDir As String = String.Empty
|
||||||
|
GetPrivateProfileString(S_SCRAPS, K_PHOTODIR, "", PhotDir, GetIniFile())
|
||||||
|
' verifico che esista il file "OmagPHOTOVb.sqlite" nel direttorio inidicato
|
||||||
|
If System.IO.File.Exists(PhotDir.Trim & "\" & DB_FILENAME) Then
|
||||||
|
|
||||||
|
If Not ManageDb.ConnectToDb(PhotDir.Trim & "\" & DB_FILENAME) Then
|
||||||
|
EgtOutLog("Error connecting to DB: " & PhotDir.Trim & "\" & DB_FILENAME)
|
||||||
|
' coumico che il grezzo contiene un pezzo e quindi non può essere definito come grezzo
|
||||||
|
m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
m_CurrentProjectPageUC.SetErrorMessage("Denied connection SlabDB")
|
||||||
|
Else
|
||||||
|
' Impostazione direttorio per backup
|
||||||
|
Dim BackUpDir As String = m_sDataRoot & "\BackUp"
|
||||||
|
Directory.CreateDirectory(BackUpDir)
|
||||||
|
EgtPHOTOLib.MainData.SetConfigDir(m_sConfigDir)
|
||||||
|
EgtPHOTOLib.MainData.SetKeyLevel(m_nKeyLevel)
|
||||||
|
EgtPHOTOLib.MainData.SetKeyOptions(CInt(m_nKeyOptions))
|
||||||
|
EgtPHOTOLib.MainData.SetPhotoDir(PhotDir)
|
||||||
|
EgtPHOTOLib.MainData.SetBackUpDir(BackUpDir)
|
||||||
|
EgtPHOTOLib.MainData.SetIsOMagCUT(True)
|
||||||
|
Dim sLastBlock As String = String.Empty
|
||||||
|
GetPrivateProfileString(S_SCRAPS, K_LASTBLOCK, "", sLastBlock, GetIniFile())
|
||||||
|
If Not String.IsNullOrEmpty(sLastBlock) Then
|
||||||
|
EgtPHOTOLib.MainData.SetLastBlock(sLastBlock)
|
||||||
|
End If
|
||||||
|
|
||||||
|
If GetPrivateProfileInt(S_SCRAPS, K_ENABLE_PRINTER, 0, GetIniFile()) = 1 Then
|
||||||
|
' leggo nome file prn (per stampante zebra)
|
||||||
|
Dim m_TemplateFilePrinter As String = String.Empty
|
||||||
|
GetPrivateProfileString(S_SCRAPS, K_TEMPLATE, m_sDataRoot & "\Label\Default.prn", m_TemplateFilePrinter, GetIniFile())
|
||||||
|
' leggo nome del direttorio in cui scrivere il file ini (per stampante zebra) -- solo se si desidera scrivere il file in un direttorio diverso
|
||||||
|
Dim m_DatFilePrinter As String = String.Empty
|
||||||
|
GetPrivateProfileString(S_SCRAPS, K_DAT, m_sDataRoot & "\Temp", m_DatFilePrinter, GetIniFile())
|
||||||
|
' leggo nome file exe (per stampante zebra)
|
||||||
|
Dim m_ZebraUtilitiesExe As String = String.Empty
|
||||||
|
GetPrivateProfileString(S_SCRAPS, K_ZEBRAUTILITIES, System.AppDomain.CurrentDomain.BaseDirectory & "ZebraPrinterUtilitiesR32.exe", m_ZebraUtilitiesExe, GetIniFile())
|
||||||
|
EgtPHOTOLib.MainData.SetTemplateFilePrinter(m_TemplateFilePrinter)
|
||||||
|
EgtPHOTOLib.MainData.SetDataFilePrinter(m_DatFilePrinter)
|
||||||
|
EgtPHOTOLib.MainData.SetZebraPrinterExe(m_ZebraUtilitiesExe)
|
||||||
|
EgtPHOTOLib.MainData.SetPrinterVisibility(True)
|
||||||
|
Else
|
||||||
|
EgtPHOTOLib.MainData.SetPrinterVisibility(False)
|
||||||
|
End If
|
||||||
|
|
||||||
|
' è permessa una sola istanza alla volta del programma OmagCUT -> "(1)" : "(" & nIstance.ToString & ")"
|
||||||
|
EgtPHOTOLib.MainData.SetUser(Environment.MachineName & "\" & Environment.UserName & " (1)")
|
||||||
|
Dim sIdKey As String = String.Empty
|
||||||
|
EgtGetKeyInfo(sIdKey)
|
||||||
|
EgtPHOTOLib.MainData.SetKey(sIdKey)
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' --------------------------------- SLAB DB -------------------------------------------------------
|
||||||
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ManageSingleIstance()
|
Private Sub ManageSingleIstance()
|
||||||
@@ -546,6 +609,16 @@ Class MainWindow
|
|||||||
m_WorkInProgressPageUC.Prepare()
|
m_WorkInProgressPageUC.Prepare()
|
||||||
m_WorkInProgressPageUC.UpdateTools()
|
m_WorkInProgressPageUC.UpdateTools()
|
||||||
|
|
||||||
|
Dim sVal As String = String.Empty
|
||||||
|
If m_CurrentMachine.GetUserNote("FsevLength", sVal, m_CurrentMachine.sCurrSaw) Then
|
||||||
|
StringToDouble(sVal, m_CurrentMachine.dFsevLength)
|
||||||
|
m_CurrentMachine.SetFsevLength(m_CurrentMachine.dFsevLength)
|
||||||
|
End If
|
||||||
|
If m_CurrentMachine.GetUserNote("FsevPerc", sVal, m_CurrentMachine.sCurrSaw) Then
|
||||||
|
StringToDouble(sVal, m_CurrentMachine.dFsevPerc)
|
||||||
|
m_CurrentMachine.SetFsevPerc(m_CurrentMachine.dFsevPerc)
|
||||||
|
End If
|
||||||
|
|
||||||
' Se macchina fotografica abilitata, ne inizializzo il gestore
|
' Se macchina fotografica abilitata, ne inizializzo il gestore
|
||||||
#If Not TRIAL Then
|
#If Not TRIAL Then
|
||||||
If GetKeyOption(MainWindow.KEY_OPT.MAN_PHOTO) Then
|
If GetKeyOption(MainWindow.KEY_OPT.MAN_PHOTO) Then
|
||||||
@@ -623,6 +696,8 @@ Class MainWindow
|
|||||||
MainWindowGrid.Children.Remove(m_OptionsPageUC)
|
MainWindowGrid.Children.Remove(m_OptionsPageUC)
|
||||||
MainWindowGrid.Children.Add(m_WorkInProgressPageUC)
|
MainWindowGrid.Children.Add(m_WorkInProgressPageUC)
|
||||||
m_ActivePage = Pages.WorkInProgress
|
m_ActivePage = Pages.WorkInProgress
|
||||||
|
Case Else
|
||||||
|
WorkInProgressBtn.IsChecked = False
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -681,6 +756,8 @@ Class MainWindow
|
|||||||
MainWindowGrid.Children.Add(m_CurrentProjectPageUC)
|
MainWindowGrid.Children.Add(m_CurrentProjectPageUC)
|
||||||
m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Add(m_DirectCutPageUC)
|
m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Add(m_DirectCutPageUC)
|
||||||
m_ActivePage = Pages.DirectCut
|
m_ActivePage = Pages.DirectCut
|
||||||
|
Case Else
|
||||||
|
WorkInProgressBtn.IsChecked = False
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -736,6 +813,8 @@ Class MainWindow
|
|||||||
MainWindowGrid.Children.Add(m_CurrentProjectPageUC)
|
MainWindowGrid.Children.Add(m_CurrentProjectPageUC)
|
||||||
m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Add(m_CadCutPageUC)
|
m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Add(m_CadCutPageUC)
|
||||||
m_ActivePage = Pages.CadCut
|
m_ActivePage = Pages.CadCut
|
||||||
|
Case Else
|
||||||
|
CadCutBtn.IsChecked = False
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -792,6 +871,8 @@ Class MainWindow
|
|||||||
MainWindowGrid.Children.Add(m_CurrentProjectPageUC)
|
MainWindowGrid.Children.Add(m_CurrentProjectPageUC)
|
||||||
m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Add(m_FrameCutPageUC)
|
m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Add(m_FrameCutPageUC)
|
||||||
m_ActivePage = Pages.FrameCut
|
m_ActivePage = Pages.FrameCut
|
||||||
|
Case Else
|
||||||
|
If FrameCutBtn.IsEnabled Then FrameCutBtn.IsChecked = False
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -843,6 +924,8 @@ Class MainWindow
|
|||||||
MainWindowGrid.Children.Remove(m_OptionsPageUC)
|
MainWindowGrid.Children.Remove(m_OptionsPageUC)
|
||||||
MainWindowGrid.Children.Add(m_MachinePageUC)
|
MainWindowGrid.Children.Add(m_MachinePageUC)
|
||||||
m_ActivePage = Pages.Machine
|
m_ActivePage = Pages.Machine
|
||||||
|
Case Else
|
||||||
|
MachineBtn.IsChecked = False
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -899,7 +982,7 @@ Class MainWindow
|
|||||||
MainWindowGrid.Children.Add(m_OptionsPageUC)
|
MainWindowGrid.Children.Add(m_OptionsPageUC)
|
||||||
m_ActivePage = Pages.Options
|
m_ActivePage = Pages.Options
|
||||||
Case Pages.Options
|
Case Pages.Options
|
||||||
OptionsBtn.IsChecked = True
|
OptionsBtn.IsChecked = False
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -1004,6 +1087,19 @@ Class MainWindow
|
|||||||
m_CurrentProjectPageUC.SaveNamedProject()
|
m_CurrentProjectPageUC.SaveNamedProject()
|
||||||
m_CurrentProjectPageUC.SaveProject()
|
m_CurrentProjectPageUC.SaveProject()
|
||||||
End If
|
End If
|
||||||
|
' Inizio la chiusura del programma (verifico di aver terminato il processo DripFeed)
|
||||||
|
EgtOutLog("Iniziato processo di chiusura programma")
|
||||||
|
m_IsClosingApplication = 1
|
||||||
|
Dim nCount As Integer = 0
|
||||||
|
While m_IsClosingApplication <> 2
|
||||||
|
If nCount > 5 Then
|
||||||
|
Exit While
|
||||||
|
End If
|
||||||
|
' verifico che il processo DripFeed sia terminato
|
||||||
|
EgtOutLog("Stato chiusura programma: " & m_IsClosingApplication.ToString)
|
||||||
|
Thread.Sleep(100)
|
||||||
|
nCount += 1
|
||||||
|
End While
|
||||||
' Uscita
|
' Uscita
|
||||||
MainWindowExit()
|
MainWindowExit()
|
||||||
End Sub
|
End Sub
|
||||||
@@ -1045,19 +1141,21 @@ Class MainWindow
|
|||||||
' Se non sono in tagli diretti tutto ok
|
' Se non sono in tagli diretti tutto ok
|
||||||
If m_ActivePage <> Pages.DirectCut Then Return True
|
If m_ActivePage <> Pages.DirectCut Then Return True
|
||||||
' Concludo le attività in corso
|
' Concludo le attività in corso
|
||||||
Select Case m_DirectCutPageUC.m_ActiveDirectCutPage
|
Select Case m_DirectCutPageUC.m_ControlsDirectCutUC.m_ActiveDirectCutPage
|
||||||
Case DirectCutPageUC.DirectCutPages.SingleCut
|
Case ControlsDirectCutUC.DirectCutPages.SingleCut
|
||||||
m_DirectCutPageUC.m_SingleCut.SingleCut_Unloaded(sender, e)
|
m_DirectCutPageUC.m_ControlsDirectCutUC.m_SingleCut.SingleCut_Unloaded(sender, e)
|
||||||
Case DirectCutPageUC.DirectCutPages.MultipleCut
|
Case ControlsDirectCutUC.DirectCutPages.MultipleCut
|
||||||
m_DirectCutPageUC.m_MultipleCut.MultipleCut_Unloaded(sender, e)
|
m_DirectCutPageUC.m_ControlsDirectCutUC.m_MultipleCut.MultipleCut_Unloaded(sender, e)
|
||||||
Case DirectCutPageUC.DirectCutPages.GridCut
|
Case ControlsDirectCutUC.DirectCutPages.GridCut
|
||||||
m_DirectCutPageUC.m_GridCut.GridCut_Unloaded(sender, e)
|
m_DirectCutPageUC.m_ControlsDirectCutUC.m_GridCut.GridCut_Unloaded(sender, e)
|
||||||
Case DirectCutPageUC.DirectCutPages.CopyTemplate
|
Case ControlsDirectCutUC.DirectCutPages.FlatteningCut
|
||||||
m_DirectCutPageUC.m_CopyTemplate.CopyTemplate_Unloaded(sender, e)
|
m_DirectCutPageUC.m_ControlsDirectCutUC.m_FlatteningCut.FlatteningCut_Unloaded(sender, e)
|
||||||
Case DirectCutPageUC.DirectCutPages.FlatteningCut
|
Case ControlsDirectCutUC.DirectCutPages.CopyTemplate
|
||||||
m_DirectCutPageUC.m_FlatteningCut.FlatteningCut_Unloaded(sender, e)
|
m_DirectCutPageUC.m_ControlsDirectCutUC1.m_CopyTemplate.CopyTemplate_Unloaded(sender, e)
|
||||||
Case DirectCutPageUC.DirectCutPages.SawTest
|
Case ControlsDirectCutUC.DirectCutPages.Polishing
|
||||||
m_DirectCutPageUC.m_SawTest.SawTest_Unloaded(sender, e)
|
m_DirectCutPageUC.m_ControlsDirectCutUC1.m_Polishing.Polishing_Unloaded(sender, e)
|
||||||
|
Case ControlsDirectCutUC.DirectCutPages.SawTest
|
||||||
|
m_DirectCutPageUC.m_ControlsDirectCutUC1.m_SawTest.SawTest_Unloaded(sender, e)
|
||||||
End Select
|
End Select
|
||||||
Return True
|
Return True
|
||||||
End Function
|
End Function
|
||||||
@@ -1092,10 +1190,10 @@ Class MainWindow
|
|||||||
Case MachinePageUC.MachinePages.WaterJet
|
Case MachinePageUC.MachinePages.WaterJet
|
||||||
' Verifica ed eventuale salvataggio Db Waterjet
|
' Verifica ed eventuale salvataggio Db Waterjet
|
||||||
Dim m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Dim m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
Dim nPressedBtn As Integer = DirectCast(m_MachinePageUC.m_WaterJetPageUC.DataContext, EgtWPFLib5.WaterjetDbWindowVM).CloseWaterjetDb_OmagCut(m_MainWindow)
|
Dim nPressedBtn As Integer = DirectCast(m_MachinePageUC.m_WaterJetPageUC.DataContext, WaterjetDbWindowVM_OmagCUT).CloseWaterjetDb_OmagCut(m_MainWindow)
|
||||||
If nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.CANCEL Then
|
If nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.CANCEL Then
|
||||||
Return False
|
Return False
|
||||||
ElseIf nPressedBtn = EgtWPFLib5.WaterjetDbWindowVM.SaveWndBtnEnum.NO Then
|
ElseIf nPressedBtn = WaterjetDbWindowVM_OmagCUT.SaveWndBtnEnum.NO Then
|
||||||
m_MachinePageUC.m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
m_MachinePageUC.m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
End If
|
End If
|
||||||
End Select
|
End Select
|
||||||
|
|||||||
@@ -20,9 +20,9 @@ Imports System.Windows
|
|||||||
<Assembly: AssemblyTitle("OmagCUTR32.exe")>
|
<Assembly: AssemblyTitle("OmagCUTR32.exe")>
|
||||||
<Assembly: AssemblyDescription("OmagCUT 32 bit")>
|
<Assembly: AssemblyDescription("OmagCUT 32 bit")>
|
||||||
#End If
|
#End If
|
||||||
<Assembly: AssemblyCompany("EgalTech s.r.l.")>
|
<Assembly: AssemblyCompany("Egalware s.r.l.")>
|
||||||
<Assembly: AssemblyProduct("OmagCUT")>
|
<Assembly: AssemblyProduct("OmagCUT")>
|
||||||
<Assembly: AssemblyCopyright("Copyright © 2015-2022 by EgalTech s.r.l.")>
|
<Assembly: AssemblyCopyright("Copyright © 2015-2023 by Egalware s.r.l.")>
|
||||||
<Assembly: AssemblyTrademark("")>
|
<Assembly: AssemblyTrademark("")>
|
||||||
<Assembly: ComVisible(False)>
|
<Assembly: ComVisible(False)>
|
||||||
|
|
||||||
@@ -62,5 +62,5 @@ Imports System.Windows
|
|||||||
' by using the '*' as shown below:
|
' by using the '*' as shown below:
|
||||||
' <Assembly: AssemblyVersion("1.0.*")>
|
' <Assembly: AssemblyVersion("1.0.*")>
|
||||||
|
|
||||||
<Assembly: AssemblyVersion("2.4.6.2")>
|
<Assembly: AssemblyVersion("2.5.4.3")>
|
||||||
<Assembly: AssemblyFileVersion("2.4.6.2")>
|
<Assembly: AssemblyFileVersion("2.5.4.3")>
|
||||||
|
|||||||
@@ -2,6 +2,8 @@
|
|||||||
Imports System.Globalization
|
Imports System.Globalization
|
||||||
Imports System.Collections.ObjectModel
|
Imports System.Collections.ObjectModel
|
||||||
Imports EgtUILib
|
Imports EgtUILib
|
||||||
|
Imports System.IO
|
||||||
|
Imports System.Text
|
||||||
|
|
||||||
Public Class CNCommunication
|
Public Class CNCommunication
|
||||||
|
|
||||||
@@ -31,6 +33,7 @@ Public Class CNCommunication
|
|||||||
Private m_bNewDeltaData As Boolean = True
|
Private m_bNewDeltaData As Boolean = True
|
||||||
Private m_bNewVarData As Boolean = False
|
Private m_bNewVarData As Boolean = False
|
||||||
Private m_bTimerBusy As Boolean = False
|
Private m_bTimerBusy As Boolean = False
|
||||||
|
Private m_bTimerAxesBusy As Boolean = False
|
||||||
|
|
||||||
Private m_IsNewConsole As Boolean = False
|
Private m_IsNewConsole As Boolean = False
|
||||||
|
|
||||||
@@ -39,6 +42,7 @@ Public Class CNCommunication
|
|||||||
|
|
||||||
' Timer
|
' Timer
|
||||||
Private m_RefreshTimer As New DispatcherTimer
|
Private m_RefreshTimer As New DispatcherTimer
|
||||||
|
Private m_RefreshAxesFanuc As New DispatcherTimer
|
||||||
|
|
||||||
' Nomi e indici degli assi macchina
|
' Nomi e indici degli assi macchina
|
||||||
Private m_bAxesOk As Boolean = False
|
Private m_bAxesOk As Boolean = False
|
||||||
@@ -101,6 +105,12 @@ Public Class CNCommunication
|
|||||||
m_RefreshTimer.Interval = TimeSpan.FromMilliseconds(100)
|
m_RefreshTimer.Interval = TimeSpan.FromMilliseconds(100)
|
||||||
m_RefreshTimer.Start()
|
m_RefreshTimer.Start()
|
||||||
End If
|
End If
|
||||||
|
' solo per controllo FANUC creo un timer apposito solo per la lettura degli assi
|
||||||
|
If m_nNCType = 4 Then
|
||||||
|
AddHandler m_RefreshAxesFanuc.Tick, AddressOf RefreshAxesFanucTimer_tick
|
||||||
|
m_RefreshAxesFanuc.Interval = TimeSpan.FromMilliseconds(50)
|
||||||
|
m_RefreshAxesFanuc.Start()
|
||||||
|
End If
|
||||||
|
|
||||||
' Leggo dati sugli assi della macchina
|
' Leggo dati sugli assi della macchina
|
||||||
ReadAxesData()
|
ReadAxesData()
|
||||||
@@ -117,6 +127,8 @@ Public Class CNCommunication
|
|||||||
|
|
||||||
If m_nNCType = 3 Then
|
If m_nNCType = 3 Then
|
||||||
RefreshNoEvents()
|
RefreshNoEvents()
|
||||||
|
ElseIf m_nNCType = 4 Then
|
||||||
|
RefreshFANUC()
|
||||||
Else
|
Else
|
||||||
Refresh()
|
Refresh()
|
||||||
End If
|
End If
|
||||||
@@ -129,8 +141,22 @@ Public Class CNCommunication
|
|||||||
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub RefreshAxesFanucTimer_tick()
|
||||||
|
If Not m_bTimerAxesBusy Then
|
||||||
|
m_bTimerAxesBusy = True
|
||||||
|
m_RefreshAxesFanuc.Stop()
|
||||||
|
|
||||||
|
RefreshAxesFANUC()
|
||||||
|
|
||||||
|
m_bTimerAxesBusy = False
|
||||||
|
m_RefreshAxesFanuc.Start()
|
||||||
|
Else
|
||||||
|
Dim nDummy As Integer = 10
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub ReadAxesData()
|
Private Sub ReadAxesData()
|
||||||
' Nomi e indici degli assi macchina
|
' Nomi e indici degli assi macchina: definisco il nome degli assi da satampare nella pagina MachineStatusUC
|
||||||
m_bAxesOk = True
|
m_bAxesOk = True
|
||||||
GetPrivateProfileString(S_AXES, K_L1NAME, "X", m_sA1, m_MainWindow.GetMachIniFile())
|
GetPrivateProfileString(S_AXES, K_L1NAME, "X", m_sA1, m_MainWindow.GetMachIniFile())
|
||||||
m_nA1 = GetPrivateProfileInt(S_AXES, K_L1ID, 0, m_MainWindow.GetMachIniFile())
|
m_nA1 = GetPrivateProfileInt(S_AXES, K_L1ID, 0, m_MainWindow.GetMachIniFile())
|
||||||
@@ -222,6 +248,11 @@ Public Class CNCommunication
|
|||||||
m_CN = New Num.NumNC
|
m_CN = New Num.NumNC
|
||||||
Case 3
|
Case 3
|
||||||
m_CN = New CN_Siemens
|
m_CN = New CN_Siemens
|
||||||
|
Case 4
|
||||||
|
' Fanuc
|
||||||
|
m_CN = New Fanuc.Fanuc
|
||||||
|
' proveddo a sovrscrivere i datti di comunicazione PC-NC settati di default nella classe CN_Generico
|
||||||
|
m_MainWindow.m_CurrentMachine.InitFANUC(m_CN)
|
||||||
End Select
|
End Select
|
||||||
' Recupero la stringa di inizializzazione della comunicazione
|
' Recupero la stringa di inizializzazione della comunicazione
|
||||||
|
|
||||||
@@ -354,6 +385,11 @@ Public Class CNCommunication
|
|||||||
If Not String.IsNullOrEmpty(sVal) Then m_CN.SetCnDataVar(CN_generico.CnData.Remote, sVal)
|
If Not String.IsNullOrEmpty(sVal) Then m_CN.SetCnDataVar(CN_generico.CnData.Remote, sVal)
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' Solo per controllo FANUNC
|
||||||
|
GetPrivateProfileString(S_NCDATA, K_NAXES, "", sVal, m_MainWindow.GetMachIniFile())
|
||||||
|
m_CN.SetCnDataVar(CN_generico.CnData.nAxes, sVal)
|
||||||
|
|
||||||
|
|
||||||
' Inizializzo la comunicazione
|
' Inizializzo la comunicazione
|
||||||
m_CN.Init()
|
m_CN.Init()
|
||||||
|
|
||||||
@@ -418,6 +454,17 @@ Public Class CNCommunication
|
|||||||
m_MachineStatus.MachineStatusGrid.Background = Application.Current.FindResource("OmagCut_Red")
|
m_MachineStatus.MachineStatusGrid.Background = Application.Current.FindResource("OmagCut_Red")
|
||||||
End Try
|
End Try
|
||||||
End If
|
End If
|
||||||
|
Case 4
|
||||||
|
If IsNothing(m_CN) OrElse m_CN.n_state < 2 Then
|
||||||
|
' Per evitare crash con azioni verso il controllo, avvio quello di debug
|
||||||
|
m_nNCType = 0
|
||||||
|
Me.m_CN = New CN_Debug
|
||||||
|
m_MachineStatus.MachineStatusGrid.Background = Application.Current.FindResource("OmagCut_Red")
|
||||||
|
Else
|
||||||
|
' ATTENZIONE: durante l'inizializzazione della classe il vettore che contiene tutti gli indirizzi di memoria non è caricato
|
||||||
|
m_CN.b_axis_events_enable = True
|
||||||
|
m_MachineStatus.MachineStatusGrid.Background = Application.Current.FindResource("OmagCut_DarkGray")
|
||||||
|
End If
|
||||||
End Select
|
End Select
|
||||||
|
|
||||||
' Assegno riferimento al CN alle diverse pagine
|
' Assegno riferimento al CN alle diverse pagine
|
||||||
@@ -464,6 +511,7 @@ Public Class CNCommunication
|
|||||||
m_MachineStatus.DisplayPositionDelta()
|
m_MachineStatus.DisplayPositionDelta()
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' ----- INIZIO: lettura diretta di specifiche vaiabili -----
|
||||||
If m_CN.b_feed_changed Then
|
If m_CN.b_feed_changed Then
|
||||||
m_CN.b_feed_changed = False
|
m_CN.b_feed_changed = False
|
||||||
m_MachineStatus.DisplayFeed()
|
m_MachineStatus.DisplayFeed()
|
||||||
@@ -490,12 +538,14 @@ Public Class CNCommunication
|
|||||||
'FrmMain.LblToolRad.Text = cn.Tools(0).radius.ToString
|
'FrmMain.LblToolRad.Text = cn.Tools(0).radius.ToString
|
||||||
'FrmMain.LblToolComp.Text = cn.Tools(0).comp_num.ToString
|
'FrmMain.LblToolComp.Text = cn.Tools(0).comp_num.ToString
|
||||||
End If
|
End If
|
||||||
|
' ----- FINE : lettura diretta di specifiche vaiabili -----
|
||||||
|
|
||||||
Select Case m_nNCType
|
Select Case m_nNCType
|
||||||
Case 1
|
Case 1
|
||||||
If m_CN.read_active_mode() <> m_nCurrMode Then
|
If m_CN.read_active_mode() <> m_nCurrMode Then
|
||||||
m_nCurrMode = m_CN.read_active_mode()
|
m_nCurrMode = m_CN.read_active_mode()
|
||||||
m_MachineStatus.DisplayActiveMode(m_nCurrMode)
|
m_MachineStatus.DisplayActiveMode(m_nCurrMode)
|
||||||
|
m_CN.nMachineMode = m_nCurrMode
|
||||||
End If
|
End If
|
||||||
Case 2
|
Case 2
|
||||||
If m_CN.nMachineMode <> m_nCurrMode Then
|
If m_CN.nMachineMode <> m_nCurrMode Then
|
||||||
@@ -530,6 +580,7 @@ Public Class CNCommunication
|
|||||||
'End If
|
'End If
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
' QUESTE VARIABILI NON SONO LETTE IN QUANTO NON SONO STATE CARICATE → vedere come esempio il NUM che assegna queste variabili
|
||||||
' Flag e variabili per bottoni macchina, che verifico solo nelle pagine in cui ci sono
|
' Flag e variabili per bottoni macchina, che verifico solo nelle pagine in cui ci sono
|
||||||
If m_MainWindow.m_ActivePage = MainWindow.Pages.DirectCut Then
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.DirectCut Then
|
||||||
If m_MainWindow.m_DirectCutPageUC.m_NewMachineButtonsType Then
|
If m_MainWindow.m_DirectCutPageUC.m_NewMachineButtonsType Then
|
||||||
@@ -568,8 +619,14 @@ Public Class CNCommunication
|
|||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.CloseAllChanged(m_CN.bCloseAllState)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.CloseAllChanged(m_CN.bCloseAllState)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Open123Changed(m_CN.bOpen123State)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Open123Changed(m_CN.bOpen123State)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Open456Changed(m_CN.bOpen456State)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Open456Changed(m_CN.bOpen456State)
|
||||||
|
' in assenza della configurazione delle variabili Close123 e Close456
|
||||||
|
If Not String.IsNullOrEmpty(m_CN.m_szCnDataVar(CN_generico.CnData.Close123State)) Then
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close123Changed(m_CN.bClose123State)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close123Changed(m_CN.bClose123State)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close456Changed(m_CN.bClose456State)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close456Changed(m_CN.bClose456State)
|
||||||
|
Else
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close123Changed(Not m_CN.bOpen123State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close456Changed(Not m_CN.bOpen456State)
|
||||||
|
End If
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.BlowChanged(m_CN.bBlowState)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.BlowChanged(m_CN.bBlowState)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumOnChanged(m_CN.bVacuumOn)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumOnChanged(m_CN.bVacuumOn)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumOffChanged(m_CN.bVacuumOff)
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumOffChanged(m_CN.bVacuumOff)
|
||||||
@@ -581,6 +638,7 @@ Public Class CNCommunication
|
|||||||
m_MainWindow.m_DirectCutPageUC.ZCJogChanged(m_CN.bZCJog)
|
m_MainWindow.m_DirectCutPageUC.ZCJogChanged(m_CN.bZCJog)
|
||||||
m_MainWindow.m_DirectCutPageUC.ZBJogChanged(m_CN.bZBCJog)
|
m_MainWindow.m_DirectCutPageUC.ZBJogChanged(m_CN.bZBCJog)
|
||||||
m_MainWindow.m_DirectCutPageUC.RemoteChanged(m_CN.bRemote)
|
m_MainWindow.m_DirectCutPageUC.RemoteChanged(m_CN.bRemote)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.ParkingStateChanged(m_CN.bParkingState)
|
||||||
End If
|
End If
|
||||||
Else
|
Else
|
||||||
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.SpindleStateChanged(m_CN.bSpindleState)
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.SpindleStateChanged(m_CN.bSpindleState)
|
||||||
@@ -607,6 +665,7 @@ Public Class CNCommunication
|
|||||||
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.ZJogChanged(m_CN.bZCJog)
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.ZJogChanged(m_CN.bZCJog)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.BCJogChanged(m_CN.bZBCJog)
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.BCJogChanged(m_CN.bZBCJog)
|
||||||
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.RemoteChanged(m_CN.bRemote)
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.RemoteChanged(m_CN.bRemote)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.ParkingStateChanged(m_CN.bParkingState)
|
||||||
End If
|
End If
|
||||||
|
|
||||||
End If
|
End If
|
||||||
@@ -617,10 +676,188 @@ Public Class CNCommunication
|
|||||||
End If
|
End If
|
||||||
|
|
||||||
' Nuove bottoni (Power Macchina)
|
' Nuove bottoni (Power Macchina)
|
||||||
If m_IsNewConsole AndAlso m_MainWindow.m_ActivePage = MainWindow.Pages.Machine Then
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.Machine Then
|
||||||
|
If m_IsNewConsole Then
|
||||||
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.PowerONChanged(m_CN.bPowerON)
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.PowerONChanged(m_CN.bPowerON)
|
||||||
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.PowerOFFChanged(Not m_CN.bPowerON)
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.PowerOFFChanged(Not m_CN.bPowerON)
|
||||||
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.CncModeChange(m_CN.nMachineMode)
|
||||||
End If
|
End If
|
||||||
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.CncModeChange(m_CN.nMachineMode)
|
||||||
|
End If
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.WorkInProgress Then
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.SpindleStateChanged(m_CN.bSpindleState)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.CoolantStateChanged(m_CN.bCoolantState OrElse m_CN.bInternalCoolantState OrElse m_CN.bExternCoolantState)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.LaserStateChanged(m_CN.bLaserState)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.LaserTracStateChanged(m_CN.bLaserTracState)
|
||||||
|
If m_CN.Is_G24_active() Then
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.ThreeAxisStateChanged(False)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.FiveAxisStateChanged(True)
|
||||||
|
Else
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.ThreeAxisStateChanged(True)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.FiveAxisStateChanged(False)
|
||||||
|
End If
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.DoorStateChanged(m_CN.nDoorClosedState)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.ParkingStateChanged(m_CN.bParkingState)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.EnableZoneStateChanged(m_CN.nEnableZone)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.EnablePcStateChanged(m_CN.nEnablePc)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.TableUpChanged(m_CN.bTableUpState)
|
||||||
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.TableDownChanged(m_CN.bTableDownState)
|
||||||
|
End If
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub RefreshAxesFANUC()
|
||||||
|
' ----- INIZIO: lettura diretta di specifiche vaiabili -----
|
||||||
|
' avvio lettura variabili da CN
|
||||||
|
m_CN.Geppo()
|
||||||
|
' notifico valori all'interfaccia
|
||||||
|
m_MachineStatus.DisplayPosition()
|
||||||
|
m_MachineStatus.DisplayPositionDelta()
|
||||||
|
m_MachineStatus.DisplayFeed()
|
||||||
|
m_MachineStatus.DisplaySpeed()
|
||||||
|
m_MachineStatus.DisplayPower()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub RefreshFANUC()
|
||||||
|
' Copia della funzione Refresh
|
||||||
|
|
||||||
|
' ----- INIZIO: lettura diretta di specifiche vaiabili -----
|
||||||
|
'' avvio lettura variabili da CN
|
||||||
|
'm_CN.Geppo()
|
||||||
|
'' notifico valori all'interfaccia
|
||||||
|
'm_MachineStatus.DisplayPosition()
|
||||||
|
'm_MachineStatus.DisplayPositionDelta()
|
||||||
|
'm_MachineStatus.DisplayFeed()
|
||||||
|
'm_MachineStatus.DisplaySpeed()
|
||||||
|
'm_MachineStatus.DisplayPower()
|
||||||
|
' eventualmente carico messaggi di errore
|
||||||
|
ErrorList.Clear()
|
||||||
|
If m_CN.b_NC_error Then
|
||||||
|
ErrorList.Clear()
|
||||||
|
SyncLock m_CN
|
||||||
|
For Each Item As String In m_CN.sz_NC_error_messages
|
||||||
|
ErrorList.Add(Item)
|
||||||
|
Next
|
||||||
|
End SyncLock
|
||||||
|
End If
|
||||||
|
m_AlarmsPage.NcError()
|
||||||
|
' ----- FINE : lettura diretta di specifiche vaiabili -----
|
||||||
|
|
||||||
|
If m_CN.read_active_mode() <> CShort(m_nCurrMode) Then
|
||||||
|
m_nCurrMode = CInt(m_CN.read_active_mode())
|
||||||
|
m_MachineStatus.DisplayActiveMode(m_nCurrMode)
|
||||||
|
m_CN.nMachineMode = m_nCurrMode
|
||||||
|
End If
|
||||||
|
|
||||||
|
' QUESTE VARIABILI NON SONO LETTE IN QUANTO NON SONO STATE CARICATE → vedere come esempio il NUM che assegna queste variabili
|
||||||
|
' Flag e variabili per bottoni macchina, che verifico solo nelle pagine in cui ci sono
|
||||||
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.DirectCut Then
|
||||||
|
If m_MainWindow.m_DirectCutPageUC.m_NewMachineButtonsType Then
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.SpindleStateChanged(m_CN.bSpindleState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.LaserStateChanged(m_CN.bLaserState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.LaserTracStateChanged(m_CN.bLaserTracState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.CoolantStateChanged(m_CN.bCoolantState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.InternalCoolantStateChanged(m_CN.bInternalCoolantState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.ExternCoolantStateChanged(m_CN.bExternCoolantState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.CBAxesStateChanged(m_CN.bCBAxesState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.AirBlowStateChanged(m_CN.bAirBlowState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.HomeStateChanged(m_CN.bHomeState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.TableUpChanged(m_CN.bTableUpState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.TableDownChanged(m_CN.bTableDownState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.DoorClosedChanged(m_CN.nDoorClosedState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.LimitZChanged(m_CN.bLimitZState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.FiveAxisStateChanged(m_CN.Is_G24_active())
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.ParkingStateChanged(m_CN.bParkingState)
|
||||||
|
'm_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.ZoneStateChanged(m_CN.nEnableZone)
|
||||||
|
'm_MainWindow.m_DirectCutPageUC.m_ControlsMachineButton.PcStateChanged(m_CN.nEnablePc)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumUpChanged(m_CN.bVacuumUp)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumDownChanged(m_CN.bVacuumDown)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum2UpChanged(m_CN.bVacuum2Up)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum2DownChanged(m_CN.bVacuum2Down)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum0Changed(m_CN.bVacuum0)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum90Changed(m_CN.bVacuum90)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum1Changed(m_CN.bVacuum1State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum2Changed(m_CN.bVacuum2State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum3Changed(m_CN.bVacuum3State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum4Changed(m_CN.bVacuum4State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum5Changed(m_CN.bVacuum5State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum6Changed(m_CN.bVacuum6State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum135Changed(m_CN.bVacuum135State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Vacuum246Changed(m_CN.bVacuum246State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.OpenAllChanged(m_CN.bOpenAllState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.CloseAllChanged(m_CN.bCloseAllState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Open123Changed(m_CN.bOpen123State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Open456Changed(m_CN.bOpen456State)
|
||||||
|
' in assenza della configurazione delle variabili Close123 e Close456
|
||||||
|
If Not String.IsNullOrEmpty(m_CN.m_szCnDataVar(CN_generico.CnData.Close123State)) Then
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close123Changed(m_CN.bClose123State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close456Changed(m_CN.bClose456State)
|
||||||
|
Else
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close123Changed(Not m_CN.bOpen123State)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.Close456Changed(Not m_CN.bOpen456State)
|
||||||
|
End If
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.BlowChanged(m_CN.bBlowState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumOnChanged(m_CN.bVacuumOn)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.VacuumOffChanged(m_CN.bVacuumOff)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_VacuumMachineButton.BypassChanged(m_CN.bBypassState)
|
||||||
|
|
||||||
|
' Nuovi bottoni (uso joystick)
|
||||||
|
If m_IsNewConsole Then
|
||||||
|
m_MainWindow.m_DirectCutPageUC.XYJogChanged(m_CN.bXYJog)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.ZCJogChanged(m_CN.bZCJog)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.ZBJogChanged(m_CN.bZBCJog)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.RemoteChanged(m_CN.bRemote)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.ParkingStateChanged(m_CN.bParkingState)
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.SpindleStateChanged(m_CN.bSpindleState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.CoolantStateChanged(m_CN.bCoolantState OrElse m_CN.bInternalCoolantState OrElse m_CN.bExternCoolantState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.LaserStateChanged(m_CN.bLaserState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.LaserTracStateChanged(m_CN.bLaserTracState)
|
||||||
|
If m_CN.Is_G24_active() Then
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.ThreeAxisStateChanged(False)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.FiveAxisStateChanged(True)
|
||||||
|
Else
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.ThreeAxisStateChanged(True)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.FiveAxisStateChanged(False)
|
||||||
|
End If
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.DoorStateChanged(m_CN.nDoorClosedState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.ParkingStateChanged(m_CN.bParkingState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.EnableZoneStateChanged(m_CN.nEnableZone)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.EnablePcStateChanged(m_CN.nEnablePc)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.TableUpChanged(m_CN.bTableUpState)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.TableDownChanged(m_CN.bTableDownState)
|
||||||
|
|
||||||
|
' Nuovi bottoni (uso joystick) per Area4
|
||||||
|
If m_IsNewConsole Then
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.XYJogChanged(m_CN.bXYJog)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.ZJogChanged(m_CN.bZCJog)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.BCJogChanged(m_CN.bZBCJog)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.m_MachineButtons.RemoteChanged(m_CN.bRemote)
|
||||||
|
m_MainWindow.m_DirectCutPageUC.ParkingStateChanged(m_CN.bParkingState)
|
||||||
|
End If
|
||||||
|
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
|
||||||
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.RawPart Then
|
||||||
|
m_MainWindow.m_RawPartPage.m_MachineButtons.LaserStateChanged(m_CN.bLaserState)
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Nuove bottoni (Power Macchina)
|
||||||
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.Machine Then
|
||||||
|
If m_IsNewConsole Then
|
||||||
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.PowerONChanged(m_CN.bPowerON)
|
||||||
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.PowerOFFChanged(Not m_CN.bPowerON)
|
||||||
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.CncModeChange(m_CN.nMachineMode)
|
||||||
|
End If
|
||||||
|
m_MainWindow.m_MachinePageUC.m_MachineCNPageUC.CncModeChange(m_CN.nMachineMode)
|
||||||
|
End If
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
If m_MainWindow.m_ActivePage = MainWindow.Pages.WorkInProgress Then
|
If m_MainWindow.m_ActivePage = MainWindow.Pages.WorkInProgress Then
|
||||||
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.SpindleStateChanged(m_CN.bSpindleState)
|
m_MainWindow.m_WorkInProgressPageUC.m_MachineButtons.SpindleStateChanged(m_CN.bSpindleState)
|
||||||
@@ -904,28 +1141,84 @@ Public Class CNCommunication
|
|||||||
End If
|
End If
|
||||||
' Se richiesta successiva attivazione, faccio reset
|
' Se richiesta successiva attivazione, faccio reset
|
||||||
If bActivate Then
|
If bActivate Then
|
||||||
|
EgtOutLog("Call function: DGeneralFunctions_Reset")
|
||||||
|
TimeSpanInit()
|
||||||
m_CN.DGeneralFunctions_Reset()
|
m_CN.DGeneralFunctions_Reset()
|
||||||
|
EgtOutLog(TimeSpanEnd())
|
||||||
End If
|
End If
|
||||||
' Attesa opportuna
|
' Attesa opportuna
|
||||||
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nResetSendDelay)
|
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nResetSendDelay)
|
||||||
If m_nNCType = 1 Then
|
If m_nNCType = 1 Then
|
||||||
' Cancellazione eventuale file già presente con lo stesso nome (ignoro eventuale errore)
|
' Cancellazione eventuale file già presente con lo stesso nome (ignoro eventuale errore)
|
||||||
|
EgtOutLog("Delete_NC_prog(sNumProg)")
|
||||||
|
TimeSpanInit()
|
||||||
m_CN.Delete_NC_prog(sNumProg)
|
m_CN.Delete_NC_prog(sNumProg)
|
||||||
|
EgtOutLog(TimeSpanEnd())
|
||||||
' Attesa opportuna
|
' Attesa opportuna
|
||||||
System.Threading.Thread.Sleep(100)
|
System.Threading.Thread.Sleep(100)
|
||||||
|
ElseIf m_nNCType = 4 Then
|
||||||
|
' FANUC: imposto modalità EDIT
|
||||||
|
bOk = bOk AndAlso (m_CN.DGeneralFunctions_WriteCncMode(1) = 0)
|
||||||
|
' Attesa opportuna
|
||||||
|
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nThreadSleep)
|
||||||
End If
|
End If
|
||||||
|
EgtOutLog("Download_NC_prog(sCncPath, sNumProg)")
|
||||||
|
' -------------- START DOWNLOAD --------------
|
||||||
|
TimeSpanInit()
|
||||||
bOk = bOk AndAlso (m_CN.Download_NC_prog(sCncPath, sNumProg) = 0)
|
bOk = bOk AndAlso (m_CN.Download_NC_prog(sCncPath, sNumProg) = 0)
|
||||||
' Attesa opportuna
|
' Attesa opportuna
|
||||||
System.Threading.Thread.Sleep(100)
|
System.Threading.Thread.Sleep(100)
|
||||||
|
' FANUC: genero un file 901 vuoto da aspedire, attivare; poi rispedisco il file 900
|
||||||
|
If m_nNCType = 4 And Not bOk Then
|
||||||
|
bOk = True
|
||||||
|
Dim sCncPath1 As String = m_MainWindow.GetCncDir() & "\PlaceHolder" & m_MainWindow.m_CurrentMachine.sIsoFileExt
|
||||||
|
Dim fs As FileStream = File.Create(sCncPath1)
|
||||||
|
' Add text to the file.
|
||||||
|
Dim info As Byte() = New UTF8Encoding(True).GetBytes(vbLf & "(PlaceHolder)")
|
||||||
|
fs.Write(info, 0, info.Length)
|
||||||
|
fs.Close()
|
||||||
|
bOk = bOk AndAlso (m_CN.Download_NC_prog(sCncPath1, "901") = 0)
|
||||||
|
' Attesa opportuna
|
||||||
|
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nThreadSleep)
|
||||||
|
If bActivate Then
|
||||||
|
bOk = bOk AndAlso (m_CN.ActivateProgram("901") = 0)
|
||||||
|
' Attesa opportuna
|
||||||
|
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nThreadSleep)
|
||||||
|
End If
|
||||||
|
' riprovo ad eseguire il programma 900
|
||||||
|
bOk = True
|
||||||
|
bOk = bOk AndAlso (m_CN.Download_NC_prog(sCncPath, sNumProg) = 0)
|
||||||
|
' Attesa opportuna
|
||||||
|
System.Threading.Thread.Sleep(m_MainWindow.m_CurrentMachine.nThreadSleep)
|
||||||
|
End If
|
||||||
|
EgtOutLog("Nc Type : " & m_nNCType.ToString)
|
||||||
|
' AXIUM (NUM OLD): se DripFeed non esegluo attivazione programma)
|
||||||
|
If m_nNCType = 1 AndAlso m_CN.bIsDripFeed Then
|
||||||
|
' eventauli cambi di stato sono trattati all'interno della funzione DownLoad_NC_prog
|
||||||
|
Return True
|
||||||
|
End If
|
||||||
|
EgtOutLog(TimeSpanEnd())
|
||||||
|
' -------------- END DOWNLOAD --------------
|
||||||
|
' -------------- START ACTIVATE --------------
|
||||||
' Se richiesta attivazione
|
' Se richiesta attivazione
|
||||||
If bActivate Then
|
If bActivate Then
|
||||||
' Attivazione programma
|
' Attivazione programma
|
||||||
|
EgtOutLog("ActivateProgram(nNumProg)")
|
||||||
|
TimeSpanInit()
|
||||||
bOk = bOk AndAlso (m_CN.ActivateProgram(nNumProg) = 0)
|
bOk = bOk AndAlso (m_CN.ActivateProgram(nNumProg) = 0)
|
||||||
|
EgtOutLog(TimeSpanEnd())
|
||||||
|
' Attesa opportuna
|
||||||
|
System.Threading.Thread.Sleep(100)
|
||||||
|
' Attivo la modalità AUTO prima per preparar il cyclo start
|
||||||
|
bOk = bOk AndAlso (m_CN.DGeneralFunctions_WriteCncMode(0) = 0)
|
||||||
' Attesa opportuna
|
' Attesa opportuna
|
||||||
System.Threading.Thread.Sleep(100)
|
System.Threading.Thread.Sleep(100)
|
||||||
' Modalità automatica
|
' Modalità automatica
|
||||||
bOk = bOk AndAlso (m_CN.DGeneralFunctions_WriteCncMode(0) = 0)
|
EgtOutLog("DGeneralFunctions_WriteCncMode(0)")
|
||||||
|
TimeSpanInit()
|
||||||
|
EgtOutLog(TimeSpanEnd())
|
||||||
End If
|
End If
|
||||||
|
' -------------- END ACTIVATE --------------
|
||||||
' Messaggio con risultato
|
' Messaggio con risultato
|
||||||
If bOk Then
|
If bOk Then
|
||||||
m_CurrProjPage.SetInfoMessage(EgtMsg(90317)) 'Programma CN trasmesso con successo
|
m_CurrProjPage.SetInfoMessage(EgtMsg(90317)) 'Programma CN trasmesso con successo
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ Public MustInherit Class CN_generico
|
|||||||
Public Const MAX_VAR As Short = 100
|
Public Const MAX_VAR As Short = 100
|
||||||
Public Const MAX_VALUES As Short = 9 ' Max. index to read the data from the FXServer array
|
Public Const MAX_VALUES As Short = 9 ' Max. index to read the data from the FXServer array
|
||||||
Public Const MAX_TOOLS As Short = 100
|
Public Const MAX_TOOLS As Short = 100
|
||||||
Public Const NUM_DATA = 55 ' Numero di dati del CN (Speed,Feed,...)
|
Public Const NUM_DATA = 56 ' Numero di dati del CN (Speed,Feed,...)
|
||||||
|
|
||||||
Public m_NewVariable As Boolean = False ' per scrittura delle vairbaili Apllication del PLC
|
Public m_NewVariable As Boolean = False ' per scrittura delle vairbaili Apllication del PLC
|
||||||
|
|
||||||
@@ -70,8 +70,18 @@ Public MustInherit Class CN_generico
|
|||||||
Parking = 52
|
Parking = 52
|
||||||
EnableZone = 53
|
EnableZone = 53
|
||||||
EnablePC = 54
|
EnablePC = 54
|
||||||
|
|
||||||
|
nAxes = 55
|
||||||
End Enum
|
End Enum
|
||||||
|
|
||||||
|
Public Enum Type As Short
|
||||||
|
TBoolean = 0
|
||||||
|
TInteger = 1
|
||||||
|
TLong = 2
|
||||||
|
TDouble = 3
|
||||||
|
TString = 4
|
||||||
|
|
||||||
|
End Enum
|
||||||
#End Region
|
#End Region
|
||||||
|
|
||||||
#Region " Struct"
|
#Region " Struct"
|
||||||
@@ -218,10 +228,27 @@ Public MustInherit Class CN_generico
|
|||||||
Public bRemote As Boolean
|
Public bRemote As Boolean
|
||||||
' Nuovi di bottoni -------------------------------------------
|
' Nuovi di bottoni -------------------------------------------
|
||||||
|
|
||||||
|
' solo per NumOld
|
||||||
|
Public bIsDripFeed As Boolean = False
|
||||||
|
|
||||||
|
' usato nel FANUC per leggere lo stato macchina se 5 assi attivo
|
||||||
|
Public b5AxesActive As Boolean
|
||||||
|
|
||||||
Public nMachineMode As Integer
|
Public nMachineMode As Integer
|
||||||
|
|
||||||
Public m_szCnDataVar(NUM_DATA - 1) As String
|
Public m_szCnDataVar(NUM_DATA - 1) As String
|
||||||
|
'
|
||||||
|
' nuovi dal 29-III-2023 per Fanuc
|
||||||
|
'
|
||||||
|
Public n_Base_addr_int_vars As Integer = 59800
|
||||||
|
Public n_Base_addr_byte_for_bits_vars As Integer = 59820
|
||||||
|
Public n_num_var_int_to_read As Short = 10
|
||||||
|
Public n_num_var_byte_for_bits_to_read As Short = 30
|
||||||
|
Public s_addr_set_nc_mode As String = "D59825"
|
||||||
|
Public s_addr_feedhold As String = "D59850.6"
|
||||||
|
'
|
||||||
|
' Eventi
|
||||||
|
'
|
||||||
Public Event NewPositionData(ByVal sender As Object)
|
Public Event NewPositionData(ByVal sender As Object)
|
||||||
Public Event NewPosDeltaData(ByVal sender As Object)
|
Public Event NewPosDeltaData(ByVal sender As Object)
|
||||||
Public Event NewVarChanged(ByVal sender As Object)
|
Public Event NewVarChanged(ByVal sender As Object)
|
||||||
@@ -294,8 +321,8 @@ Public MustInherit Class CN_generico
|
|||||||
|
|
||||||
Public MustOverride Function DTool_set_read_range(n_start As Short, n_stop As Short) As Short
|
Public MustOverride Function DTool_set_read_range(n_start As Short, n_stop As Short) As Short
|
||||||
|
|
||||||
Public MustOverride Function DTool_write_tool(n_tool_number As Short, Length_X As Double, Radius As Double, TipRadius_Z As Double, _
|
Public MustOverride Function DTool_write_tool(n_tool_number As Short, Length_X As Double, Radius As Double, TipRadius_Z As Double,
|
||||||
DLength_X As Double, DTipRadius_Z As Double, _
|
DLength_X As Double, DTipRadius_Z As Double,
|
||||||
nDirection As Short, nType As Short, nH As Integer) As Short
|
nDirection As Short, nType As Short, nH As Integer) As Short
|
||||||
|
|
||||||
Public Overridable Function SetProgramMainOrSub(bMain As Boolean) As Boolean
|
Public Overridable Function SetProgramMainOrSub(bMain As Boolean) As Boolean
|
||||||
@@ -341,4 +368,36 @@ Public MustInherit Class CN_generico
|
|||||||
|
|
||||||
#End Region
|
#End Region
|
||||||
|
|
||||||
|
#Region " Nuovi metodi pubblici"
|
||||||
|
|
||||||
|
Public Overridable Function NC_read_var_short(VarAddr As String, ByRef value As Short) As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Public Overridable Function NC_read_var_short_range(VarStartAddr As String, VarEndAddr As String, ByRef values() As Short) As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Public Overridable Function NC_write_var_short(VarAddr As String, ByRef value As Short) As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Public Overridable Function NC_read_var_bit(VarAddr As String, ByRef value As Boolean) As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Public Overridable Function NC_write_var_bit(VarAddr As String, ByRef value As Boolean) As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
Public Overridable Function NC_pulse_bit(VarAddr As String) As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
Public Overridable Function Geppo() As Boolean
|
||||||
|
Return False
|
||||||
|
End Function
|
||||||
|
|
||||||
|
#End Region
|
||||||
|
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|||||||
@@ -9,12 +9,50 @@ Imports System.Text
|
|||||||
Imports System.Windows.Forms
|
Imports System.Windows.Forms
|
||||||
Imports System.Runtime.InteropServices
|
Imports System.Runtime.InteropServices
|
||||||
Imports EgtUILib
|
Imports EgtUILib
|
||||||
|
Imports System.IO
|
||||||
|
Imports System.Threading
|
||||||
|
Imports System.Windows.Threading
|
||||||
|
|
||||||
Namespace Num
|
Namespace Num
|
||||||
|
|
||||||
Public Class NumNCOld
|
Public Class NumNCOld
|
||||||
Inherits CN_generico
|
Inherits CN_generico
|
||||||
|
|
||||||
|
'Public bIsDripFeed As Boolean = False
|
||||||
|
' costruisco il riferimento alla pagina principale
|
||||||
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
|
' costruisco il riferimento alla barra ProjectMng
|
||||||
|
Private m_ProjectMng As ProjectMgrUC
|
||||||
|
|
||||||
|
' Messaggi ricevuti direttamente dal Thread che gestisce la comunicazione DripFeed
|
||||||
|
Private m_nMsg As Integer = 0
|
||||||
|
' Colore originale del bottone WorkBtn
|
||||||
|
Private m_BackgroundOrig As SolidColorBrush
|
||||||
|
' Timer per la lettura aggiornata dei messaggi in fase di comunicazione DriFeed
|
||||||
|
Private m_RefreshTimer As New DispatcherTimer
|
||||||
|
' funzione richiamata ad ogni clik
|
||||||
|
Private Sub RefreshTimer_tick()
|
||||||
|
' verifico se ci sono messaggi da stampare (Se n_Msg > 0 è una info, Se n_Msg < 0 è un errore)
|
||||||
|
If m_nMsg > 0 Then
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.SetInfoMessage(EgtMsg(m_nMsg))
|
||||||
|
ElseIf m_nMsg < 0 Then
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.SetWarningMessage(EgtMsg(Math.Abs(m_nMsg)))
|
||||||
|
End If
|
||||||
|
' dopo la stampa del messaggio resetto l'indice
|
||||||
|
m_nMsg = 0
|
||||||
|
' se ha terminato la trasmissione DripFeed fermo il timer
|
||||||
|
If Not bIsDripFeed Then
|
||||||
|
m_RefreshTimer.Stop()
|
||||||
|
' reimposto il colore originale del bottone WorkBtn della pagina ProjectMng
|
||||||
|
If Not IsNothing(m_ProjectMng) Then
|
||||||
|
m_ProjectMng.WorkBtn.Background = m_BackgroundOrig
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
#Region " Classes"
|
#Region " Classes"
|
||||||
#End Region
|
#End Region
|
||||||
|
|
||||||
@@ -79,6 +117,10 @@ Public Class NumNCOld
|
|||||||
Const TSi = 1, TFi = 2, SPi = 3, THi = 4, INI = 5, TABSYMB = 10, ALLMODULE = 16, CMODULE = 65, TXTFILE = 97
|
Const TSi = 1, TFi = 2, SPi = 3, THi = 4, INI = 5, TABSYMB = 10, ALLMODULE = 16, CMODULE = 65, TXTFILE = 97
|
||||||
Const IHMFNT = 98, IHMBMP = 99, IHMRSC = 100, IHMINI = 101, IHMTXT = 102, IHMICO = 103, IHMCOD = 104
|
Const IHMFNT = 98, IHMBMP = 99, IHMRSC = 100, IHMINI = 101, IHMTXT = 102, IHMICO = 103, IHMCOD = 104
|
||||||
|
|
||||||
|
' Const DNC_MODE_FIRST = &H3A00, DNC_MODE_CONTINUE = &H3B00, DNC_MODE_ABORT = &H3C00
|
||||||
|
Const DNC_MODE_FIRST = 0, DNC_MODE_CONTINUE = 1, DNC_MODE_ABORT = 2
|
||||||
|
Const DNC_IN_PROGRES = &HC8, DNC_RING_BUFFER_FULL = &H7
|
||||||
|
|
||||||
#End Region
|
#End Region
|
||||||
|
|
||||||
#Region " Structures"
|
#Region " Structures"
|
||||||
@@ -115,7 +157,7 @@ Public Class NumNCOld
|
|||||||
Dim Type As Long
|
Dim Type As Long
|
||||||
End Structure
|
End Structure
|
||||||
|
|
||||||
<StructLayout(LayoutKind.Explicit)> _
|
<StructLayout(LayoutKind.Explicit)>
|
||||||
Public Structure tDNC20_ObjectList
|
Public Structure tDNC20_ObjectList
|
||||||
<FieldOffset(0)> Public ElemNum As UInt16
|
<FieldOffset(0)> Public ElemNum As UInt16
|
||||||
<FieldOffset(2)> Public First As UInt16
|
<FieldOffset(2)> Public First As UInt16
|
||||||
@@ -123,7 +165,7 @@ Public Class NumNCOld
|
|||||||
End Structure
|
End Structure
|
||||||
|
|
||||||
Public Structure My_data_struct
|
Public Structure My_data_struct
|
||||||
<MarshalAs(UnmanagedType.ByValArray, SizeConst:=256)> _
|
<MarshalAs(UnmanagedType.ByValArray, SizeConst:=256)>
|
||||||
Public data As Byte()
|
Public data As Byte()
|
||||||
End Structure
|
End Structure
|
||||||
|
|
||||||
@@ -149,6 +191,7 @@ Public Class NumNCOld
|
|||||||
|
|
||||||
Private iFirstVar As UInt16
|
Private iFirstVar As UInt16
|
||||||
Private n_portNC As Int16
|
Private n_portNC As Int16
|
||||||
|
Private n_PPport As Int16
|
||||||
|
|
||||||
Private Vmminch As Long = 1000
|
Private Vmminch As Long = 1000
|
||||||
Private NumCifreDecP4 As Long = 1000
|
Private NumCifreDecP4 As Long = 1000
|
||||||
@@ -209,6 +252,9 @@ Public Class NumNCOld
|
|||||||
|
|
||||||
Declare Function UpLoadFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal filename As String) As Int16
|
Declare Function UpLoadFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal filename As String) As Int16
|
||||||
Declare Function DownLoadFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal filename As String) As Int16
|
Declare Function DownLoadFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal filename As String) As Int16
|
||||||
|
Declare Function DownLoadFileAsyn Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal ringsize As Int32, ByVal filename As String, ByVal Mode As UInt16, ByRef Index As UInt16) As Int16
|
||||||
|
Declare Function DownLoadPPPFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal ringsize As Int32, ByVal filename As String) As Int16
|
||||||
|
Declare Function DownLoadPPPFile2 Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32, ByVal ringsize As Int32, ByVal filename As String, ByVal Offset As Int16, ByVal Mode As UInt16, ByRef Index As UInt16) As Int16
|
||||||
Declare Function DncDeleteFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32) As Int16
|
Declare Function DncDeleteFile Lib "dnc2.dll" (ByVal Port As Int16, ByVal prog As Int32) As Int16
|
||||||
|
|
||||||
Declare Function DNC20_Position_OM Lib "dnc20_2.dll" (ByVal Port As Int16, ByVal Groupe As Int16, ByRef d As My_data_struct, ByVal Mode As UInt16) As Int16
|
Declare Function DNC20_Position_OM Lib "dnc20_2.dll" (ByVal Port As Int16, ByVal Groupe As Int16, ByRef d As My_data_struct, ByVal Mode As UInt16) As Int16
|
||||||
@@ -316,6 +362,14 @@ Public Class NumNCOld
|
|||||||
EgtOutLog(msga)
|
EgtOutLog(msga)
|
||||||
End If
|
End If
|
||||||
|
|
||||||
|
nret = Get_Port(n_PPport)
|
||||||
|
If nret <> 0 Then
|
||||||
|
msga = " PP Port not available (Get_Port) : " & nret.ToString
|
||||||
|
EgtOutLog(msga)
|
||||||
|
Else
|
||||||
|
EgtOutLog("PP Port available: " & n_PPport.ToString)
|
||||||
|
End If
|
||||||
|
|
||||||
' eventualmente aggiungere apertura porta per PPP
|
' eventualmente aggiungere apertura porta per PPP
|
||||||
'iport3 = 3
|
'iport3 = 3
|
||||||
'nret = Get_Port(iport3)
|
'nret = Get_Port(iport3)
|
||||||
@@ -333,6 +387,7 @@ Public Class NumNCOld
|
|||||||
End If
|
End If
|
||||||
|
|
||||||
Dim nret As Int16 = Free_Port(n_portNC)
|
Dim nret As Int16 = Free_Port(n_portNC)
|
||||||
|
nret = Free_Port(n_PPport)
|
||||||
|
|
||||||
global_state = eStateType.NOT_INIT
|
global_state = eStateType.NOT_INIT
|
||||||
|
|
||||||
@@ -481,6 +536,8 @@ Public Class NumNCOld
|
|||||||
|
|
||||||
If nret <> 0 Then
|
If nret <> 0 Then
|
||||||
EgtOutLog("Error in set_NC_mode(" & n_mode.ToString() & ") : " & nret.ToString())
|
EgtOutLog("Error in set_NC_mode(" & n_mode.ToString() & ") : " & nret.ToString())
|
||||||
|
Else
|
||||||
|
EgtOutLog("set_NC_mode(" & n_mode.ToString() & ") : " & nret.ToString() & " → ok")
|
||||||
End If
|
End If
|
||||||
|
|
||||||
global_state = eStateType.READY
|
global_state = eStateType.READY
|
||||||
@@ -792,33 +849,133 @@ Public Class NumNCOld
|
|||||||
Return nret
|
Return nret
|
||||||
|
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
'
|
'
|
||||||
' da PC a CN
|
' da PC a CN (sincrono)
|
||||||
'
|
'
|
||||||
Public Overrides Function Download_NC_prog(sz_PC_filename As String, sz_NC_filename As String) As Int16
|
Public Overrides Function Download_NC_prog(sz_PC_filename As String, sz_NC_filename As String) As Int16
|
||||||
|
|
||||||
' Verifico accessibilità CN
|
' Verifico accessibilità CN
|
||||||
If VerifyBusy() <> eStateType.READY Then
|
If VerifyBusy() <> eStateType.READY Then
|
||||||
|
EgtOutLog("Stato CN " & global_state.ToString)
|
||||||
Return global_state
|
Return global_state
|
||||||
End If
|
End If
|
||||||
' Dichiaro CN occupato
|
|
||||||
global_state = eStateType.BUSY
|
|
||||||
|
|
||||||
' Determino numero programma ( %900.0 -> 9000)
|
' Determino numero programma ( %900.0 -> 9000)
|
||||||
Dim l As Int32 = get_Num_prog_number(sz_NC_filename)
|
Dim l As Int32 = get_Num_prog_number(sz_NC_filename)
|
||||||
' Trasmetto il programma
|
' verifico la dimensione del file
|
||||||
Dim nRet As Int16 = DownLoadFile(n_portNC, l, sz_PC_filename)
|
Dim myFile As New FileInfo(sz_PC_filename)
|
||||||
|
' determino dimensione file
|
||||||
|
Dim sizeInBytes As Long = myFile.Length
|
||||||
|
|
||||||
|
EgtOutLog(" --- Dimensione file CadCut " & sizeInBytes.ToString)
|
||||||
|
' Verifico se dimensione file è maggiore del Buffer
|
||||||
|
If sizeInBytes > 32000 Then
|
||||||
|
' Trasmetto il programma (PPPFile2)
|
||||||
|
EgtOutLog(" --- START DOWNLOAD PPP FILE --- ")
|
||||||
|
' Imposto la modalità AUTO
|
||||||
|
set_NC_mode(0)
|
||||||
|
' Dichiaro CN occupato
|
||||||
|
global_state = eStateType.BUSY
|
||||||
|
' Attesa opportuna
|
||||||
|
System.Threading.Thread.Sleep(1000)
|
||||||
|
' 90969=Drip feed has been started
|
||||||
|
m_nMsg = 90969
|
||||||
|
bIsDripFeed = True
|
||||||
|
' cambio lo sfondo del pulsante WorkBtn
|
||||||
|
If Not IsNothing(m_MainWindow.m_FrameCutPageUC) AndAlso Not IsNothing(m_MainWindow.m_FrameCutPageUC.m_ProjectMgr) Then
|
||||||
|
m_ProjectMng = m_MainWindow.m_FrameCutPageUC.m_ProjectMgr
|
||||||
|
ElseIf Not IsNothing(m_MainWindow.m_CadCutPageUC) AndAlso Not IsNothing(m_MainWindow.m_CadCutPageUC.m_ProjectMgr) Then
|
||||||
|
m_ProjectMng = m_MainWindow.m_CadCutPageUC.m_ProjectMgr
|
||||||
|
End If
|
||||||
|
If Not IsNothing(m_ProjectMng) Then
|
||||||
|
m_BackgroundOrig = m_ProjectMng.WorkBtn.Background
|
||||||
|
Dim MyLinearGradientBrush As LinearGradientBrush = Application.Current.FindResource("OmagCut_GradientYellow")
|
||||||
|
m_ProjectMng.WorkBtn.Background = MyLinearGradientBrush
|
||||||
|
End If
|
||||||
|
' avvio il timer per la lettura dei messaggi, imposto il clock a 1s
|
||||||
|
AddHandler m_RefreshTimer.Tick, AddressOf RefreshTimer_tick
|
||||||
|
m_RefreshTimer.Interval = TimeSpan.FromMilliseconds(1000)
|
||||||
|
m_RefreshTimer.Start()
|
||||||
|
Dim thread As New Thread(Sub()
|
||||||
|
Download_Drip_CN_prog(sz_PC_filename, sz_NC_filename)
|
||||||
|
End Sub)
|
||||||
|
thread.Start()
|
||||||
|
Return 1
|
||||||
|
Else
|
||||||
|
' Dichiaro CN occupato
|
||||||
|
global_state = eStateType.BUSY
|
||||||
|
' Trasmetto il programma (interamente)
|
||||||
|
Dim nRet As Int16 = DownLoadFile(n_portNC, l, sz_PC_filename)
|
||||||
If nRet <> 0 Then
|
If nRet <> 0 Then
|
||||||
EgtOutLog("Error in Download_NC_prog : " & nRet.ToString())
|
EgtOutLog("Error in Download_NC_prog : " & nRet.ToString())
|
||||||
End If
|
End If
|
||||||
|
|
||||||
' Dichiaro CN libero
|
' Dichiaro CN libero
|
||||||
global_state = eStateType.READY
|
global_state = eStateType.READY
|
||||||
|
Return nRet
|
||||||
|
End If
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
End Function
|
||||||
|
'
|
||||||
|
' da PC a CN (asincrono)
|
||||||
|
'
|
||||||
|
|
||||||
|
Private Function Download_Drip_CN_prog(sz_PC_filename As String, sz_NC_filename As String) As Int16
|
||||||
|
' Determino numero programma ( %900.0 -> 9000)
|
||||||
|
Dim l As Int32 = get_Num_prog_number(sz_NC_filename)
|
||||||
|
' Ultimo numero di segmento invaito
|
||||||
|
Dim i As UInt16
|
||||||
|
' Invia il primo segmento (dati comunicazione)
|
||||||
|
EgtOutLog(" -> Invia il primo segmento " & " → PPport: " & n_PPport & " → NC file name: " & sz_PC_filename & " → Dnc Mode: " & DNC_MODE_FIRST)
|
||||||
|
Dim nRet As Int16 = DownLoadPPPFile2(n_PPport, l, 32768, sz_PC_filename, Nothing, DNC_MODE_FIRST, i)
|
||||||
|
' Inserisco un tempo di attesa di sicurezza
|
||||||
|
Thread.Sleep(100)
|
||||||
|
' Verifico che il primo invio sia andato a buon fine (il CN deve esser in modalità IN_PROGRESS oppure RING_BUFFER_FULL)
|
||||||
|
If nRet <> DNC_IN_PROGRES And nRet <> DNC_RING_BUFFER_FULL And m_MainWindow.m_IsClosingApplication <> 1 Then
|
||||||
|
' 90970=Drip feed has been failed (Error)
|
||||||
|
m_nMsg = -90970
|
||||||
|
EgtOutLog("Error in Download_NC_prog/DownLoadPPPFile : " & nRet.ToString())
|
||||||
|
Else
|
||||||
|
' 90969=Drip feed has been started (Info)
|
||||||
|
m_nMsg = 90969
|
||||||
|
' Se il primo invio è andato a buon fine allora invio i segmenti seguenti
|
||||||
|
While (nRet = DNC_IN_PROGRES Or nRet = DNC_RING_BUFFER_FULL) And m_MainWindow.m_IsClosingApplication <> 1
|
||||||
|
nRet = DownLoadPPPFile2(n_portNC, l, 32768, sz_PC_filename, Nothing, DNC_MODE_CONTINUE, i)
|
||||||
|
Thread.Sleep(10)
|
||||||
|
End While
|
||||||
|
End If
|
||||||
|
|
||||||
|
' Verifico che il processo sia terminato correttamente
|
||||||
|
If nRet <> 0 Then
|
||||||
|
' 90971=Drip feed hes been aborted (Error)
|
||||||
|
If m_nMsg > 0 Then
|
||||||
|
' se in precedenza non è stato generato un messaggio di errore (m_nMsg = -90970) comunico che il processo è stato interrotto
|
||||||
|
m_nMsg = -90971
|
||||||
|
End If
|
||||||
|
EgtOutLog("Error in Download_NC_prog/DownLoadPPPFile : " & nRet.ToString() & ", DownLoadPPPFile is aborted")
|
||||||
|
Else
|
||||||
|
' 90972=Drip feed has been ended (Info)
|
||||||
|
m_nMsg = 90972
|
||||||
|
End If
|
||||||
|
|
||||||
|
' prima di terminare (a prescinere dall'esito della comunicazione) forzo la terminazione
|
||||||
|
nRet = DownLoadPPPFile2(n_PPport, l, 32768, sz_PC_filename, Nothing, DNC_MODE_ABORT, i)
|
||||||
|
' Dichiaro CN libero
|
||||||
|
global_state = eStateType.READY
|
||||||
|
bIsDripFeed = False
|
||||||
|
EgtOutLog("IsDripFeed : " & bIsDripFeed.ToString)
|
||||||
|
EgtOutLog(" --- END DOWNLOAD PPP FILE --- ")
|
||||||
|
' se richiesta chiusura del programma, notifico che è stata chiusa correttmanete la comunicazione DripFeed
|
||||||
|
If m_MainWindow.m_IsClosingApplication = 1 Then
|
||||||
|
m_MainWindow.m_IsClosingApplication = 2
|
||||||
|
End If
|
||||||
|
' chiudo il thread aperto
|
||||||
Return nRet
|
Return nRet
|
||||||
|
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
'
|
'
|
||||||
' da CN a pc
|
' da CN a pc
|
||||||
'
|
'
|
||||||
|
|||||||
@@ -115,16 +115,20 @@
|
|||||||
<Reference Include="AxInterop.FXLib">
|
<Reference Include="AxInterop.FXLib">
|
||||||
<HintPath>..\..\EgtProg\OmagCUT\AxInterop.FXLib.dll</HintPath>
|
<HintPath>..\..\EgtProg\OmagCUT\AxInterop.FXLib.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
|
<Reference Include="EgtPHOTOLib">
|
||||||
|
<HintPath>..\..\EgtProg\Dll32\EgtPHOTOLib.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="EgtUILib, Version=2.3.4.5, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="EgtUILib, Version=2.3.4.5, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<SpecificVersion>False</SpecificVersion>
|
<SpecificVersion>False</SpecificVersion>
|
||||||
<HintPath>..\..\EgtProg\DllD32\EgtUILib.dll</HintPath>
|
<HintPath>..\..\EgtProg\DllD32\EgtUILib.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="EgtWPFLib, Version=2.1.7.1, Culture=neutral, processorArchitecture=MSIL">
|
<Reference Include="EgtWPFLib, Version=2.5.2.2, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<SpecificVersion>False</SpecificVersion>
|
<SpecificVersion>False</SpecificVersion>
|
||||||
<HintPath>..\..\EgtProg\Dll32\EgtWPFLib.dll</HintPath>
|
<HintPath>..\..\EgtProg\Dll32\EgtWPFLib.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="EgtWPFLib5">
|
<Reference Include="EgtWPFLib5, Version=2.5.2.2, Culture=neutral, processorArchitecture=MSIL">
|
||||||
<HintPath>..\..\EgtProg\OmagCUT\EgtWPFLib5.dll</HintPath>
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>..\..\EgtProg\Dll32\EgtWPFLib5.dll</HintPath>
|
||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="Interop.FXLib">
|
<Reference Include="Interop.FXLib">
|
||||||
<HintPath>..\..\EgtProg\OmagCUT\Interop.FXLib.dll</HintPath>
|
<HintPath>..\..\EgtProg\OmagCUT\Interop.FXLib.dll</HintPath>
|
||||||
@@ -143,6 +147,10 @@
|
|||||||
</Reference>
|
</Reference>
|
||||||
<Reference Include="PresentationFramework.Aero" />
|
<Reference Include="PresentationFramework.Aero" />
|
||||||
<Reference Include="System.Core" />
|
<Reference Include="System.Core" />
|
||||||
|
<Reference Include="System.Data.SQLite, Version=1.0.112.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139, processorArchitecture=x86">
|
||||||
|
<SpecificVersion>False</SpecificVersion>
|
||||||
|
<HintPath>..\..\EgtProg\Dll32\System.Data.SQLite.dll</HintPath>
|
||||||
|
</Reference>
|
||||||
<Reference Include="System.Drawing" />
|
<Reference Include="System.Drawing" />
|
||||||
<Reference Include="System.Windows.Forms" />
|
<Reference Include="System.Windows.Forms" />
|
||||||
<Reference Include="System.Xml.Linq" />
|
<Reference Include="System.Xml.Linq" />
|
||||||
@@ -170,6 +178,12 @@
|
|||||||
<DependentUpon>SelectPartFromFamilyWD.xaml</DependentUpon>
|
<DependentUpon>SelectPartFromFamilyWD.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
<Compile Include="CAM\CamPolishing.vb" />
|
<Compile Include="CAM\CamPolishing.vb" />
|
||||||
|
<Compile Include="DirectCuts\ControlsDirectCutUC.xaml.vb">
|
||||||
|
<DependentUpon>ControlsDirectCutUC.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="DirectCuts\ControlsDirectCutUC1.xaml.vb">
|
||||||
|
<DependentUpon>ControlsDirectCutUC1.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="DirectCuts\Polishing.xaml.vb">
|
<Compile Include="DirectCuts\Polishing.xaml.vb">
|
||||||
<DependentUpon>Polishing.xaml</DependentUpon>
|
<DependentUpon>Polishing.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -179,6 +193,9 @@
|
|||||||
<Compile Include="DirectCuts\SingleDrillUC.xaml.vb">
|
<Compile Include="DirectCuts\SingleDrillUC.xaml.vb">
|
||||||
<DependentUpon>SingleDrillUC.xaml</DependentUpon>
|
<DependentUpon>SingleDrillUC.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="DirectCuts\SquaringUC.xaml.vb">
|
||||||
|
<DependentUpon>SquaringUC.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="DrawImport\AlzFrontUC.xaml.vb">
|
<Compile Include="DrawImport\AlzFrontUC.xaml.vb">
|
||||||
<DependentUpon>AlzFrontUC.xaml</DependentUpon>
|
<DependentUpon>AlzFrontUC.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -205,10 +222,23 @@
|
|||||||
<Compile Include="Machine\ImportExportToolWD.xaml.vb">
|
<Compile Include="Machine\ImportExportToolWD.xaml.vb">
|
||||||
<DependentUpon>ImportExportToolWD.xaml</DependentUpon>
|
<DependentUpon>ImportExportToolWD.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="Machine\WaterjetDbWindowVM.vb" />
|
||||||
<Compile Include="Machine\WaterJetPageVM.vb" />
|
<Compile Include="Machine\WaterJetPageVM.vb" />
|
||||||
<Compile Include="Machine\WaterJetPageUC.xaml.vb">
|
<Compile Include="Machine\WaterJetPageUC.xaml.vb">
|
||||||
<DependentUpon>WaterJetPageUC.xaml</DependentUpon>
|
<DependentUpon>WaterJetPageUC.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
|
<Compile Include="NcComm\fwlib32.vb" />
|
||||||
|
<Compile Include="NcComm\M_Fanuc.vb" />
|
||||||
|
<Compile Include="NcComm\M_Fanuc_hi.vb" />
|
||||||
|
<Compile Include="Project\AddToDataBaseUC.xaml.vb">
|
||||||
|
<DependentUpon>AddToDataBaseUC.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Project\OmagPhotoWD.xaml.vb">
|
||||||
|
<DependentUpon>OmagPhotoWD.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Project\ScrapsWD.xaml.vb">
|
||||||
|
<DependentUpon>ScrapsWD.xaml</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Project\StartLauncheWD.xaml.vb">
|
<Compile Include="Project\StartLauncheWD.xaml.vb">
|
||||||
<DependentUpon>StartLauncheWD.xaml</DependentUpon>
|
<DependentUpon>StartLauncheWD.xaml</DependentUpon>
|
||||||
</Compile>
|
</Compile>
|
||||||
@@ -412,6 +442,14 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="DirectCuts\ControlsDirectCutUC.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
|
<Page Include="DirectCuts\ControlsDirectCutUC1.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="DirectCuts\Polishing.xaml">
|
<Page Include="DirectCuts\Polishing.xaml">
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
@@ -424,6 +462,10 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="DirectCuts\SquaringUC.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="DrawImport\AlzFrontUC.xaml">
|
<Page Include="DrawImport\AlzFrontUC.xaml">
|
||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
@@ -459,6 +501,18 @@
|
|||||||
<SubType>Designer</SubType>
|
<SubType>Designer</SubType>
|
||||||
<Generator>MSBuild:Compile</Generator>
|
<Generator>MSBuild:Compile</Generator>
|
||||||
</Page>
|
</Page>
|
||||||
|
<Page Include="Project\AddToDataBaseUC.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
|
<Page Include="Project\OmagPhotoWD.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
|
<Page Include="Project\ScrapsWD.xaml">
|
||||||
|
<SubType>Designer</SubType>
|
||||||
|
<Generator>MSBuild:Compile</Generator>
|
||||||
|
</Page>
|
||||||
<Page Include="Project\StartLauncheWD.xaml">
|
<Page Include="Project\StartLauncheWD.xaml">
|
||||||
</Page>
|
</Page>
|
||||||
<Page Include="Project\CicloStartWD.xaml">
|
<Page Include="Project\CicloStartWD.xaml">
|
||||||
@@ -847,7 +901,7 @@
|
|||||||
<Resource Include="Resources\MachineStatusImage\Single.png" />
|
<Resource Include="Resources\MachineStatusImage\Single.png" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Resource Include="Resources\ToolChangerPos.png" />
|
<Resource Include="Resources\ToolChangerPos_OLD.png" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Resource Include="Resources\Manual.png" />
|
<Resource Include="Resources\Manual.png" />
|
||||||
@@ -1261,6 +1315,21 @@
|
|||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Resource Include="Resources\NewIcons\START-WJ.png" />
|
<Resource Include="Resources\NewIcons\START-WJ.png" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Resource Include="Resources\NewIcons\Ponticelli.png" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Resource Include="Resources\NewIcons\Ponticelli_delete.png" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Resource Include="Resources\NewIcons\Parking.png" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Resource Include="Resources\NewIcons\Quality.png" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Resource Include="Resources\ToolChangerPos.png" />
|
||||||
|
</ItemGroup>
|
||||||
<Import Project="$(MSBuildToolsPath)\Microsoft.VisualBasic.targets" />
|
<Import Project="$(MSBuildToolsPath)\Microsoft.VisualBasic.targets" />
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<PostBuildEvent>IF "$(PlatformName)"=="x86" IF "$(ConfigurationName)" == "Release" copy $(TargetPath) c:\EgtProg\OmagCUT\OmagCUTR32.exe
|
<PostBuildEvent>IF "$(PlatformName)"=="x86" IF "$(ConfigurationName)" == "Release" copy $(TargetPath) c:\EgtProg\OmagCUT\OmagCUTR32.exe
|
||||||
|
|||||||
@@ -208,6 +208,7 @@
|
|||||||
<BitmapImage x:Key="XYJogImg" UriSource="Resources/NewIcons/XYJog.png"></BitmapImage>
|
<BitmapImage x:Key="XYJogImg" UriSource="Resources/NewIcons/XYJog.png"></BitmapImage>
|
||||||
<BitmapImage x:Key="ZCJogImg" UriSource="Resources/NewIcons/ZCJog.png"></BitmapImage>
|
<BitmapImage x:Key="ZCJogImg" UriSource="Resources/NewIcons/ZCJog.png"></BitmapImage>
|
||||||
<BitmapImage x:Key="ZBJogImg" UriSource="Resources/NewIcons/ZBJog.png"></BitmapImage>
|
<BitmapImage x:Key="ZBJogImg" UriSource="Resources/NewIcons/ZBJog.png"></BitmapImage>
|
||||||
|
<BitmapImage x:Key="ParkingImg" UriSource="Resources/NewIcons/Parking.png"></BitmapImage>
|
||||||
|
|
||||||
|
|
||||||
<!--Frame-->
|
<!--Frame-->
|
||||||
@@ -218,6 +219,9 @@
|
|||||||
<!--Machinig-->
|
<!--Machinig-->
|
||||||
<BitmapImage x:Key="Allunga-AccorciaImg" UriSource="Resources/NewIcons/Allunga-o-accorcia.png"></BitmapImage>
|
<BitmapImage x:Key="Allunga-AccorciaImg" UriSource="Resources/NewIcons/Allunga-o-accorcia.png"></BitmapImage>
|
||||||
<BitmapImage x:Key="Inizio-Allunga-AccorciaImg" UriSource="Resources/NewIcons/Inizio-allunga-o-accorcia.png"></BitmapImage>
|
<BitmapImage x:Key="Inizio-Allunga-AccorciaImg" UriSource="Resources/NewIcons/Inizio-allunga-o-accorcia.png"></BitmapImage>
|
||||||
|
<BitmapImage x:Key="PonticelliWJImg" UriSource="Resources/NewIcons/Ponticelli.png"></BitmapImage>
|
||||||
|
<BitmapImage x:Key="PonticelliDeleteWJImg" UriSource="Resources/NewIcons/Ponticelli_delete.png"></BitmapImage>
|
||||||
|
<BitmapImage x:Key="QualityWJImg" UriSource="Resources/NewIcons/Quality.png"></BitmapImage>
|
||||||
<BitmapImage x:Key="Fine-Allunga-AccorciaImg" UriSource="Resources/NewIcons/Fine-allunga-o-accorcia.png"></BitmapImage>
|
<BitmapImage x:Key="Fine-Allunga-AccorciaImg" UriSource="Resources/NewIcons/Fine-allunga-o-accorcia.png"></BitmapImage>
|
||||||
<BitmapImage x:Key="ON_OFF-singolo-taglioImg" UriSource="Resources/NewIcons/ON_OFF-singolo-taglio.png"></BitmapImage>
|
<BitmapImage x:Key="ON_OFF-singolo-taglioImg" UriSource="Resources/NewIcons/ON_OFF-singolo-taglio.png"></BitmapImage>
|
||||||
<BitmapImage x:Key="Tutti-ONImg" UriSource="Resources/NewIcons/Tutti-ON.png"></BitmapImage>
|
<BitmapImage x:Key="Tutti-ONImg" UriSource="Resources/NewIcons/Tutti-ON.png"></BitmapImage>
|
||||||
@@ -1206,6 +1210,7 @@
|
|||||||
|
|
||||||
<Style x:Key="OmagCut_CalculatorTextBox" TargetType="{x:Type EgtWPFLib:EgtTextBox}" BasedOn="{StaticResource OmagCut_TextBox}">
|
<Style x:Key="OmagCut_CalculatorTextBox" TargetType="{x:Type EgtWPFLib:EgtTextBox}" BasedOn="{StaticResource OmagCut_TextBox}">
|
||||||
<Setter Property="Keyboard" Value="Calculator"/>
|
<Setter Property="Keyboard" Value="Calculator"/>
|
||||||
|
<Setter Property="IsLength" Value="True"/>
|
||||||
<Setter Property="KeyboardDimension" Value="300"/>
|
<Setter Property="KeyboardDimension" Value="300"/>
|
||||||
</Style>
|
</Style>
|
||||||
|
|
||||||
|
|||||||
@@ -55,23 +55,43 @@
|
|||||||
|
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
|
|
||||||
|
<!--UNITA' DI MISURA-->
|
||||||
<GroupBox Name="UnitsOfMeasureGpBx"
|
<GroupBox Name="UnitsOfMeasureGpBx"
|
||||||
Grid.Column="1"
|
Grid.Column="1"
|
||||||
Grid.RowSpan="3"
|
Grid.RowSpan="3"
|
||||||
Style="{DynamicResource OmagCut_GroupBox}">
|
Style="{DynamicResource OmagCut_GroupBox}">
|
||||||
<Grid >
|
<Grid Name ="UnitGrid">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="0.5*"/>
|
<ColumnDefinition Width="0.5*"/>
|
||||||
<ColumnDefinition Width="4*"/>
|
<ColumnDefinition Width="3.2*"/>
|
||||||
|
<ColumnDefinition Width="1.8*"/>
|
||||||
<ColumnDefinition Width="0.5*"/>
|
<ColumnDefinition Width="0.5*"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="0.25*"/>
|
<RowDefinition Height="0.25*"/>
|
||||||
<RowDefinition Height="0.5*"/>
|
<RowDefinition Height="0.5*"/>
|
||||||
<RowDefinition Height="0.25*"/>
|
<RowDefinition Height="0.25*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.25*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<ComboBox Name="UnitsOfMeasureCmBx" Grid.Column="1" Grid.Row="1" Style="{StaticResource OmagCut_ComboBox}">
|
<ComboBox Name="UnitsOfMeasureCmBx" Grid.Column="1" Grid.Row="1" Grid.ColumnSpan="2" Style="{StaticResource OmagCut_ComboBox}">
|
||||||
|
<ComboBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<TextBlock Text="{Binding}" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</DataTemplate>
|
||||||
|
</ComboBox.ItemTemplate>
|
||||||
|
</ComboBox>
|
||||||
|
|
||||||
|
<ComboBox Name="FractionPatternCmBx" Grid.Column="1" Grid.Row="3" Style="{StaticResource OmagCut_ComboBox}">
|
||||||
|
<ComboBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<TextBlock Text="{Binding}" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</DataTemplate>
|
||||||
|
</ComboBox.ItemTemplate>
|
||||||
|
</ComboBox>
|
||||||
|
|
||||||
|
<ComboBox Name="PrecisionCmBx" Grid.Column="2" Grid.Row="3" Style="{StaticResource OmagCut_ComboBox}">
|
||||||
<ComboBox.ItemTemplate>
|
<ComboBox.ItemTemplate>
|
||||||
<DataTemplate>
|
<DataTemplate>
|
||||||
<TextBlock Text="{Binding}" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
<TextBlock Text="{Binding}" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
@@ -80,9 +100,9 @@
|
|||||||
</ComboBox>
|
</ComboBox>
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
</GroupBox>
|
</GroupBox>
|
||||||
|
|
||||||
|
|
||||||
<GroupBox Name="TextColorGpBx"
|
<GroupBox Name="TextColorGpBx"
|
||||||
Grid.Column="2" Grid.RowSpan="3" Grid.ColumnSpan="1"
|
Grid.Column="2" Grid.RowSpan="3" Grid.ColumnSpan="1"
|
||||||
Style="{DynamicResource OmagCut_GroupBox}">
|
Style="{DynamicResource OmagCut_GroupBox}">
|
||||||
@@ -224,7 +244,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="ToleranceMsgTxBl" Grid.Column="3" Grid.Row="0"
|
<TextBlock Name="ToleranceMsgTxBl" Grid.Column="3" Grid.Row="0"
|
||||||
Style="{DynamicResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{DynamicResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="ToleranceMsgTxBx" Grid.Column="4" Grid.Row="0" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="ToleranceMsgTxBx" Grid.Column="4" Grid.Row="0" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
@@ -241,7 +261,7 @@
|
|||||||
Style="{StaticResource OmagCut_Button}" />
|
Style="{StaticResource OmagCut_Button}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA1TalloneTxBx" Grid.Column="5" Grid.Row="2" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA1TalloneTxBx" Grid.Column="5" Grid.Row="2" Margin="10,0,10,0"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA1InclinazioneTxBx" Grid.Column="3" Grid.Row="2" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA1InclinazioneTxBx" Grid.Column="3" Grid.Row="2" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA2EnableChBx" Grid.Column="0" Grid.Row="3"
|
<CheckBox Name="CTSA2EnableChBx" Grid.Column="0" Grid.Row="3"
|
||||||
@@ -250,7 +270,7 @@
|
|||||||
Style="{StaticResource OmagCut_Button}" />
|
Style="{StaticResource OmagCut_Button}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA2TalloneTxBx" Grid.Column="5" Grid.Row="3" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA2TalloneTxBx" Grid.Column="5" Grid.Row="3" Margin="10,0,10,0"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA2InclinazioneTxBx" Grid.Column="3" Grid.Row="3" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA2InclinazioneTxBx" Grid.Column="3" Grid.Row="3" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA3EnableChBx" Grid.Column="0" Grid.Row="4"
|
<CheckBox Name="CTSA3EnableChBx" Grid.Column="0" Grid.Row="4"
|
||||||
@@ -259,7 +279,7 @@
|
|||||||
Style="{StaticResource OmagCut_Button}" />
|
Style="{StaticResource OmagCut_Button}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA3TalloneTxBx" Grid.Column="5" Grid.Row="4" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA3TalloneTxBx" Grid.Column="5" Grid.Row="4" Margin="10,0,10,0"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA3InclinazioneTxBx" Grid.Column="3" Grid.Row="4" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA3InclinazioneTxBx" Grid.Column="3" Grid.Row="4" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA4EnableChBx" Grid.Column="0" Grid.Row="5"
|
<CheckBox Name="CTSA4EnableChBx" Grid.Column="0" Grid.Row="5"
|
||||||
@@ -272,7 +292,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA4InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="5"
|
<TextBlock Name="CTSA4InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="5"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA4InclinazioneTxBx" Grid.Column="3" Grid.Row="5" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA4InclinazioneTxBx" Grid.Column="3" Grid.Row="5" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA5EnableChBx" Grid.Column="0" Grid.Row="6"
|
<CheckBox Name="CTSA5EnableChBx" Grid.Column="0" Grid.Row="6"
|
||||||
@@ -285,7 +305,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA5InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="6"
|
<TextBlock Name="CTSA5InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="6"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA5InclinazioneTxBx" Grid.Column="3" Grid.Row="6" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA5InclinazioneTxBx" Grid.Column="3" Grid.Row="6" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA6EnableChBx" Grid.Column="0" Grid.Row="7"
|
<CheckBox Name="CTSA6EnableChBx" Grid.Column="0" Grid.Row="7"
|
||||||
@@ -298,7 +318,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA6InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="7"
|
<TextBlock Name="CTSA6InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="7"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA6InclinazioneTxBx" Grid.Column="3" Grid.Row="7" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA6InclinazioneTxBx" Grid.Column="3" Grid.Row="7" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA7EnableChBx" Grid.Column="0" Grid.Row="8"
|
<CheckBox Name="CTSA7EnableChBx" Grid.Column="0" Grid.Row="8"
|
||||||
@@ -311,7 +331,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA7InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="8"
|
<TextBlock Name="CTSA7InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="8"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA7InclinazioneTxBx" Grid.Column="3" Grid.Row="8" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA7InclinazioneTxBx" Grid.Column="3" Grid.Row="8" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA8EnableChBx" Grid.Column="0" Grid.Row="9"
|
<CheckBox Name="CTSA8EnableChBx" Grid.Column="0" Grid.Row="9"
|
||||||
@@ -324,7 +344,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA8InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="9"
|
<TextBlock Name="CTSA8InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="9"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA8InclinazioneTxBx" Grid.Column="3" Grid.Row="9" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA8InclinazioneTxBx" Grid.Column="3" Grid.Row="9" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA9EnableChBx" Grid.Column="0" Grid.Row="10"
|
<CheckBox Name="CTSA9EnableChBx" Grid.Column="0" Grid.Row="10"
|
||||||
@@ -337,7 +357,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA9InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="10"
|
<TextBlock Name="CTSA9InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="10"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA9InclinazioneTxBx" Grid.Column="3" Grid.Row="10" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA9InclinazioneTxBx" Grid.Column="3" Grid.Row="10" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
<CheckBox Name="CTSA10EnableChBx" Grid.Column="0" Grid.Row="11"
|
<CheckBox Name="CTSA10EnableChBx" Grid.Column="0" Grid.Row="11"
|
||||||
@@ -350,7 +370,7 @@
|
|||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
<TextBlock Name="CTSA10InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="11"
|
<TextBlock Name="CTSA10InclinazioneMsgTxBl" Grid.Column="4" Grid.Row="11"
|
||||||
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{StaticResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="CTSA10InclinazioneTxBx" Grid.Column="3" Grid.Row="11" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="CTSA10InclinazioneTxBx" Grid.Column="3" Grid.Row="11" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
@@ -432,7 +452,7 @@
|
|||||||
|
|
||||||
<TextBlock Name="ToleranceEMsgTxBl" Grid.Column="3" Grid.Row="0"
|
<TextBlock Name="ToleranceEMsgTxBl" Grid.Column="3" Grid.Row="0"
|
||||||
Style="{DynamicResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
Style="{DynamicResource OmagCut_CenteredLowerCaseCharacterTextBlock}" />
|
||||||
<EgtWPFLib:EgtTextBox Name="ToleranceEMsgTxBx" Grid.Column="4" Grid.Row="0" Margin="10,0,10,0"
|
<EgtWPFLib:EgtTextBox Name="ToleranceEMsgTxBx" Grid.Column="4" Grid.Row="0" Margin="10,0,10,0" IsLength="False"
|
||||||
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
Style="{DynamicResource OmagCut_CalculatorTextBox}" />
|
||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@@ -7,6 +7,8 @@ Public Class OptionsPageUC
|
|||||||
Dim m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
Dim m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
|
|
||||||
Private UnitsList() As String = {"inch", "mm"}
|
Private UnitsList() As String = {"inch", "mm"}
|
||||||
|
Private FractionPatternList() As String = {"Decimal", "Foot'Inch""", "Only Inch"}
|
||||||
|
Private PrecisionList() As Double = {2, 4, 8, 16, 32, 64, 128}
|
||||||
Private ThemesList() As String = {"Classic", "Dark"}
|
Private ThemesList() As String = {"Classic", "Dark"}
|
||||||
|
|
||||||
' "Last Project", "New Project", "Open Folder", "Show Window"
|
' "Last Project", "New Project", "Open Folder", "Show Window"
|
||||||
@@ -18,6 +20,10 @@ Public Class OptionsPageUC
|
|||||||
LanguageCmBx.ItemsSource = m_MainWindow.m_LanguagesList
|
LanguageCmBx.ItemsSource = m_MainWindow.m_LanguagesList
|
||||||
' Associazione della lista unità di misura alla combobox
|
' Associazione della lista unità di misura alla combobox
|
||||||
UnitsOfMeasureCmBx.ItemsSource = UnitsList
|
UnitsOfMeasureCmBx.ItemsSource = UnitsList
|
||||||
|
' Associazione della lista dei Pattern
|
||||||
|
FractionPatternCmBx.ItemsSource = FractionPatternList
|
||||||
|
' Associazione della lista della precisione
|
||||||
|
PrecisionCmBx.ItemsSource = PrecisionList
|
||||||
' Associazione della lista temi alla combobox
|
' Associazione della lista temi alla combobox
|
||||||
ThemesCmBx.ItemsSource = ThemesList
|
ThemesCmBx.ItemsSource = ThemesList
|
||||||
|
|
||||||
@@ -27,6 +33,16 @@ Public Class OptionsPageUC
|
|||||||
' Imposto l'unità di misura corrente
|
' Imposto l'unità di misura corrente
|
||||||
UnitsOfMeasureCmBx.SelectedIndex = If(EgtUiUnitsAreMM(), 1, 0)
|
UnitsOfMeasureCmBx.SelectedIndex = If(EgtUiUnitsAreMM(), 1, 0)
|
||||||
|
|
||||||
|
' Imposto il pattern della per la rappresentazione frazionaria
|
||||||
|
nCurrFractionPattern = GetPrivateProfileInt(S_GENERAL, K_FRACTIONPATTERN, 0, m_MainWindow.GetIniFile())
|
||||||
|
FractionPatternCmBx.SelectedIndex = nCurrFractionPattern
|
||||||
|
EgtWPFLib.FractionStringConverter.SetCurrFractionPattern(nCurrFractionPattern)
|
||||||
|
|
||||||
|
' Imposto la preciosne della rappresentazione frazionaria
|
||||||
|
dPrecision = CDbl(GetPrivateProfileInt(S_GENERAL, K_PRECISION, 64, m_MainWindow.GetIniFile()))
|
||||||
|
Dim Index As Integer = PrecisionCmBx.Items.IndexOf(dPrecision)
|
||||||
|
PrecisionCmBx.SelectedIndex = Index
|
||||||
|
|
||||||
' Imposto il tema corrente
|
' Imposto il tema corrente
|
||||||
ThemesCmBx.SelectedIndex = GetPrivateProfileInt(S_GENERAL, K_THEME, 0, m_MainWindow.GetIniFile())
|
ThemesCmBx.SelectedIndex = GetPrivateProfileInt(S_GENERAL, K_THEME, 0, m_MainWindow.GetIniFile())
|
||||||
Themes_StartUp()
|
Themes_StartUp()
|
||||||
@@ -322,9 +338,60 @@ Public Class OptionsPageUC
|
|||||||
EgtSetUiUnits(bMM)
|
EgtSetUiUnits(bMM)
|
||||||
m_MainWindow.m_CurrentProjectPageUC.UpdateHeightTxBx()
|
m_MainWindow.m_CurrentProjectPageUC.UpdateHeightTxBx()
|
||||||
WritePrivateProfileString(S_GENERAL, K_MMUNITS, If(bMM, "1", "0"), m_MainWindow.GetIniFile())
|
WritePrivateProfileString(S_GENERAL, K_MMUNITS, If(bMM, "1", "0"), m_MainWindow.GetIniFile())
|
||||||
|
|
||||||
|
If bMM Then
|
||||||
|
' se selezione MILLIMETRI nascondo la combobox che permette di inserie il tipo di pattern per la definizione delle frazioni
|
||||||
|
FractionPatternCmBx.Visibility = Visibility.Hidden
|
||||||
|
PrecisionCmBx.Visibility = Visibility.Hidden
|
||||||
|
Dim RowNum As Integer = UnitGrid.RowDefinitions.Count
|
||||||
|
If RowNum > 3 Then
|
||||||
|
UnitsOfMeasureCmBx.SetValue(Grid.RowSpanProperty, 3)
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
' se selezione POLLICI mostro la combobox che permette di inserie il tipo di pattern per la definizione delle frazioni
|
||||||
|
FractionPatternCmBx.Visibility = Visibility.Visible
|
||||||
|
PrecisionCmBx.Visibility = Visibility.Visible
|
||||||
|
UnitsOfMeasureCmBx.SetValue(Grid.RowSpanProperty, 1)
|
||||||
|
End If
|
||||||
|
|
||||||
' Aggiorno dati nella pagina dipendenti da unità di misura
|
' Aggiorno dati nella pagina dipendenti da unità di misura
|
||||||
UpdateSlabDxf()
|
UpdateSlabDxf()
|
||||||
UpdateAllCSTA()
|
UpdateAllCSTA()
|
||||||
|
If m_MainWindow.m_CurrentMachine.bWaterJet And m_MainWindow.m_CurrentMachine.bFromDBWaterJet Then
|
||||||
|
m_MainWindow.m_CurrentMachine.LoadWJMaterial()
|
||||||
|
If Not IsNothing(m_MainWindow.m_MachinePageUC.m_WaterJetPageUC) Then
|
||||||
|
m_MainWindow.m_MachinePageUC.m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub FractionPatternCmBx_SelectionChanged(sender As Object, e As SelectionChangedEventArgs) Handles FractionPatternCmBx.SelectionChanged
|
||||||
|
nCurrFractionPattern = FractionPatternCmBx.SelectedIndex
|
||||||
|
EgtWPFLib.FractionStringConverter.SetCurrFractionPattern(nCurrFractionPattern)
|
||||||
|
WritePrivateProfileString(S_GENERAL, K_FRACTIONPATTERN, nCurrFractionPattern, m_MainWindow.GetIniFile())
|
||||||
|
' Aggiorno dati nella pagina dipendenti da unità di misura
|
||||||
|
UpdateSlabDxf()
|
||||||
|
UpdateAllCSTA()
|
||||||
|
If m_MainWindow.m_CurrentMachine.bWaterJet And m_MainWindow.m_CurrentMachine.bFromDBWaterJet Then
|
||||||
|
m_MainWindow.m_CurrentMachine.LoadWJMaterial()
|
||||||
|
If Not IsNothing(m_MainWindow.m_MachinePageUC.m_WaterJetPageUC) Then
|
||||||
|
m_MainWindow.m_MachinePageUC.m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub PrecisionCmBx_SelectionChanged(sender As Object, e As SelectionChangedEventArgs) Handles PrecisionCmBx.SelectionChanged
|
||||||
|
dPrecision = PrecisionCmBx.SelectedValue
|
||||||
|
WritePrivateProfileString(S_GENERAL, K_PRECISION, dPrecision, m_MainWindow.GetIniFile())
|
||||||
|
' Aggiorno dati nella pagina dipendenti da unità di misura
|
||||||
|
UpdateSlabDxf()
|
||||||
|
UpdateAllCSTA()
|
||||||
|
If m_MainWindow.m_CurrentMachine.bWaterJet And m_MainWindow.m_CurrentMachine.bFromDBWaterJet Then
|
||||||
|
m_MainWindow.m_CurrentMachine.LoadWJMaterial()
|
||||||
|
If Not IsNothing(m_MainWindow.m_MachinePageUC.m_WaterJetPageUC) Then
|
||||||
|
m_MainWindow.m_MachinePageUC.m_WaterJetPageUC.WaterJetPage_Reinitialize()
|
||||||
|
End If
|
||||||
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ThemesCmBx_SelectionChanged(sender As Object, e As SelectionChangedEventArgs) Handles ThemesCmBx.SelectionChanged
|
Private Sub ThemesCmBx_SelectionChanged(sender As Object, e As SelectionChangedEventArgs) Handles ThemesCmBx.SelectionChanged
|
||||||
@@ -648,70 +715,70 @@ Public Class OptionsPageUC
|
|||||||
|
|
||||||
Private Sub CTSA1InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA1InclinazioneTxBx.TextChanged
|
Private Sub CTSA1InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA1InclinazioneTxBx.TextChanged
|
||||||
If CTSA1InclinazioneTxBx.Text <> "-" Then
|
If CTSA1InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA1InclinazioneTxBx.Text, dAng) Then CTSA1InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA1InclinazioneTxBx.Text, dAng) Then CTSA1InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA1EnableChBx_Click(sender, e)
|
CTSA1EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA2InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA2InclinazioneTxBx.TextChanged
|
Private Sub CTSA2InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA2InclinazioneTxBx.TextChanged
|
||||||
If CTSA2InclinazioneTxBx.Text <> "-" Then
|
If CTSA2InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA2InclinazioneTxBx.Text, dAng) Then CTSA2InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA2InclinazioneTxBx.Text, dAng) Then CTSA2InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA2EnableChBx_Click(sender, e)
|
CTSA2EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA3InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA3InclinazioneTxBx.TextChanged
|
Private Sub CTSA3InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA3InclinazioneTxBx.TextChanged
|
||||||
If CTSA3InclinazioneTxBx.Text <> "-" Then
|
If CTSA3InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA3InclinazioneTxBx.Text, dAng) Then CTSA3InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA3InclinazioneTxBx.Text, dAng) Then CTSA3InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA3EnableChBx_Click(sender, e)
|
CTSA3EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA4InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA4InclinazioneTxBx.TextChanged
|
Private Sub CTSA4InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA4InclinazioneTxBx.TextChanged
|
||||||
If CTSA4InclinazioneTxBx.Text <> "-" Then
|
If CTSA4InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA4InclinazioneTxBx.Text, dAng) Then CTSA4InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA4InclinazioneTxBx.Text, dAng) Then CTSA4InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA4EnableChBx_Click(sender, e)
|
CTSA4EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA5InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA5InclinazioneTxBx.TextChanged
|
Private Sub CTSA5InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA5InclinazioneTxBx.TextChanged
|
||||||
If CTSA5InclinazioneTxBx.Text <> "-" Then
|
If CTSA5InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA5InclinazioneTxBx.Text, dAng) Then CTSA5InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA5InclinazioneTxBx.Text, dAng) Then CTSA5InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA5EnableChBx_Click(sender, e)
|
CTSA5EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA6InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA6InclinazioneTxBx.TextChanged
|
Private Sub CTSA6InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA6InclinazioneTxBx.TextChanged
|
||||||
If CTSA6InclinazioneTxBx.Text <> "-" Then
|
If CTSA6InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA6InclinazioneTxBx.Text, dAng) Then CTSA6InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA6InclinazioneTxBx.Text, dAng) Then CTSA6InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA6EnableChBx_Click(sender, e)
|
CTSA6EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA7InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA7InclinazioneTxBx.TextChanged
|
Private Sub CTSA7InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA7InclinazioneTxBx.TextChanged
|
||||||
If CTSA7InclinazioneTxBx.Text <> "-" Then
|
If CTSA7InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA7InclinazioneTxBx.Text, dAng) Then CTSA7InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA7InclinazioneTxBx.Text, dAng) Then CTSA7InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA7EnableChBx_Click(sender, e)
|
CTSA7EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA8InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA8InclinazioneTxBx.TextChanged
|
Private Sub CTSA8InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA8InclinazioneTxBx.TextChanged
|
||||||
If CTSA8InclinazioneTxBx.Text <> "-" Then
|
If CTSA8InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA8InclinazioneTxBx.Text, dAng) Then CTSA8InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA8InclinazioneTxBx.Text, dAng) Then CTSA8InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA8EnableChBx_Click(sender, e)
|
CTSA8EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA9InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA9InclinazioneTxBx.TextChanged
|
Private Sub CTSA9InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA9InclinazioneTxBx.TextChanged
|
||||||
If CTSA9InclinazioneTxBx.Text <> "-" Then
|
If CTSA9InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA9InclinazioneTxBx.Text, dAng) Then CTSA9InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA9InclinazioneTxBx.Text, dAng) Then CTSA9InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA9EnableChBx_Click(sender, e)
|
CTSA9EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub CTSA10InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA10InclinazioneTxBx.TextChanged
|
Private Sub CTSA10InclinazioneTxBx_TextChanged(sender As Object, e As TextChangedEventArgs) Handles CTSA10InclinazioneTxBx.TextChanged
|
||||||
If CTSA10InclinazioneTxBx.Text <> "-" Then
|
If CTSA10InclinazioneTxBx.Text <> "-" Then
|
||||||
Dim dAng As Double : If Not StringToLen(CTSA10InclinazioneTxBx.Text, dAng) Then CTSA10InclinazioneTxBx.Text = ""
|
Dim dAng As Double : If Not StringToDouble(CTSA10InclinazioneTxBx.Text, dAng) Then CTSA10InclinazioneTxBx.Text = ""
|
||||||
End If
|
End If
|
||||||
CTSA10EnableChBx_Click(sender, e)
|
CTSA10EnableChBx_Click(sender, e)
|
||||||
End Sub
|
End Sub
|
||||||
|
|||||||
@@ -0,0 +1,95 @@
|
|||||||
|
<UserControl x:Class="AddToDataBaseUC"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:EgtWPFLib="clr-namespace:EgtWPFLib;assembly=EgtWPFLib"
|
||||||
|
mc:Ignorable="d"
|
||||||
|
d:DesignHeight="853.3" d:DesignWidth="1280">
|
||||||
|
|
||||||
|
<Border Style="{DynamicResource OmagCut_Border}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
<ColumnDefinition Width="2.5*"/>
|
||||||
|
<ColumnDefinition Width="0.25*"/>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<!--Nome BLOCCO-->
|
||||||
|
<TextBlock Name="BlockTxBl" Grid.Column="1" Grid.Row="1" Text="Name block"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="BlockTxBx" Grid.Column="3" Grid.Row="1"
|
||||||
|
Style="{DynamicResource OmagCut_KeyboardTextBox}"/>
|
||||||
|
<!--Numero ID-->
|
||||||
|
<TextBlock Name="NbrIdTxBl" Grid.Column="1" Grid.Row="3" Text="ID"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="NbrIdTxBx" Grid.Column="3" Grid.Row="3"
|
||||||
|
Style="{DynamicResource OmagCut_KeyboardTextBox}"/>
|
||||||
|
<!--STATE-->
|
||||||
|
<TextBlock Name="StateTxBl" Grid.Column="1" Grid.Row="5" Text="State"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<ComboBox Name="StateCmBx" Grid.Column="3" Grid.Row="5" Style="{StaticResource OmagCut_LeftComboBoxInBorder}">
|
||||||
|
<ComboBox.ItemTemplate>
|
||||||
|
<DataTemplate>
|
||||||
|
<TextBlock Text="{Binding}" Style="{StaticResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
</DataTemplate>
|
||||||
|
</ComboBox.ItemTemplate>
|
||||||
|
</ComboBox>
|
||||||
|
<!--PROJECT-->
|
||||||
|
<TextBlock Name="ProjectNameTxBl" Grid.Column="1" Grid.Row="7" Text="Project"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="ProjectTxBx" Grid.Column="3" Grid.Row="7"
|
||||||
|
Style="{DynamicResource OmagCut_KeyboardTextBox}"/>
|
||||||
|
<!--MATERIAL-->
|
||||||
|
<TextBlock Name="MatTxBl" Grid.Column="1" Grid.Row="9" Text="Mat"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="MatTxBx" Grid.Column="3" Grid.Row="9"
|
||||||
|
Style="{DynamicResource OmagCut_KeyboardTextBox}" IsEnabled="False"/>
|
||||||
|
<!--THICKNESS-->
|
||||||
|
<TextBlock Name="ThicknessTxBl" Grid.Column="1" Grid.Row="11" Text="Thickness"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="ThicknessTxBx" Grid.Column="3" Grid.Row="11"
|
||||||
|
Style="{DynamicResource OmagCut_CalculatorTextBox}"/>
|
||||||
|
<!--WAREHOUSE-->
|
||||||
|
<TextBlock Name="WarehouseTxBl" Grid.Column="1" Grid.Row="13" Text="Warehouse position"
|
||||||
|
Style="{DynamicResource OmagCut_ToolsDBTextBlock}"/>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="WarehouseTxBx" Grid.Column="3" Grid.Row="13"
|
||||||
|
Style="{DynamicResource OmagCut_KeyboardTextBox}"/>
|
||||||
|
|
||||||
|
<!--CANCEL-->
|
||||||
|
<Button Name="CacelBtn" Grid.Column="1" Grid.Row="15" Content="Delete"
|
||||||
|
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
||||||
|
<!--ADD-->
|
||||||
|
<Button Name="AddBtn" Grid.Column="3" Grid.Row="15" Content="Add"
|
||||||
|
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
||||||
|
<!--PRINT-->
|
||||||
|
<Button Name="PrintBtn" Grid.Column="1" Grid.Row="17" Content="Print"
|
||||||
|
Style="{DynamicResource OmagCut_YellowTextButton}"/>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Border>
|
||||||
|
|
||||||
|
</UserControl>
|
||||||
@@ -0,0 +1,121 @@
|
|||||||
|
Imports EgtUILib
|
||||||
|
Imports EgtPHOTOLib
|
||||||
|
Imports System.IO
|
||||||
|
|
||||||
|
Public Class AddToDataBaseUC
|
||||||
|
|
||||||
|
Private m_OmagPhotoWD As OmagPhotoWD
|
||||||
|
|
||||||
|
#Region "PROPERTY"
|
||||||
|
Private Sub BlockTxBx_EgtClosed(sender As Object, e As EventArgs) Handles BlockTxBx.EgtClosed
|
||||||
|
' assegno il dato alla classe inizializzata nella libreria
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNameBlock = BlockTxBx.Text
|
||||||
|
' devo riasseganre il valore dell'indice
|
||||||
|
NbrIdTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNbrID
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub NbrIdTxBx_EgtClosed(sender As Object, e As EventArgs) Handles NbrIdTxBx.EgtClosed
|
||||||
|
' assegno il dato alla classe inizializzata nella libreria
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNbrID = NbrIdTxBx.Text
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub StateCmBx_Changed() Handles StateCmBx.SelectionChanged
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.State = StateCmBx.SelectedIndex
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ProjectTxBx_EgtClosed(sender As Object, e As EventArgs) Handles ProjectTxBx.EgtClosed
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.ProjectAssignedTo = ProjectTxBx.Text
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ThicknessTxBx_EgtClosed(sender As Object, e As EventArgs) Handles ThicknessTxBx.EgtClosed
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Thickness = ThicknessTxBx.Text
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub WarehouseTxBx_EgtClosed(sender As Object, e As EventArgs) Handles WarehouseTxBx.EgtClosed
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.WarehousePosition = WarehouseTxBl.Text
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
#End Region ' Property
|
||||||
|
|
||||||
|
Sub New(LocalOmagPhotoWD As OmagPhotoWD)
|
||||||
|
|
||||||
|
' La chiamata è richiesta dalla finestra di progettazione.
|
||||||
|
InitializeComponent()
|
||||||
|
|
||||||
|
' Aggiungere le eventuali istruzioni di inizializzazione dopo la chiamata a InitializeComponent().
|
||||||
|
m_OmagPhotoWD = LocalOmagPhotoWD
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' dopo la crezione della pagina imposto lo stato dei pulsanti
|
||||||
|
Private Sub PostLoaded() Handles Me.Loaded
|
||||||
|
If EgtPHOTOLib.MainData.bEnableTextId Then
|
||||||
|
BlockTxBx.Visibility = Visibility.Collapsed
|
||||||
|
BlockTxBl.Visibility = Visibility.Collapsed
|
||||||
|
Else
|
||||||
|
NbrIdTxBx.IsEnabled = False
|
||||||
|
End If
|
||||||
|
PrintBtn.IsEnabled = EgtPHOTOLib.MainData.bEnablePrinter
|
||||||
|
EnableButtons()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
#Region "COMMAND"
|
||||||
|
Private Sub CancelBtn_Click() Handles CacelBtn.Click
|
||||||
|
' se è stata inserita nel DB allora devo rimuoverla ed esco dalla pagina
|
||||||
|
EgtPHOTOLib.refOptionPanelVM.Delete()
|
||||||
|
' notifico che il grezzo è stato rimosso
|
||||||
|
OmagPhotoWD.m_IsDeleted = True
|
||||||
|
' notifico che il grezzo non è stato aggiunto al DB delle lastre
|
||||||
|
OmagPhotoWD.m_IsAdded = False
|
||||||
|
' elimino l'identificativo usato nel database del grezzo appena inserito
|
||||||
|
OmagPhotoWD.m_sDtBsId = ""
|
||||||
|
' esco dalla pagina
|
||||||
|
m_OmagPhotoWD.Close()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub AddBtn_Click() Handles AddBtn.Click
|
||||||
|
' se non sono validi i campi allora attendo
|
||||||
|
If Not EgtPHOTOLib.PhotoMap.refOptionPanelVM.Ok_IsEnabled Then Return
|
||||||
|
' modalità di funzionamento della libreria: ProjectSlabVM.ProjectModeOpt.NEWSLAB
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.Save()
|
||||||
|
' notifico che il grezzo è stato aggiunto al DB delle lastre
|
||||||
|
OmagPhotoWD.m_IsAdded = True
|
||||||
|
' salvo l'identificativo usato nel database del grezzo appena inserito
|
||||||
|
OmagPhotoWD.m_sDtBsId = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Id
|
||||||
|
' salvo il nome del blocco che è stato utilizzato
|
||||||
|
If Not EgtPHOTOLib.MainData.bEnableTextId Then
|
||||||
|
WritePrivateProfileString(S_SCRAPS, K_LASTBLOCK, EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNameBlock, m_OmagPhotoWD.m_MainWindow.GetIniFile())
|
||||||
|
End If
|
||||||
|
' aggiorno il testo del messaggio "Add" → "Save"
|
||||||
|
AddBtn.Content = "Save"
|
||||||
|
|
||||||
|
' notifico che da ora la lastra inserita è in modalità di modifica (non salvo la lastra come nuova, ma la sovrascrivo come in modifica)
|
||||||
|
EgtPHOTOLib.PhotoMap.refProjectVM.SetSelProjectMode(ProjectSlabVM.ProjectModeOpt.DETAIL)
|
||||||
|
EgtPHOTOLib.PhotoMap.refProjectVM.SelSlab.SetOrigValues()
|
||||||
|
|
||||||
|
' notifico che la lastra è in modifica da questo programma
|
||||||
|
EgtPHOTOLib.PhotoMap.refProjectVM.SelSlab.IsSelected = EgtPHOTOLib.MainData.nKey
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.IsSelected()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub PrintBtn_Click() Handles PrintBtn.Click
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.PrintLabel()
|
||||||
|
End Sub
|
||||||
|
#End Region ' Command
|
||||||
|
|
||||||
|
#Region "METHODS"
|
||||||
|
Private Sub EnableButtons()
|
||||||
|
AddBtn.IsEnabled = EgtPHOTOLib.PhotoMap.refOptionPanelVM.Ok_IsEnabled
|
||||||
|
' se la stampante non è abilitata allora non permetto assolutamente di abilitare il comando
|
||||||
|
If EgtPHOTOLib.MainData.bEnablePrinter Then
|
||||||
|
PrintBtn.IsEnabled = EgtPHOTOLib.PhotoMap.refOptionPanelVM.Ok_IsEnabled
|
||||||
|
End If
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
#End Region ' Methods
|
||||||
|
|
||||||
|
End Class
|
||||||
@@ -107,7 +107,8 @@ Public Class CurrentProjectPageUC
|
|||||||
Dim nDepthBits As Integer = GetPrivateProfileInt(S_OPENGL, K_DEPTHBITS, 32, m_MainWindow.GetIniFile())
|
Dim nDepthBits As Integer = GetPrivateProfileInt(S_OPENGL, K_DEPTHBITS, 32, m_MainWindow.GetIniFile())
|
||||||
CurrentProjectScene.SetViewAttributes(nDriver, b2Buff, nColorBits, nDepthBits)
|
CurrentProjectScene.SetViewAttributes(nDriver, b2Buff, nColorBits, nDepthBits)
|
||||||
' inizializzo la scena (DB geometrico + visualizzazione) e verifico presenza chiave
|
' inizializzo la scena (DB geometrico + visualizzazione) e verifico presenza chiave
|
||||||
If Not CurrentProjectScene.Init() Then
|
Dim bProd As Boolean = m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.CUT_BASE)
|
||||||
|
If Not CurrentProjectScene.Init() Or Not bProd Then
|
||||||
' Rimuovo l'host della scena perchè altrimenti rimarrebbe il buco!!
|
' Rimuovo l'host della scena perchè altrimenti rimarrebbe il buco!!
|
||||||
Me.CurrentProjectPageGrid.Children.Remove(CurrentProjectSceneHost)
|
Me.CurrentProjectPageGrid.Children.Remove(CurrentProjectSceneHost)
|
||||||
' Flag per riavvio programma
|
' Flag per riavvio programma
|
||||||
@@ -158,6 +159,7 @@ Public Class CurrentProjectPageUC
|
|||||||
#End If
|
#End If
|
||||||
m_MainWindow.Close()
|
m_MainWindow.Close()
|
||||||
If bRestart Then Process.Start(Application.ResourceAssembly.Location)
|
If bRestart Then Process.Start(Application.ResourceAssembly.Location)
|
||||||
|
Return
|
||||||
End If
|
End If
|
||||||
' visualizzazione avanzata dei triangoli costituenti le superfici
|
' visualizzazione avanzata dei triangoli costituenti le superfici
|
||||||
Dim bShowTriaAdv As Boolean = (GetPrivateProfileInt(S_SCENE, K_SHOWTRIAADV, 1, m_MainWindow.GetIniFile()) <> 0)
|
Dim bShowTriaAdv As Boolean = (GetPrivateProfileInt(S_SCENE, K_SHOWTRIAADV, 1, m_MainWindow.GetIniFile()) <> 0)
|
||||||
@@ -168,11 +170,6 @@ Public Class CurrentProjectPageUC
|
|||||||
' dimensione lineare max in pixel delle textures
|
' dimensione lineare max in pixel delle textures
|
||||||
Dim nTxrMaxLinPix As Integer = GetPrivateProfileInt(S_SCENE, K_TEXMAXLINPIX, 4096, m_MainWindow.GetIniFile())
|
Dim nTxrMaxLinPix As Integer = GetPrivateProfileInt(S_SCENE, K_TEXMAXLINPIX, 4096, m_MainWindow.GetIniFile())
|
||||||
EgtSetTextureMaxLinPixels(nTxrMaxLinPix)
|
EgtSetTextureMaxLinPixels(nTxrMaxLinPix)
|
||||||
' Verifico abilitazione prodotto
|
|
||||||
If Not m_MainWindow.GetKeyOption(MainWindow.KEY_OPT.CUT_BASE) Then
|
|
||||||
Dim MissingKeyWnd As New EgtMsgBox(m_MainWindow, EgtMsg(MSG_MISSINGKEYWD + 1), EgtMsg(MSG_MISSINGKEYWD + 5), EgtMsgBox.Buttons.OK, EgtMsgBox.Icons.NULL, 1)
|
|
||||||
m_MainWindow.Close()
|
|
||||||
End If
|
|
||||||
' Recupero e imposto handle finestra principale
|
' Recupero e imposto handle finestra principale
|
||||||
Dim hMainWnd As IntPtr = New WindowInteropHelper(Application.Current.MainWindow).Handle
|
Dim hMainWnd As IntPtr = New WindowInteropHelper(Application.Current.MainWindow).Handle
|
||||||
EgtSetMainWindowHandle(hMainWnd)
|
EgtSetMainWindowHandle(hMainWnd)
|
||||||
@@ -399,6 +396,8 @@ Public Class CurrentProjectPageUC
|
|||||||
m_MainWindow.m_CadCutPageUC.m_NestPage.CalcRawPart()
|
m_MainWindow.m_CadCutPageUC.m_NestPage.CalcRawPart()
|
||||||
m_dRawHeight = 0
|
m_dRawHeight = 0
|
||||||
UpdateHeightTxBx()
|
UpdateHeightTxBx()
|
||||||
|
' prima di parcheggiare svuoto dei pezzi in parcheggio sia vuota
|
||||||
|
m_MainWindow.m_CadCutPageUC.m_NestPage.ResetListOfGruopInPark()
|
||||||
' Parcheggio correttamente i pezzi precedentemente salvati
|
' Parcheggio correttamente i pezzi precedentemente salvati
|
||||||
Dim nId2 As Integer = EgtGetFirstPart()
|
Dim nId2 As Integer = EgtGetFirstPart()
|
||||||
While nId2 <> GDB_ID.NULL
|
While nId2 <> GDB_ID.NULL
|
||||||
@@ -413,6 +412,11 @@ Public Class CurrentProjectPageUC
|
|||||||
SetTotalArea(dTotArea)
|
SetTotalArea(dTotArea)
|
||||||
UpdateToProduceArea()
|
UpdateToProduceArea()
|
||||||
ShowAreas()
|
ShowAreas()
|
||||||
|
' Salvo info di C home
|
||||||
|
Dim dCHome As Double
|
||||||
|
EgtGetAxisHomePos("C", dCHome)
|
||||||
|
EgtSetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), INFO_CAXESHOME, DoubleToString(dCHome, 0))
|
||||||
|
EgtZoom(ZM.ALL)
|
||||||
' Dichiaro progetto non modificato
|
' Dichiaro progetto non modificato
|
||||||
EgtResetModified()
|
EgtResetModified()
|
||||||
Return True
|
Return True
|
||||||
@@ -508,8 +512,36 @@ Public Class CurrentProjectPageUC
|
|||||||
UpdateHeightTxBx()
|
UpdateHeightTxBx()
|
||||||
' aggiorno materiale
|
' aggiorno materiale
|
||||||
m_MainWindow.m_CurrentMachine.SetCurrMatByName(GetProjectMaterial())
|
m_MainWindow.m_CurrentMachine.SetCurrMatByName(GetProjectMaterial())
|
||||||
|
' aggiorno altezza sovaratavola
|
||||||
|
If GetPrivateProfileInt(S_GENERAL, "AdditionalTableByProj", 0, m_sIniFile) = 1 Then
|
||||||
|
' leggo il valore OrigiAdditionalTable
|
||||||
|
Dim dValue As Double = m_MainWindow.m_CurrentMachine.dAdditionalTable
|
||||||
|
Select Case GetCurrentTable()
|
||||||
|
Case 3
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_TAB3_ADDITIONALTABLE, dValue)
|
||||||
|
Case 2
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_TAB2_ADDITIONALTABLE, dValue)
|
||||||
|
Case Else
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), K_ADDITIONALTABLE, dValue)
|
||||||
|
End Select
|
||||||
|
m_MainWindow.m_CurrentMachine.dAdditionalTable = dValue
|
||||||
|
End If
|
||||||
' forzo visualizzazione eventuali dati su aree
|
' forzo visualizzazione eventuali dati su aree
|
||||||
SetAreasStatus(True)
|
SetAreasStatus(True)
|
||||||
|
' Recupero info C Home
|
||||||
|
Dim dCHomeCurrMach As Double
|
||||||
|
Dim dCHomeCurrproj As Double
|
||||||
|
EgtGetAxisHomePos("C", dCHomeCurrMach)
|
||||||
|
' Verifico che esista l'info del progetto
|
||||||
|
If EgtExistsInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), INFO_CAXESHOME) Then
|
||||||
|
EgtGetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), INFO_CAXESHOME, dCHomeCurrproj)
|
||||||
|
' Se la macchina indicata ha C Home differente allora comunico un errore del progetto
|
||||||
|
If Math.Abs(dCHomeCurrproj - dCHomeCurrMach) > EPS_ANG_SMALL Then
|
||||||
|
EgtOutLog(" WARNING -> C axes home project is different from current machine, delta ang C home:" & DoubleToString(dCHomeCurrproj - dCHomeCurrMach, 2))
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
EgtSetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), INFO_CAXESHOME, DoubleToString(dCHomeCurrMach, 0))
|
||||||
|
End If
|
||||||
' Dichiaro progetto non modificato
|
' Dichiaro progetto non modificato
|
||||||
EgtResetModified()
|
EgtResetModified()
|
||||||
Return True
|
Return True
|
||||||
|
|||||||
@@ -0,0 +1,40 @@
|
|||||||
|
<Window x:Class="OmagPhotoWD"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
|
xmlns:OmagCUT="clr-namespace:OmagCUT"
|
||||||
|
xmlns:EgtWPFLib5="clr-namespace:EgtWPFLib5;assembly=EgtWPFLib5"
|
||||||
|
xmlns:EgtPHOTOLib="clr-namespace:EgtPHOTOLib;assembly=EgtPHOTOLib"
|
||||||
|
FontFamily="{DynamicResource OmagCut_Font}"
|
||||||
|
Title="OmagPHOTO" Height="700" Width="1250" WindowStyle="None" ResizeMode="NoResize" ShowInTaskbar="False" >
|
||||||
|
<Border Style="{DynamicResource OmagCut_Border}">
|
||||||
|
<Grid Name="OptionSLabGrid">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
<ColumnDefinition Width="10*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="0.25*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="0.25*"/>
|
||||||
|
<RowDefinition Height="10*"/>
|
||||||
|
<RowDefinition Height="0.25*"/>
|
||||||
|
<RowDefinition Height="1.5*"/>
|
||||||
|
<RowDefinition Height="0.25*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<!-- nel codice mi occupo di riempire la griglia con gli UserControl -->
|
||||||
|
|
||||||
|
<Button Name="ExitBtn" Grid.Column="2" Grid.Row="3"
|
||||||
|
Style="{DynamicResource OmagCut_GradientBlueIconButton}" IsCancel="True">
|
||||||
|
<Image Source="{DynamicResource XImg}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
<DockPanel Grid.Column="1" Grid.Row="1" Visibility="Hidden">
|
||||||
|
<!--StatusBar-->
|
||||||
|
<EgtWPFLib5:StatusBarV DataContext="{StaticResource StatusBarVM}" DockPanel.Dock="Bottom"/>
|
||||||
|
</DockPanel>
|
||||||
|
</Grid>
|
||||||
|
</Border>
|
||||||
|
</Window>
|
||||||
@@ -0,0 +1,172 @@
|
|||||||
|
Imports EgtUILib
|
||||||
|
Imports EgtWPFLib5
|
||||||
|
Imports EgtPHOTOLib
|
||||||
|
Imports System.IO
|
||||||
|
|
||||||
|
Public Class OmagPhotoWD
|
||||||
|
' Riferimento alla MainWindow
|
||||||
|
Friend m_MainWindow As MainWindow
|
||||||
|
|
||||||
|
Private m_AddToDataBaseUC As AddToDataBaseUC
|
||||||
|
Private m_StateList As New List(Of EgtWPFLib5.IdNameStruct)
|
||||||
|
|
||||||
|
' il contorno dell sfrido è definito a partire dai punti che rappresentano i vertici dello stesso
|
||||||
|
Private m_ContornScrap As New List(Of Point3d)
|
||||||
|
' se lo stato della lastra è "2" significa che è già stata inserita nel DB (non devo generare una nuova foto!)
|
||||||
|
Private m_nState As Integer = 1
|
||||||
|
' salvo il nome del file *.jpg
|
||||||
|
Private m_sFileImage As String = String.Empty
|
||||||
|
|
||||||
|
' definsce se il slavataggio è andato a buon fine (questa variabile deve esistere anche dopo la chiusura della finestra!)
|
||||||
|
Public Shared m_IsAdded As Boolean = False
|
||||||
|
Public Shared m_sDtBsId As String = ""
|
||||||
|
Public Shared m_bSlabIsSelected As Boolean = False
|
||||||
|
|
||||||
|
' definisce se il grezzo è stato eliminato dal DB
|
||||||
|
Public Shared m_IsDeleted As Boolean = False
|
||||||
|
|
||||||
|
Public Sub New(sImage As String, ContornScrap As List(Of Point3d), MnWindow As MainWindow, nState As Integer, DatabaseID As String)
|
||||||
|
|
||||||
|
InitializeComponent()
|
||||||
|
|
||||||
|
' salvo il riferimento della finestra principale
|
||||||
|
m_MainWindow = MnWindow
|
||||||
|
' leggo lo stato dello sfrido per decidere quale modalità di apertuta usare
|
||||||
|
m_nState = nState
|
||||||
|
|
||||||
|
'--------------- CARCICO lastra esistente ---------------
|
||||||
|
If m_nState = 2 Then
|
||||||
|
m_bSlabIsSelected = False
|
||||||
|
' ricerco l'elemento già inserito nel DB
|
||||||
|
For Each Item As Slab In EgtPHOTOLib.refProjectVM.SlabList
|
||||||
|
Dim CurrId As String = Item.GetCurrentID.Trim
|
||||||
|
If Item.GetCurrentID.Trim = DatabaseID.Trim Then
|
||||||
|
EgtPHOTOLib.refProjectVM.SelSlab = Item
|
||||||
|
m_bSlabIsSelected = True
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
' se non trovo nessun elemento nel db allora esco
|
||||||
|
If IsNothing(EgtPHOTOLib.refProjectVM.SelSlab) Then
|
||||||
|
EgtOutLog("ID is not found in database: " & DatabaseID)
|
||||||
|
m_bSlabIsSelected = False
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' procedo alla visualizzazione della pagina
|
||||||
|
EgtPHOTOLib.PhotoMap.refProjectVM.SelProjectMode = ProjectSlabVM.ProjectModeOpt.DETAIL
|
||||||
|
' carico la lista degli stati letta dalla libreria
|
||||||
|
For Each Item As EgtWPFLib5.IdNameStruct In EgtPHOTOLib.PhotoMap.refOptionPanelVM.StateList
|
||||||
|
m_StateList.Add(Item)
|
||||||
|
Next
|
||||||
|
|
||||||
|
' notifico che la lastra è in modifica da questo programma
|
||||||
|
EgtPHOTOLib.PhotoMap.refProjectVM.SelSlab.IsSelected = EgtPHOTOLib.MainData.nKey
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.IsSelected()
|
||||||
|
|
||||||
|
' posiziono la finestra
|
||||||
|
Me.Top = 15
|
||||||
|
Me.Left = 15
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
|
||||||
|
'--------------- DEFINSCO nuova lastra esistente ---------------
|
||||||
|
' imposto come prima pagina sempre la lista (per inizializzare gli elementi della libreria) → ACCELERARE il processo di creazione di questo oggetto!
|
||||||
|
EgtPHOTOLib.PhotoMap.refProjectVM.SelProjectMode = ProjectSlabVM.ProjectModeOpt.NEWSLAB
|
||||||
|
' imposto il percoso della foto appena generato
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.ImagePath = sImage
|
||||||
|
' carico la foto come texture
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.PostPhoto(sImage, "")
|
||||||
|
' carico l'elenco dei materiali (non serve...)
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SetMaterialFromDB()
|
||||||
|
' definisco la lista degli stati
|
||||||
|
For Each Item As EgtWPFLib5.IdNameStruct In EgtPHOTOLib.PhotoMap.refOptionPanelVM.StateList
|
||||||
|
m_StateList.Add(Item)
|
||||||
|
Next
|
||||||
|
|
||||||
|
' imposto i dati lastra
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Thickness = m_MainWindow.m_CurrentProjectPageUC.m_dRawHeight
|
||||||
|
' carico la lista degli stati letta dalla libreria
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelState = EgtPHOTOLib.PhotoMap.refOptionPanelVM.StateList(0)
|
||||||
|
' ricorco il materiale corrente nell'elenco dei materiali presenti nel DB (se non presente nell'elenco?)
|
||||||
|
For Each MaterialItem As String In EgtPHOTOLib.PhotoMap.refOptionPanelVM.MaterialList
|
||||||
|
If MaterialItem.ToLower = m_MainWindow.m_CurrentMachine.CurrMat.sName.ToLower Then
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Material = MaterialItem
|
||||||
|
Exit For
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
|
||||||
|
' salvo in locale i punti che arrivano dal progetto
|
||||||
|
m_ContornScrap = ContornScrap
|
||||||
|
' avvio la finestra di modifica
|
||||||
|
Dim m_refImagePrevieV As New EgtPHOTOLib.ImagePreviewV()
|
||||||
|
' modifico l'immagine e salvo
|
||||||
|
m_refImagePrevieV.SetContourScraps(m_ContornScrap)
|
||||||
|
m_refImagePrevieV.Hide()
|
||||||
|
m_refImagePrevieV.Show()
|
||||||
|
m_refImagePrevieV.SaveImage()
|
||||||
|
m_refImagePrevieV.Close()
|
||||||
|
m_bSlabIsSelected = True
|
||||||
|
|
||||||
|
' posiziono la finestra
|
||||||
|
Me.Top = 15
|
||||||
|
Me.Left = 15
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' posizionamento degli UserControl all'interno della griglia
|
||||||
|
Private Sub OmagPhotoWD_Initialized(sender As Object, e As EventArgs) Handles Me.Initialized
|
||||||
|
' definisco nella pagina la posizione dello UserControl e inizializzo le liste
|
||||||
|
m_AddToDataBaseUC = New AddToDataBaseUC(Me)
|
||||||
|
m_AddToDataBaseUC.SetValue(Grid.ColumnProperty, 0)
|
||||||
|
m_AddToDataBaseUC.SetValue(Grid.RowProperty, 1)
|
||||||
|
m_AddToDataBaseUC.SetValue(Grid.RowSpanProperty, 2)
|
||||||
|
Me.OptionSLabGrid.Children.Add(m_AddToDataBaseUC)
|
||||||
|
m_AddToDataBaseUC.StateCmBx.ItemsSource = m_StateList
|
||||||
|
' recupero la scena dalla libreria e la carico nel finestra
|
||||||
|
Dim MyScene As New EgtPHOTOLib.SceneHostSlabV(EgtPHOTOLib.PhotoMap.refSceneHostVM)
|
||||||
|
MyScene.SetValue(Grid.ColumnProperty, 1)
|
||||||
|
MyScene.SetValue(Grid.ColumnSpanProperty, 2)
|
||||||
|
MyScene.SetValue(Grid.RowProperty, 1)
|
||||||
|
Me.OptionSLabGrid.Children.Add(MyScene)
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
' carcio i dati della lastra
|
||||||
|
Private Sub PostLoaded() Handles Me.Loaded
|
||||||
|
If Not m_bSlabIsSelected Then
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' carico i campi con i dati letti da database
|
||||||
|
If m_nState = 2 Then
|
||||||
|
' provo ad eseguire la separazione dei campi
|
||||||
|
m_sDtBsId = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Id
|
||||||
|
m_AddToDataBaseUC.BlockTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNameBlock
|
||||||
|
m_AddToDataBaseUC.NbrIdTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNbrID
|
||||||
|
m_AddToDataBaseUC.StateCmBx.SelectedIndex = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.State
|
||||||
|
m_AddToDataBaseUC.MatTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Material
|
||||||
|
m_AddToDataBaseUC.ThicknessTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Thickness
|
||||||
|
m_AddToDataBaseUC.ProjectTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.ProjectAssignedTo
|
||||||
|
' aggiorno il testo del messaggio "Add" → "Save"
|
||||||
|
m_AddToDataBaseUC.AddBtn.Content = "Save"
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' inizializzo i campi
|
||||||
|
'm_AddToDataBaseUC.IdTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.Id
|
||||||
|
m_AddToDataBaseUC.BlockTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNameBlock
|
||||||
|
m_AddToDataBaseUC.NbrIdTxBx.Text = EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.sNbrID
|
||||||
|
m_AddToDataBaseUC.StateCmBx.SelectedIndex = 0
|
||||||
|
m_AddToDataBaseUC.MatTxBx.Text = m_MainWindow.m_CurrentMachine.CurrMat.sName
|
||||||
|
m_AddToDataBaseUC.ThicknessTxBx.Text = LenToString(m_MainWindow.m_CurrentProjectPageUC.m_dRawHeight, 4)
|
||||||
|
m_AddToDataBaseUC.ProjectTxBx.Text = m_MainWindow.m_CurrentProjectPageUC.GetCurrentProjectName()
|
||||||
|
' rendo in primo piano la finestra
|
||||||
|
Me.Activate()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ExitBtn_Click() Handles ExitBtn.Click
|
||||||
|
' se esista una lastra corrente, notifico che deve essere deselezionata
|
||||||
|
If Not IsNothing(EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab) Then
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.SelSlab.IsSelected = 0
|
||||||
|
EgtPHOTOLib.PhotoMap.refOptionPanelVM.IsSelected()
|
||||||
|
End If
|
||||||
|
Me.Close()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
End Class
|
||||||
@@ -3,6 +3,7 @@
|
|||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||||
|
xmlns:EgtWPFLib="clr-namespace:EgtWPFLib;assembly=EgtWPFLib"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
d:DesignHeight="853.3" d:DesignWidth="1280" Initialized="OpenPage_Initialized" Loaded="OpenPage_Loaded" Unloaded="OpenPage_Unloaded">
|
d:DesignHeight="853.3" d:DesignWidth="1280" Initialized="OpenPage_Initialized" Loaded="OpenPage_Loaded" Unloaded="OpenPage_Unloaded">
|
||||||
|
|
||||||
@@ -20,7 +21,7 @@
|
|||||||
<RowDefinition Height="1*"/>
|
<RowDefinition Height="1*"/>
|
||||||
</Grid.RowDefinitions>
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
<!-- Definizione della Grid Inferiore per i Button V e X -->
|
<!-- Definizione della Grid Superiore -->
|
||||||
<Grid Name="UpperButtonsGrid" Grid.Column="1" Grid.RowSpan="2">
|
<Grid Name="UpperButtonsGrid" Grid.Column="1" Grid.RowSpan="2">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="5*"/>
|
<ColumnDefinition Width="5*"/>
|
||||||
@@ -29,10 +30,30 @@
|
|||||||
|
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
<TextBlock Name="FilePathTxBl" Foreground="White" Style="{DynamicResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
<TextBlock Name="FilePathTxBl" Grid.Row="0" Foreground="White" Style="{DynamicResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
<ListBox Name="FileListBox" Grid.Row="1" Grid.RowSpan="2" ItemTemplate="{DynamicResource DataTemplateItem}"
|
|
||||||
|
<Grid Grid.Row="1" Grid.RowSpan="2">
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="6.5*"/>
|
||||||
|
<RowDefinition Height="0.65*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<ListBox Name="FileListBox" ItemTemplate="{DynamicResource DataTemplateItem}"
|
||||||
ItemsSource="{Binding ItemList}"/>
|
ItemsSource="{Binding ItemList}"/>
|
||||||
|
|
||||||
|
<Grid Grid.Row="1" Margin="0,0,8,0">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<EgtWPFLib:EgtTextBox Name="FindTxBx" Grid.Column="0"
|
||||||
|
Style="{DynamicResource OmagCut_LeftKeyboardTextBoxNoBorder}"/>
|
||||||
|
<Button Name="ClearFindBtn" Grid.Column="1" Style="{DynamicResource OmagCut_GradientBlueIconButton}" Margin="0,6,2,6">
|
||||||
|
<Image Source="{DynamicResource XImg}" Style="{StaticResource OmagCut_ButtonIcon}" Width="30" />
|
||||||
|
</Button>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
|
||||||
<Border Name="MessageBrd" Grid.Row="3" BorderThickness="0,1,0,0" BorderBrush="Gray">
|
<Border Name="MessageBrd" Grid.Row="3" BorderThickness="0,1,0,0" BorderBrush="Gray">
|
||||||
<TextBlock Name="MessageTxBx" TextAlignment="Center"
|
<TextBlock Name="MessageTxBx" TextAlignment="Center"
|
||||||
Style="{DynamicResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
Style="{DynamicResource OmagCut_LowerCaseCharacterTextBlock}"/>
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ Public Class OpenPageUC
|
|||||||
OpenSceneHost.SetValue(Grid.ColumnProperty, 1)
|
OpenSceneHost.SetValue(Grid.ColumnProperty, 1)
|
||||||
OpenSceneHost.SetValue(Grid.RowProperty, 2)
|
OpenSceneHost.SetValue(Grid.RowProperty, 2)
|
||||||
' OpenSceneHost.SetValue(Grid.RowSpanProperty, 1)
|
' OpenSceneHost.SetValue(Grid.RowSpanProperty, 1)
|
||||||
|
OpenSceneHost.SetValue(Grid.ColumnSpanProperty, 2)
|
||||||
Me.OpenPageGrid.Children.Add(OpenSceneHost)
|
Me.OpenPageGrid.Children.Add(OpenSceneHost)
|
||||||
|
|
||||||
' Definizione del collegamento tra ItemList e ListBox1
|
' Definizione del collegamento tra ItemList e ListBox1
|
||||||
@@ -203,6 +204,36 @@ Public Class OpenPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub FindTxBx_EgtClosed(sender As Object, e As EventArgs) Handles FindTxBx.EgtClosed
|
||||||
|
' Elimino spazi iniziali e finali
|
||||||
|
FindTxBx.Text = FindTxBx.Text.Trim()
|
||||||
|
' ricarico la lista dei file
|
||||||
|
LoadCurrDir()
|
||||||
|
Dim UpdateListFile As New List(Of IconListBoxItem)
|
||||||
|
' Se esiste un nome
|
||||||
|
If Not String.IsNullOrWhiteSpace(FindTxBx.Text) Then
|
||||||
|
For Each Item As IconListBoxItem In FileListBox.ItemsSource
|
||||||
|
If Item.Name.ToLower.Contains(FindTxBx.Text.ToLower) Then
|
||||||
|
UpdateListFile.Add(Item)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
End If
|
||||||
|
If UpdateListFile.Count > 0 Then
|
||||||
|
FileListBox.ItemsSource = UpdateListFile
|
||||||
|
Else
|
||||||
|
FileListBox.ItemsSource = m_MainWindow.m_OpenItemList
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ClearFindBtn_Click() Handles ClearFindBtn.Click
|
||||||
|
' svuoto la text
|
||||||
|
FindTxBx.Text = ""
|
||||||
|
' ricarico la lista dei file
|
||||||
|
LoadCurrDir()
|
||||||
|
' e aggiorno la lista dei file
|
||||||
|
FileListBox.ItemsSource = m_MainWindow.m_OpenItemList
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Function ClearView() As Boolean
|
Private Function ClearView() As Boolean
|
||||||
' Pulisco il DB geometrico locale
|
' Pulisco il DB geometrico locale
|
||||||
EgtNewFile()
|
EgtNewFile()
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
Imports System.IO
|
Imports System.ComponentModel
|
||||||
|
Imports System.Drawing
|
||||||
|
Imports System.IO
|
||||||
Imports EgtUILib
|
Imports EgtUILib
|
||||||
Imports EgtWPFLib
|
Imports EgtWPFLib
|
||||||
|
|
||||||
@@ -99,7 +101,6 @@ Public Class ProjectMgrUC
|
|||||||
m_CurrProjPage.NewProject(nTabInd, bRetainParkedParts)
|
m_CurrProjPage.NewProject(nTabInd, bRetainParkedParts)
|
||||||
' Gestione stato FastGrid
|
' Gestione stato FastGrid
|
||||||
m_MainWindow.m_CadCutPageUC.m_FastGridSlabManager.OnPostNewProject()
|
m_MainWindow.m_CadCutPageUC.m_FastGridSlabManager.OnPostNewProject()
|
||||||
EgtZoom(ZM.ALL)
|
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Friend Function ChooseTable() As Integer
|
Friend Function ChooseTable() As Integer
|
||||||
@@ -256,10 +257,18 @@ Public Class ProjectMgrUC
|
|||||||
ResetAllSplitCurv()
|
ResetAllSplitCurv()
|
||||||
' cancello tutti i punti di inizio (Waterjet)
|
' cancello tutti i punti di inizio (Waterjet)
|
||||||
ResetAllStartCurv()
|
ResetAllStartCurv()
|
||||||
|
' cancello tutti i ponticelli disegnati
|
||||||
|
ResetAllBRidges()
|
||||||
' Ricalcolo tutte le lavorazioni
|
' Ricalcolo tutte le lavorazioni
|
||||||
Dim nWarn As Integer = 0
|
Dim nWarn As Integer = 0
|
||||||
ResetAllMachinings(nWarn)
|
ResetAllMachinings(nWarn)
|
||||||
If nWarn = 1 Then m_CurrProjPage.SetWarningMessage(EgtMsg(MSG_SPLITPAGEUC + 11)) ' Lama troppo grande per utilizzo ventosa
|
If nWarn = 1 Then m_CurrProjPage.SetWarningMessage(EgtMsg(MSG_SPLITPAGEUC + 11)) ' Lama troppo grande per utilizzo ventosa
|
||||||
|
' Se eistono elimino i grezzi delle fasi che non contengono lavorazioni
|
||||||
|
ResetAllRawPart()
|
||||||
|
' Aggiorno Info C Home
|
||||||
|
Dim dCHome As Double
|
||||||
|
EgtGetAxisHomePos("C", dCHome)
|
||||||
|
EgtSetInfo(EgtGetFirstNameInGroup(GDB_ID.ROOT, NAME_PROJMARK), INFO_CAXESHOME, DoubleToString(dCHome, 0))
|
||||||
' Aggiorno visualizzazione
|
' Aggiorno visualizzazione
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
End Sub
|
End Sub
|
||||||
@@ -476,7 +485,6 @@ Public Class ProjectMgrUC
|
|||||||
If Not (m_CurrMachine.bProdLine Or m_CurrMachine.bDemo) Then
|
If Not (m_CurrMachine.bProdLine Or m_CurrMachine.bDemo) Then
|
||||||
' Download programma (eventuali errori sono segnalati dalla funzione)
|
' Download programma (eventuali errori sono segnalati dalla funzione)
|
||||||
If m_CurrNcComm.SendProgram(sCncPath, 900) Then
|
If m_CurrNcComm.SendProgram(sCncPath, 900) Then
|
||||||
' copio il progetto corrente come progetto in lavorazione
|
|
||||||
Dim sWrkPath As String = m_MainWindow.GetTempDir() & "\" & "WorkProj.nge"
|
Dim sWrkPath As String = m_MainWindow.GetTempDir() & "\" & "WorkProj.nge"
|
||||||
My.Computer.FileSystem.CopyFile(sMchPath, sWrkPath, True)
|
My.Computer.FileSystem.CopyFile(sMchPath, sWrkPath, True)
|
||||||
' se abilitato e non è restart, lancio eventuale lua post-trasmissione
|
' se abilitato e non è restart, lancio eventuale lua post-trasmissione
|
||||||
@@ -492,6 +500,20 @@ Public Class ProjectMgrUC
|
|||||||
End If
|
End If
|
||||||
'------------------- FINE Avvio il Ciclo-Start-------------------------
|
'------------------- FINE Avvio il Ciclo-Start-------------------------
|
||||||
|
|
||||||
|
' ------------------ INIZIO gestione SCRAPS ---------------------------
|
||||||
|
Dim NewScrapsList As New List(Of Scrap)
|
||||||
|
' procedo all'aggiornamento della lista degli sfridi
|
||||||
|
UpDateScrapList(NewScrapsList)
|
||||||
|
|
||||||
|
' se esiste almeno uno sfrido da inserire come nuovo grezzo
|
||||||
|
If NewScrapsList.Count > 0 Then
|
||||||
|
' apro la finestra con l'elenco degli sfridi
|
||||||
|
Dim MyScrapsWD As New ScrapsWD(m_MainWindow, Me, NewScrapsList)
|
||||||
|
MyScrapsWD.ShowDialog()
|
||||||
|
|
||||||
|
End If
|
||||||
|
' ------------------ FINE gestione SCRAPS -----------------------------
|
||||||
|
|
||||||
' Altrimenti linea di produzione
|
' Altrimenti linea di produzione
|
||||||
Else
|
Else
|
||||||
' Verifico non sia già stato trasmesso
|
' Verifico non sia già stato trasmesso
|
||||||
@@ -663,6 +685,32 @@ Public Class ProjectMgrUC
|
|||||||
#End If
|
#End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
' aggiorno la lista dei grezzi/sfridi
|
||||||
|
Public Sub UpDateScrapList(ByRef NewScrapsList As List(Of Scrap))
|
||||||
|
If IsNothing(NewScrapsList) Then
|
||||||
|
NewScrapsList = New List(Of Scrap)
|
||||||
|
Else
|
||||||
|
NewScrapsList.Clear()
|
||||||
|
End If
|
||||||
|
' procedo all'aggiornamento della lista degli sfridi
|
||||||
|
Dim CurrRawId As Integer = EgtGetFirstRawPart()
|
||||||
|
Dim IsNewScraps As Integer = 0
|
||||||
|
Dim nCountScrap As Integer = 1
|
||||||
|
While CurrRawId <> GDB_ID.NULL
|
||||||
|
If EgtGetInfo(CurrRawId, K_ISNEWSCRAPS, IsNewScraps) Then
|
||||||
|
If IsNewScraps = 1 Or IsNewScraps = 2 Then
|
||||||
|
' deve essere aggiunto nel DB delle lastre come nuovo grezzo (l'indice è utilizzato per definire il nome della lastra)
|
||||||
|
NewScrapsList.Add(New Scrap(CurrRawId, "Scrap_" & nCountScrap.ToString, IsNewScraps))
|
||||||
|
nCountScrap += 1
|
||||||
|
' è già stato aggiunto al DB delle lastre come nuovo grezzo
|
||||||
|
Else
|
||||||
|
' non è stato definito come nuovo grezzo
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
CurrRawId = EgtGetNextRawPart(CurrRawId)
|
||||||
|
End While
|
||||||
|
End Sub
|
||||||
|
|
||||||
' ------------------------------------------------ GENERA COMANDI CNC MOVIMENTO ------------------------------------------------
|
' ------------------------------------------------ GENERA COMANDI CNC MOVIMENTO ------------------------------------------------
|
||||||
Private Sub ExecuteCommandCNC(ptMid As Point3d, dAngC As Double, dAngB As Double)
|
Private Sub ExecuteCommandCNC(ptMid As Point3d, dAngC As Double, dAngB As Double)
|
||||||
|
|
||||||
@@ -936,3 +984,60 @@ Public Class ProjectMgrUC
|
|||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
End Class
|
End Class
|
||||||
|
|
||||||
|
Public Class Scrap
|
||||||
|
|
||||||
|
Private m_iPictureID As Integer
|
||||||
|
Private m_sName As String
|
||||||
|
Private m_IdRaw As Integer
|
||||||
|
Private m_nState As Integer
|
||||||
|
|
||||||
|
Public Property PictureID() As Integer
|
||||||
|
Get
|
||||||
|
Return m_iPictureID
|
||||||
|
End Get
|
||||||
|
Set(value As Integer)
|
||||||
|
m_iPictureID = value
|
||||||
|
End Set
|
||||||
|
End Property
|
||||||
|
|
||||||
|
Public Property Name() As String
|
||||||
|
Get
|
||||||
|
Return m_sName
|
||||||
|
End Get
|
||||||
|
Set(value As String)
|
||||||
|
m_sName = value
|
||||||
|
End Set
|
||||||
|
End Property
|
||||||
|
|
||||||
|
Public ReadOnly Property IdRaw() As Integer
|
||||||
|
Get
|
||||||
|
Return m_IdRaw
|
||||||
|
End Get
|
||||||
|
End Property
|
||||||
|
|
||||||
|
Public ReadOnly Property nState As Integer
|
||||||
|
Get
|
||||||
|
Return m_nState
|
||||||
|
End Get
|
||||||
|
End Property
|
||||||
|
|
||||||
|
Public ReadOnly Property PictureString() As String
|
||||||
|
Get
|
||||||
|
Return "/Resources/ImportPageListBoxImages/" + PictureID.ToString() + ".png"
|
||||||
|
End Get
|
||||||
|
End Property
|
||||||
|
|
||||||
|
Sub New(IdScrap As Integer, NameScrap As String, State As Integer)
|
||||||
|
m_IdRaw = IdScrap
|
||||||
|
m_sName = NameScrap
|
||||||
|
m_nState = State
|
||||||
|
' immagine del grezzo
|
||||||
|
If m_nState = 2 Then
|
||||||
|
m_iPictureID = 5
|
||||||
|
Else
|
||||||
|
m_iPictureID = 4
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
End Class
|
||||||
|
|||||||
@@ -0,0 +1,50 @@
|
|||||||
|
<Window x:Class="ScrapsWD"
|
||||||
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
||||||
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
||||||
|
xmlns:EgtWPFLib="clr-namespace:EgtWPFLib;assembly=EgtWPFLib"
|
||||||
|
FontFamily="{DynamicResource OmagCut_Font}"
|
||||||
|
Title="Scraps" Height="482.6" Width="226.6" WindowStyle="None" ResizeMode="NoResize" ShowInTaskbar="False" AllowsTransparency="True" Background="Transparent">
|
||||||
|
|
||||||
|
<Border Style="{DynamicResource OmagCut_Border}">
|
||||||
|
<Grid>
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
<ColumnDefinition Width="0.5*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="3*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
<RowDefinition Height="1*"/>
|
||||||
|
<RowDefinition Height="0.5*"/>
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<Label Name="TitleTxBl" Grid.Column="1" Grid.Row="1" Foreground="White" FontSize="20" VerticalAlignment="Center"/>
|
||||||
|
<ListBox Name="ScrapsListBox" Grid.Column="1" Grid.Row="2" ItemTemplate="{DynamicResource DataTemplateItem}"
|
||||||
|
ItemsSource="{Binding ItemList, NotifyOnSourceUpdated=True}"/>
|
||||||
|
|
||||||
|
<Grid Grid.Column="1" Grid.Row="4">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="0.1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="0.1*"/>
|
||||||
|
<ColumnDefinition Width="1*"/>
|
||||||
|
<ColumnDefinition Width="0.1*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Button Name="OkBtn" Grid.Column="1" Style="{DynamicResource OmagCut_GradientBlueIconButton}" >
|
||||||
|
<Image Source="{DynamicResource VImg}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
<Button Name="ExitBtn" Grid.Column="3" Style="{DynamicResource OmagCut_GradientBlueIconButton}" IsCancel="True">
|
||||||
|
<Image Source="{DynamicResource XImg}" Style="{StaticResource OmagCut_ButtonIcon}"/>
|
||||||
|
</Button>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
</Border>
|
||||||
|
|
||||||
|
</Window>
|
||||||
@@ -0,0 +1,186 @@
|
|||||||
|
Imports EgtUILib
|
||||||
|
Imports EgtPHOTOLib
|
||||||
|
Imports System.IO
|
||||||
|
|
||||||
|
Public Class ScrapsWD
|
||||||
|
' Riferimento alla MainWindow
|
||||||
|
Private m_MainWindow As MainWindow = DirectCast(Application.Current.MainWindow, MainWindow)
|
||||||
|
Private m_refProjectMgrUC As ProjectMgrUC
|
||||||
|
|
||||||
|
Private m_ScrapList As New List(Of Scrap)
|
||||||
|
Private m_CurrScrapId As Integer = GDB_ID.NULL
|
||||||
|
Private m_CurrScrapState As Integer = 2
|
||||||
|
Private m_sDatabaseId As String = ""
|
||||||
|
|
||||||
|
Private Sub Initalized()
|
||||||
|
' resetto eventuali errori mostrati nella pagina
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
|
||||||
|
' inserisco il titolo della pagina aperta
|
||||||
|
TitleTxBl.Content = "Scraps List"
|
||||||
|
ScrapsListBox.ItemsSource = m_ScrapList
|
||||||
|
' definzione posizione finetra
|
||||||
|
Me.Left = 25
|
||||||
|
Me.Top = 25
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Public Sub New(Owner As Window, LocalProjectMgrUC As ProjectMgrUC, MyScrapList As List(Of Scrap))
|
||||||
|
Me.Owner = Owner
|
||||||
|
InitializeComponent()
|
||||||
|
m_ScrapList = MyScrapList
|
||||||
|
m_refProjectMgrUC = LocalProjectMgrUC
|
||||||
|
Initalized()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
|
||||||
|
' visualizzo la fase del pezzo selezionato
|
||||||
|
Private Sub ScrapListBox_PreviewMouseUp(sender As Object, e As MouseButtonEventArgs) Handles ScrapsListBox.PreviewMouseUp
|
||||||
|
Dim vItems As Scrap = ScrapsListBox.SelectedItems(0)
|
||||||
|
' elimino l'utimo selzione
|
||||||
|
EgtResetMark(m_CurrScrapId)
|
||||||
|
EgtDeselectObj(m_CurrScrapId)
|
||||||
|
' ricerco il grezzo associato a questo Id
|
||||||
|
Dim nRawId As Integer = EgtGetFirstRawPart()
|
||||||
|
While nRawId <> GDB_ID.NULL
|
||||||
|
If nRawId = vItems.IdRaw Then
|
||||||
|
m_CurrScrapId = nRawId
|
||||||
|
m_CurrScrapState = vItems.nState
|
||||||
|
If m_CurrScrapState = 2 Then
|
||||||
|
EgtGetInfo(nRawId, K_DATABASEID, m_sDatabaseId)
|
||||||
|
Else
|
||||||
|
m_sDatabaseId = String.Empty
|
||||||
|
End If
|
||||||
|
Dim nCurrRawPhase As Integer = 0
|
||||||
|
' recupero la fase del grezzo corrente
|
||||||
|
EgtGetInfo(nRawId, "Ph", nCurrRawPhase)
|
||||||
|
If nCurrRawPhase <> 0 Then
|
||||||
|
' evidenzio lo sfrido selezionato all'interno della fase
|
||||||
|
EgtSetCurrPhase(nCurrRawPhase)
|
||||||
|
EgtSetMark(m_CurrScrapId)
|
||||||
|
EgtSelectObj(m_CurrScrapId)
|
||||||
|
EgtDraw()
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
nRawId = EgtGetNextRawPart(nRawId)
|
||||||
|
End While
|
||||||
|
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub OkBtn_Click() Handles OkBtn.Click
|
||||||
|
If m_CurrScrapId = GDB_ID.NULL Then Return
|
||||||
|
' creo una copia dell'immagine attuale (fotocamera 1)
|
||||||
|
Dim sImage As String = String.Empty
|
||||||
|
Dim sInfo As String = String.Empty
|
||||||
|
GetPrivateProfileString(S_CAMERA, K_CAM_IMAGE, "", sImage, m_MainWindow.GetIniFile())
|
||||||
|
GetPrivateProfileString(S_CAMERA, K_CAM_INFO, "", sInfo, m_MainWindow.GetIniFile())
|
||||||
|
' recupero dalla libreria il percoso del database
|
||||||
|
Dim sPhotoDir As String = String.Empty
|
||||||
|
EgtPHOTOLib.GetPhotoDir(sPhotoDir)
|
||||||
|
' recupero l'ora corrente
|
||||||
|
Dim sDate As String = Date.Now.ToString
|
||||||
|
sDate = sDate.Replace("/", "_")
|
||||||
|
sDate = sDate.Replace(" ", "_")
|
||||||
|
sDate = sDate.Replace(":", "_")
|
||||||
|
Dim sNewPath As String = sPhotoDir & "\Scrap_" & sDate
|
||||||
|
Try
|
||||||
|
File.Copy(sImage, sNewPath & ".jpg", False)
|
||||||
|
File.Copy(sInfo, sNewPath & ".txt", False)
|
||||||
|
Catch ex As Exception
|
||||||
|
EgtOutLog(ex.Message.ToString)
|
||||||
|
End Try
|
||||||
|
|
||||||
|
' se non esiste la classe StatusBar allora provo ad inizializzarla...
|
||||||
|
If IsNothing(EgtWPFLib5.LibMap.refStatusBarVM) Then
|
||||||
|
Dim objStatusBarVM As New EgtWPFLib5.StatusBarVM
|
||||||
|
End If
|
||||||
|
' salvo il contesto corrente del programma
|
||||||
|
Dim nCurrentContetxt As Integer = EgtGetCurrentContext()
|
||||||
|
' costruisco l'elenco ordinato dei punti che reppresentano il contorno del grezzo da salvare
|
||||||
|
Dim ContornScrapList As New List(Of Point3d)
|
||||||
|
|
||||||
|
Dim RefId As New Frame3d
|
||||||
|
Dim nRawSolidId As Integer = EgtGetFirstNameInGroup(m_CurrScrapId, "RawSolid")
|
||||||
|
EgtGetTextureFrame(nRawSolidId, nRawSolidId, RefId)
|
||||||
|
Dim nCurveCompoId As Integer = EgtGetFirstNameInGroup(m_CurrScrapId, "RawOutline")
|
||||||
|
Dim dStart As Double = 0
|
||||||
|
Dim dEnd As Double = 0
|
||||||
|
EgtCurveDomain(nCurveCompoId, dStart, dEnd)
|
||||||
|
Dim ptCurrPoint As Point3d
|
||||||
|
For dU As Integer = dStart To dEnd - 1
|
||||||
|
EgtAtParamPoint(nCurveCompoId, dU, m_CurrScrapId, ptCurrPoint)
|
||||||
|
ptCurrPoint.z = 0
|
||||||
|
ptCurrPoint.ToLoc(RefId)
|
||||||
|
ContornScrapList.Add(ptCurrPoint)
|
||||||
|
Next
|
||||||
|
|
||||||
|
MainData.SetPreviousContext(nCurrentContetxt)
|
||||||
|
|
||||||
|
'If Not IsNothing(MainData.ContextSTONELib) Or MainData.ContextSTONELib <> 0 Then
|
||||||
|
'If MainData.ContextSTONELib <> 0 Then
|
||||||
|
' EgtSetCurrentContext(MainData.ContextSTONELib)
|
||||||
|
'End If
|
||||||
|
|
||||||
|
' inizializzo PojectSlabV pechè si occupa di inizializzare le pagine Detail e Option
|
||||||
|
Dim MyProjectSlab As New EgtPHOTOLib.ProjectSlabV
|
||||||
|
' ACCELERARE il processo di creazione di questo oggetto!
|
||||||
|
MyProjectSlab.DataContext = New EgtPHOTOLib.ProjectSlabVM
|
||||||
|
' per ogni creazione della nuova pagina viene creata una nuova scena, ma non viene eliminata
|
||||||
|
Dim refProjectVMSceneContext As Integer = EgtGetCurrentContext()
|
||||||
|
|
||||||
|
' apro la finestra OmagPHOTO (passo il nome del file come copia dell'originale)
|
||||||
|
If ContornScrapList.Count > 2 Then
|
||||||
|
Dim MyOmagPhotoWD As New OmagPhotoWD(sNewPath & ".jpg", ContornScrapList, m_MainWindow, m_CurrScrapState, m_sDatabaseId)
|
||||||
|
OmagPhotoWD.m_IsAdded = False
|
||||||
|
OmagPhotoWD.m_sDtBsId = String.Empty
|
||||||
|
OmagPhotoWD.m_IsDeleted = False
|
||||||
|
MyOmagPhotoWD.ShowDialog()
|
||||||
|
Else
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.SetErrorMessage("Error loading contour scrap")
|
||||||
|
End If
|
||||||
|
|
||||||
|
' ripristino il contesto corrente dell'immagine
|
||||||
|
EgtSetCurrentContext(EgtPHOTOLib.MainData.PreviousContext)
|
||||||
|
' se l'inserimento è andatoa buon fine allora procedo a notificarlo
|
||||||
|
If OmagPhotoWD.m_IsAdded AndAlso Not String.IsNullOrEmpty(OmagPhotoWD.m_sDtBsId) Then
|
||||||
|
EgtSetInfo(m_CurrScrapId, K_ISNEWSCRAPS, 2)
|
||||||
|
EgtSetInfo(m_CurrScrapId, K_DATABASEID, OmagPhotoWD.m_sDtBsId)
|
||||||
|
Else
|
||||||
|
' se è stato eliminato dal DB allora aggiorno la lista dei grezzi
|
||||||
|
If OmagPhotoWD.m_IsDeleted Then
|
||||||
|
EgtSetInfo(m_CurrScrapId, K_ISNEWSCRAPS, 1)
|
||||||
|
EgtRemoveInfo(m_CurrScrapId, K_DATABASEID)
|
||||||
|
End If
|
||||||
|
Try
|
||||||
|
File.Delete(sNewPath & ".jpg")
|
||||||
|
File.Delete(sNewPath & ".txt")
|
||||||
|
Catch ex As Exception
|
||||||
|
EgtOutLog(ex.Message.ToString)
|
||||||
|
End Try
|
||||||
|
End If
|
||||||
|
|
||||||
|
'----------------INIZIO ELIMINAZIONE contesti generati da OmagPHOTOLib per la visualizzazione delle Texture
|
||||||
|
EgtDeleteContext(EgtPHOTOLib.MainData.ContextSTONELib)
|
||||||
|
EgtDeleteContext(refProjectVMSceneContext)
|
||||||
|
'---------------- FINE ELIMINAZIONE contesti
|
||||||
|
|
||||||
|
' aggiorno la lista degli scrap
|
||||||
|
m_refProjectMgrUC.UpDateScrapList(m_ScrapList)
|
||||||
|
ScrapsListBox.ItemsSource = m_ScrapList
|
||||||
|
ScrapsListBox.Items.Refresh()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
Private Sub ExitBtn_Click() Handles ExitBtn.Click
|
||||||
|
' resetto eventuali errori mostrati nella pagina
|
||||||
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
|
' deseleziono l'oggetto corrente
|
||||||
|
EgtResetMark(m_CurrScrapId)
|
||||||
|
EgtDeselectObj(m_CurrScrapId)
|
||||||
|
' reimposto la fase iniziale
|
||||||
|
EgtSetCurrPhase(1)
|
||||||
|
EgtDraw()
|
||||||
|
Me.Close()
|
||||||
|
End Sub
|
||||||
|
|
||||||
|
End Class
|
||||||
@@ -45,9 +45,9 @@ Public Class RawPartPageUC
|
|||||||
' Layer per crocette temporanee
|
' Layer per crocette temporanee
|
||||||
Private m_nTempLay As Integer = GDB_ID.NULL
|
Private m_nTempLay As Integer = GDB_ID.NULL
|
||||||
' Definizione lista modalità di definizione grezzo per ComboBox
|
' Definizione lista modalità di definizione grezzo per ComboBox
|
||||||
Private m_RawModeList(2) As String
|
Private m_RawModeList(3) As String
|
||||||
Private m_RawModeDamagedList(1) As String
|
Private m_RawModeDamagedList(2) As String
|
||||||
Private m_RawModeListEx(3) As String
|
Private m_RawModeListEx(4) As String
|
||||||
' Variabile che indica la zona danneggiata selezionata
|
' Variabile che indica la zona danneggiata selezionata
|
||||||
Private m_nSelDmg As Integer
|
Private m_nSelDmg As Integer
|
||||||
' Array per modalità per punti
|
' Array per modalità per punti
|
||||||
@@ -63,6 +63,8 @@ Public Class RawPartPageUC
|
|||||||
Private m_CurveXDamagedAreaList As New List(Of Integer)
|
Private m_CurveXDamagedAreaList As New List(Of Integer)
|
||||||
' Flag che indica se è in corso la definizione tramite laser o se il grezzo è già chiuso
|
' Flag che indica se è in corso la definizione tramite laser o se il grezzo è già chiuso
|
||||||
Private m_bIsRawDefiningByLaser As Boolean = False
|
Private m_bIsRawDefiningByLaser As Boolean = False
|
||||||
|
' Flag che indica se è in corso la definizione tramite lama o se il grezzo è già chiuso
|
||||||
|
Private m_bIsRawDefiningBySaw As Boolean = False
|
||||||
' Flag di tastatura in corso
|
' Flag di tastatura in corso
|
||||||
Private m_bProbingOn As Boolean = False
|
Private m_bProbingOn As Boolean = False
|
||||||
' Flag inserimento punti laser da disegno
|
' Flag inserimento punti laser da disegno
|
||||||
@@ -99,6 +101,8 @@ Public Class RawPartPageUC
|
|||||||
FROM_PHOTO = 3
|
FROM_PHOTO = 3
|
||||||
DAMAGED = 4
|
DAMAGED = 4
|
||||||
DAMAGED_BY_LASER = 5
|
DAMAGED_BY_LASER = 5
|
||||||
|
DAMAGED_BY_SAW = 6
|
||||||
|
FROM_SAW = 7
|
||||||
End Enum
|
End Enum
|
||||||
|
|
||||||
Private Sub RawPartPage_Initialized(sender As Object, e As EventArgs)
|
Private Sub RawPartPage_Initialized(sender As Object, e As EventArgs)
|
||||||
@@ -123,14 +127,32 @@ Public Class RawPartPageUC
|
|||||||
m_RawModeList(0) = EgtMsg(MSG_RAWPARTPAGEUC + 1) 'Rettangolo
|
m_RawModeList(0) = EgtMsg(MSG_RAWPARTPAGEUC + 1) 'Rettangolo
|
||||||
m_RawModeList(1) = EgtMsg(MSG_RAWPARTPAGEUC + 2) 'Per Punti
|
m_RawModeList(1) = EgtMsg(MSG_RAWPARTPAGEUC + 2) 'Per Punti
|
||||||
m_RawModeList(2) = EgtMsg(MSG_RAWPARTPAGEUC + 30) 'Da Laser
|
m_RawModeList(2) = EgtMsg(MSG_RAWPARTPAGEUC + 30) 'Da Laser
|
||||||
|
If m_MainWindow.m_CurrentMachine.bSaw Then
|
||||||
|
m_RawModeList(3) = EgtMsg(MSG_DIRECTCUTPAGEUC + 24) 'Da Lama
|
||||||
|
Else
|
||||||
|
' se non insrisco "Lama" allora ridimensiono il vettore
|
||||||
|
ReDim Preserve m_RawModeList(2)
|
||||||
|
End If
|
||||||
m_RawModeListEx(0) = EgtMsg(MSG_RAWPARTPAGEUC + 1) 'Rettangolo
|
m_RawModeListEx(0) = EgtMsg(MSG_RAWPARTPAGEUC + 1) 'Rettangolo
|
||||||
m_RawModeListEx(1) = EgtMsg(MSG_RAWPARTPAGEUC + 2) 'Per Punti
|
m_RawModeListEx(1) = EgtMsg(MSG_RAWPARTPAGEUC + 2) 'Per Punti
|
||||||
m_RawModeListEx(2) = EgtMsg(MSG_RAWPARTPAGEUC + 30) 'Da Laser
|
m_RawModeListEx(2) = EgtMsg(MSG_RAWPARTPAGEUC + 30) 'Da Laser
|
||||||
|
If m_MainWindow.m_CurrentMachine.bSaw Then
|
||||||
|
m_RawModeListEx(3) = EgtMsg(MSG_DIRECTCUTPAGEUC + 24) 'Da Lama
|
||||||
|
m_RawModeListEx(4) = EgtMsg(MSG_RAWPARTPAGEUC + 35) 'Da Fotografia
|
||||||
|
Else
|
||||||
|
' se non insrisco "Lama" allora ridimensiono il vettore
|
||||||
m_RawModeListEx(3) = EgtMsg(MSG_RAWPARTPAGEUC + 35) 'Da Fotografia
|
m_RawModeListEx(3) = EgtMsg(MSG_RAWPARTPAGEUC + 35) 'Da Fotografia
|
||||||
|
ReDim Preserve m_RawModeListEx(3)
|
||||||
|
End If
|
||||||
RawModeCmBx.ItemsSource = m_RawModeList
|
RawModeCmBx.ItemsSource = m_RawModeList
|
||||||
' lista per selezione RawModeDamaged
|
' lista per selezione RawModeDamaged
|
||||||
m_RawModeDamagedList(0) = EgtMsg(MSG_RAWPARTPAGEUC + 2) 'Per Punti
|
m_RawModeDamagedList(0) = EgtMsg(MSG_RAWPARTPAGEUC + 2) 'Per Punti
|
||||||
m_RawModeDamagedList(1) = EgtMsg(MSG_RAWPARTPAGEUC + 30) 'Da Laser
|
m_RawModeDamagedList(1) = EgtMsg(MSG_RAWPARTPAGEUC + 30) 'Da Laser
|
||||||
|
If m_MainWindow.m_CurrentMachine.bSaw Then
|
||||||
|
m_RawModeDamagedList(2) = EgtMsg(MSG_DIRECTCUTPAGEUC + 24) 'Da Lama
|
||||||
|
Else
|
||||||
|
ReDim Preserve m_RawModeDamagedList(1)
|
||||||
|
End If
|
||||||
RawModeDamagedCmBx.ItemsSource = m_RawModeDamagedList
|
RawModeDamagedCmBx.ItemsSource = m_RawModeDamagedList
|
||||||
|
|
||||||
' Nascondo bottone tastatura lastra se disattivato da file .ini
|
' Nascondo bottone tastatura lastra se disattivato da file .ini
|
||||||
@@ -309,9 +331,10 @@ Public Class RawPartPageUC
|
|||||||
' Verifico cosa selezionato
|
' Verifico cosa selezionato
|
||||||
Dim nSolidId = EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_RAW_SOLID)
|
Dim nSolidId = EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_RAW_SOLID)
|
||||||
Dim nKerfId = EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_KERF)
|
Dim nKerfId = EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_KERF)
|
||||||
|
|
||||||
'----------------------------------------- INIZIO ------------------ se decido di inserire i punti laser manualmente --------------------------------------------------
|
'----------------------------------------- INIZIO ------------------ se decido di inserire i punti laser manualmente --------------------------------------------------
|
||||||
' se decido di inserire i punti laser manualmente
|
' se decido di inserire i punti laser manualmente (in assenza di collegamento con CN)
|
||||||
If m_bFromDraw And m_ActiveRawMode = RAWMODE.FROM_LASER Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER Then
|
If m_bFromDraw AndAlso (m_ActiveRawMode = RAWMODE.FROM_LASER Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER Or m_ActiveRawMode = RAWMODE.FROM_SAW Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_SAW) Then
|
||||||
' Rimuovo eventuali crocette create acquisendo i punti nel disegno
|
' Rimuovo eventuali crocette create acquisendo i punti nel disegno
|
||||||
EgtEmptyGroup(m_nTempLay)
|
EgtEmptyGroup(m_nTempLay)
|
||||||
' Acquisisco punto da disegno
|
' Acquisisco punto da disegno
|
||||||
@@ -336,6 +359,7 @@ Public Class RawPartPageUC
|
|||||||
Return
|
Return
|
||||||
End If
|
End If
|
||||||
'----------------------------------------- FINE ------------------ se decido di inserire i punti laser manualmente --------------------------------------------------
|
'----------------------------------------- FINE ------------------ se decido di inserire i punti laser manualmente --------------------------------------------------
|
||||||
|
' recupero elemento selezionato nella scena
|
||||||
EgtSetObjFilterForSelWin(True, True, True, True, True)
|
EgtSetObjFilterForSelWin(True, True, True, True, True)
|
||||||
Dim nSel As Integer
|
Dim nSel As Integer
|
||||||
EgtSelect(e.Location, 2 * Scene.DIM_SEL, 2 * Scene.DIM_SEL, nSel)
|
EgtSelect(e.Location, 2 * Scene.DIM_SEL, 2 * Scene.DIM_SEL, nSel)
|
||||||
@@ -349,8 +373,7 @@ Public Class RawPartPageUC
|
|||||||
m_bDrag = EgtUnProjectPoint(e.Location, m_ptPrev)
|
m_bDrag = EgtUnProjectPoint(e.Location, m_ptPrev)
|
||||||
m_nDragEnt = -1
|
m_nDragEnt = -1
|
||||||
m_dDragPar = -1
|
m_dDragPar = -1
|
||||||
ElseIf sName = NAME_KERF And
|
ElseIf sName = NAME_KERF And (m_ActiveRawMode = RAWMODE.RECTANGLE Or m_ActiveRawMode = RAWMODE.BY_POINTS) Then
|
||||||
(m_ActiveRawMode = RAWMODE.RECTANGLE Or m_ActiveRawMode = RAWMODE.BY_POINTS) Then
|
|
||||||
m_bDrag = EgtUnProjectPoint(e.Location, m_ptPrev)
|
m_bDrag = EgtUnProjectPoint(e.Location, m_ptPrev)
|
||||||
Dim dDist, dU As Double
|
Dim dDist, dU As Double
|
||||||
If Not EgtPointCurveDist(m_ptPrev.Loc(nKerfId), nKerfId, nKerfId, dDist, dU) Then
|
If Not EgtPointCurveDist(m_ptPrev.Loc(nKerfId), nKerfId, nKerfId, dDist, dU) Then
|
||||||
@@ -360,7 +383,7 @@ Public Class RawPartPageUC
|
|||||||
m_dDragPar = dU
|
m_dDragPar = dU
|
||||||
' Privilegio il kerf, pertanto esco
|
' Privilegio il kerf, pertanto esco
|
||||||
Exit While
|
Exit While
|
||||||
ElseIf sName = NAME_DAMAGED And (m_ActiveRawMode = RAWMODE.DAMAGED Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER) Then
|
ElseIf sName = NAME_DAMAGED And (m_ActiveRawMode = RAWMODE.DAMAGED Or m_ActiveRawMode = RAWMODE.BY_POINTS) Then
|
||||||
m_bDrag = EgtUnProjectPoint(e.Location, m_ptPrev)
|
m_bDrag = EgtUnProjectPoint(e.Location, m_ptPrev)
|
||||||
Dim dDist, dU As Double
|
Dim dDist, dU As Double
|
||||||
If Not EgtPointCurveDist(m_ptPrev.Loc(nSelId), nSelId, nSelId, dDist, dU) Then
|
If Not EgtPointCurveDist(m_ptPrev.Loc(nSelId), nSelId, nSelId, dDist, dU) Then
|
||||||
@@ -377,6 +400,7 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
nSelId = EgtGetNextObjInSelWin()
|
nSelId = EgtGetNextObjInSelWin()
|
||||||
End While
|
End While
|
||||||
|
|
||||||
' se drag e modalità punti
|
' se drag e modalità punti
|
||||||
If m_bDrag And m_ActiveRawMode = RAWMODE.BY_POINTS Then
|
If m_bDrag And m_ActiveRawMode = RAWMODE.BY_POINTS Then
|
||||||
' se aggiungi punto
|
' se aggiungi punto
|
||||||
@@ -413,7 +437,7 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
' se drag e modalità zona danneggiata
|
' se drag e modalità zona danneggiata
|
||||||
ElseIf m_bDrag And (m_ActiveRawMode = RAWMODE.DAMAGED Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER) Then
|
ElseIf m_bDrag And (m_ActiveRawMode = RAWMODE.DAMAGED Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_SAW) Then
|
||||||
' se aggiungi zona rovinata
|
' se aggiungi zona rovinata
|
||||||
If m_nPtDmgMode = DMGMODE.ADD Then
|
If m_nPtDmgMode = DMGMODE.ADD Then
|
||||||
AddNewDamagedArea()
|
AddNewDamagedArea()
|
||||||
@@ -489,6 +513,8 @@ Public Class RawPartPageUC
|
|||||||
End Select
|
End Select
|
||||||
' Aggiorno il punto precedente
|
' Aggiorno il punto precedente
|
||||||
m_ptPrev = ptCurr
|
m_ptPrev = ptCurr
|
||||||
|
' Resetto i ponticelli (per ora non sono in grado di muoverli assieme ai pezzi)
|
||||||
|
ResetAllBRidges()
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub ModifyRectangle(ptCurr As Point3d)
|
Private Sub ModifyRectangle(ptCurr As Point3d)
|
||||||
@@ -665,6 +691,8 @@ Public Class RawPartPageUC
|
|||||||
Private Sub OkBtn_Click(sender As Object, e As RoutedEventArgs) Handles OkBtn.Click
|
Private Sub OkBtn_Click(sender As Object, e As RoutedEventArgs) Handles OkBtn.Click
|
||||||
' Non è possibile uscire con tastatura in corso
|
' Non è possibile uscire con tastatura in corso
|
||||||
If m_bProbingOn Then Return
|
If m_bProbingOn Then Return
|
||||||
|
' reimposto il comando OutLine
|
||||||
|
OutlineBtn_Click(Nothing, Nothing)
|
||||||
' Se confermata uscita
|
' Se confermata uscita
|
||||||
If ExitRawPart(True) Then
|
If ExitRawPart(True) Then
|
||||||
m_MainWindow.m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Remove(Me)
|
m_MainWindow.m_CurrentProjectPageUC.CurrentProjectPageGrid.Children.Remove(Me)
|
||||||
@@ -696,6 +724,16 @@ Public Class RawPartPageUC
|
|||||||
CloseDamagedAreaByLaser()
|
CloseDamagedAreaByLaser()
|
||||||
End If
|
End If
|
||||||
End If
|
End If
|
||||||
|
If m_ActiveRawMode = RAWMODE.FROM_SAW Then
|
||||||
|
If m_bIsRawDefiningBySaw Then
|
||||||
|
CloseRawBySaw()
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
If m_ActiveRawMode = RAWMODE.DAMAGED_BY_SAW Then
|
||||||
|
If m_bIsRawDefiningBySaw Then
|
||||||
|
CloseDamagedAreaBySaw()
|
||||||
|
End If
|
||||||
|
End If
|
||||||
' Apro pagina di selezione della lavorazione prima di chiudere il grezzo
|
' Apro pagina di selezione della lavorazione prima di chiudere il grezzo
|
||||||
m_ChooseMachiningPage = New ChooseMachining(m_MainWindow)
|
m_ChooseMachiningPage = New ChooseMachining(m_MainWindow)
|
||||||
'--------------------------- SELEZIONE LAVORAZIONI ---------------------------------
|
'--------------------------- SELEZIONE LAVORAZIONI ---------------------------------
|
||||||
@@ -779,6 +817,8 @@ Public Class RawPartPageUC
|
|||||||
Case 0 ' Rettangolo
|
Case 0 ' Rettangolo
|
||||||
' Se ero in modalità da laser
|
' Se ero in modalità da laser
|
||||||
VerifyLaserDefining()
|
VerifyLaserDefining()
|
||||||
|
' Se ero in modalità da Lama
|
||||||
|
VerifySawDefinig()
|
||||||
' Verificos e sto realmente cambiando modalità
|
' Verificos e sto realmente cambiando modalità
|
||||||
Dim bChanging As Boolean = (m_ActiveRawMode <> RAWMODE.RECTANGLE)
|
Dim bChanging As Boolean = (m_ActiveRawMode <> RAWMODE.RECTANGLE)
|
||||||
' Imposto nuova modalità
|
' Imposto nuova modalità
|
||||||
@@ -790,6 +830,8 @@ Public Class RawPartPageUC
|
|||||||
Case 1 ' Punti
|
Case 1 ' Punti
|
||||||
' Se ero in modalità da laser
|
' Se ero in modalità da laser
|
||||||
VerifyLaserDefining()
|
VerifyLaserDefining()
|
||||||
|
' Se ero in modalità da Lama
|
||||||
|
VerifySawDefinig()
|
||||||
' Imposto nuova modalità
|
' Imposto nuova modalità
|
||||||
m_ActiveRawMode = RAWMODE.BY_POINTS
|
m_ActiveRawMode = RAWMODE.BY_POINTS
|
||||||
' Riattivo i controlli in base a quale modalità di inserimento contorni è attiva
|
' Riattivo i controlli in base a quale modalità di inserimento contorni è attiva
|
||||||
@@ -797,6 +839,8 @@ Public Class RawPartPageUC
|
|||||||
UpdateCircles()
|
UpdateCircles()
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
Case 2 ' Da laser
|
Case 2 ' Da laser
|
||||||
|
' Se ero in modalità da Lama
|
||||||
|
VerifySawDefinig()
|
||||||
' Imposto nuova modalità
|
' Imposto nuova modalità
|
||||||
m_ActiveRawMode = RAWMODE.FROM_LASER
|
m_ActiveRawMode = RAWMODE.FROM_LASER
|
||||||
RemoveCircles()
|
RemoveCircles()
|
||||||
@@ -811,9 +855,12 @@ Public Class RawPartPageUC
|
|||||||
' Disattivo il bottone
|
' Disattivo il bottone
|
||||||
CloseBtn.IsEnabled = False
|
CloseBtn.IsEnabled = False
|
||||||
OkBtn.IsEnabled = False
|
OkBtn.IsEnabled = False
|
||||||
Case 3 ' Da fotografia
|
Case 3 ' Da Lama
|
||||||
|
If Not m_MainWindow.m_CurrentMachine.bSaw Then ' Da fotografia
|
||||||
' Se ero in modalità da laser
|
' Se ero in modalità da laser
|
||||||
VerifyLaserDefining()
|
VerifyLaserDefining()
|
||||||
|
' Se ero in modalità da Lama
|
||||||
|
VerifySawDefinig()
|
||||||
' Imposto nuova modalità
|
' Imposto nuova modalità
|
||||||
m_ActiveRawMode = RAWMODE.FROM_PHOTO
|
m_ActiveRawMode = RAWMODE.FROM_PHOTO
|
||||||
' Riattivo i controlli in base a quale modalità di inserimento contorni è attiva
|
' Riattivo i controlli in base a quale modalità di inserimento contorni è attiva
|
||||||
@@ -822,6 +869,38 @@ Public Class RawPartPageUC
|
|||||||
' Creo il grezzo dal contorno riconosciuto nella fotografia
|
' Creo il grezzo dal contorno riconosciuto nella fotografia
|
||||||
CreateRawFromPhotoContour()
|
CreateRawFromPhotoContour()
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
Exit Select
|
||||||
|
End If
|
||||||
|
' Se ero in modalità da laser
|
||||||
|
VerifyLaserDefining()
|
||||||
|
' Imposto nuova modalità
|
||||||
|
m_ActiveRawMode = RAWMODE.FROM_SAW
|
||||||
|
RemoveCircles()
|
||||||
|
LoadFromMachine()
|
||||||
|
' Azzero lista e punto di partenza
|
||||||
|
m_CurveXKerfList.Clear()
|
||||||
|
m_bptLast = False
|
||||||
|
' Segno flag che indica definizione grezzo con laser in corso
|
||||||
|
m_bIsRawDefiningBySaw = True
|
||||||
|
' Riattivo i controlli in base a quale modalità di inserimento contorni è attiva
|
||||||
|
RawModeView()
|
||||||
|
' Disattivo il bottone
|
||||||
|
CloseBtn.IsEnabled = False
|
||||||
|
OkBtn.IsEnabled = False
|
||||||
|
Case 4 ' Da fotografia
|
||||||
|
' Se ero in modalità da laser
|
||||||
|
VerifyLaserDefining()
|
||||||
|
' Se ero in modalità da Lama
|
||||||
|
VerifySawDefinig()
|
||||||
|
' Imposto nuova modalità
|
||||||
|
m_ActiveRawMode = RAWMODE.FROM_PHOTO
|
||||||
|
' Riattivo i controlli in base a quale modalità di inserimento contorni è attiva
|
||||||
|
RawModeView()
|
||||||
|
RemoveCircles()
|
||||||
|
' Creo il grezzo dal contorno riconosciuto nella fotografia
|
||||||
|
CreateRawFromPhotoContour()
|
||||||
|
EgtDraw()
|
||||||
|
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -831,6 +910,8 @@ Public Class RawPartPageUC
|
|||||||
m_ActiveRawMode = RAWMODE.DAMAGED
|
m_ActiveRawMode = RAWMODE.DAMAGED
|
||||||
Case 1 ' Da laser
|
Case 1 ' Da laser
|
||||||
m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER
|
m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER
|
||||||
|
Case 2 ' Da Lama
|
||||||
|
m_ActiveRawMode = RAWMODE.DAMAGED_BY_SAW
|
||||||
End Select
|
End Select
|
||||||
RawModeView()
|
RawModeView()
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
@@ -927,11 +1008,43 @@ Public Class RawPartPageUC
|
|||||||
' Disattivo bottoni zone rovinate e foto
|
' Disattivo bottoni zone rovinate e foto
|
||||||
DamagedAreaGpBx.Visibility = Windows.Visibility.Hidden
|
DamagedAreaGpBx.Visibility = Windows.Visibility.Hidden
|
||||||
ConfirmPhotoBtn.Visibility = Windows.Visibility.Hidden
|
ConfirmPhotoBtn.Visibility = Windows.Visibility.Hidden
|
||||||
|
Case RAWMODE.DAMAGED_BY_SAW
|
||||||
|
RawModeCmBx.IsEnabled = True
|
||||||
|
RawModeDamagedCmBx.Visibility = Visibility.Visible
|
||||||
|
LengthTxBx.IsEnabled = False
|
||||||
|
WidthTxBx.IsEnabled = False
|
||||||
|
OffsetXTxBx.IsEnabled = False
|
||||||
|
OffsetYTxBx.IsEnabled = False
|
||||||
|
' Visualizzo bottoni per laser
|
||||||
|
PointsGpBx.Visibility = Windows.Visibility.Visible
|
||||||
|
PointsGpBx.SetValue(Grid.RowSpanProperty, 2)
|
||||||
|
AddBtn.SetValue(Grid.RowSpanProperty, 1)
|
||||||
|
RemoveBtn.SetValue(Grid.RowSpanProperty, 1)
|
||||||
|
CloseBtn.Visibility = Windows.Visibility.Visible
|
||||||
|
' Disattivo bottoni zone rovinate e foto
|
||||||
|
DamagedAreaGpBx.Visibility = Windows.Visibility.Hidden
|
||||||
|
ConfirmPhotoBtn.Visibility = Windows.Visibility.Hidden
|
||||||
|
Case RAWMODE.FROM_SAW
|
||||||
|
RawModeCmBx.IsEnabled = True
|
||||||
|
RawModeDamagedCmBx.Visibility = Visibility.Collapsed
|
||||||
|
LengthTxBx.IsEnabled = False
|
||||||
|
WidthTxBx.IsEnabled = False
|
||||||
|
OffsetXTxBx.IsEnabled = False
|
||||||
|
OffsetYTxBx.IsEnabled = False
|
||||||
|
' Visualizzo bottoni per lama
|
||||||
|
PointsGpBx.Visibility = Windows.Visibility.Visible
|
||||||
|
PointsGpBx.SetValue(Grid.RowSpanProperty, 2)
|
||||||
|
AddBtn.SetValue(Grid.RowSpanProperty, 1)
|
||||||
|
RemoveBtn.SetValue(Grid.RowSpanProperty, 1)
|
||||||
|
CloseBtn.Visibility = Windows.Visibility.Visible
|
||||||
|
' Disattivo bottoni zone rovinate e foto
|
||||||
|
DamagedAreaGpBx.Visibility = Windows.Visibility.Hidden
|
||||||
|
ConfirmPhotoBtn.Visibility = Windows.Visibility.Hidden
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
Private Sub OutlineBtn_Click(sender As Object, e As RoutedEventArgs) Handles OutlineBtn.Click
|
Private Sub OutlineBtn_Click(sender As Object, e As RoutedEventArgs) Handles OutlineBtn.Click
|
||||||
If m_ActiveRawMode = RAWMODE.DAMAGED Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER Then
|
If m_ActiveRawMode = RAWMODE.DAMAGED Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER Or m_ActiveRawMode = RAWMODE.DAMAGED_BY_SAW Then
|
||||||
' m_ActiveRawMode = RAWMODE.BY_POINTS
|
' m_ActiveRawMode = RAWMODE.BY_POINTS
|
||||||
m_ActiveRawMode = m_PrecActiveRawMode
|
m_ActiveRawMode = m_PrecActiveRawMode
|
||||||
RawModeCmBx.SelectedIndex = m_ActiveRawMode
|
RawModeCmBx.SelectedIndex = m_ActiveRawMode
|
||||||
@@ -946,6 +1059,9 @@ Public Class RawPartPageUC
|
|||||||
If m_PrecActiveRawMode = RAWMODE.FROM_LASER Then
|
If m_PrecActiveRawMode = RAWMODE.FROM_LASER Then
|
||||||
m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER
|
m_ActiveRawMode = RAWMODE.DAMAGED_BY_LASER
|
||||||
RawModeDamagedCmBx.SelectedIndex = 1
|
RawModeDamagedCmBx.SelectedIndex = 1
|
||||||
|
ElseIf m_PrecActiveRawMode = RAWMODE.FROM_SAW Then
|
||||||
|
m_ActiveRawMode = RAWMODE.DAMAGED_BY_SAW
|
||||||
|
RawModeDamagedCmBx.SelectedIndex = 2
|
||||||
Else
|
Else
|
||||||
m_ActiveRawMode = RAWMODE.DAMAGED
|
m_ActiveRawMode = RAWMODE.DAMAGED
|
||||||
RawModeDamagedCmBx.SelectedIndex = 0
|
RawModeDamagedCmBx.SelectedIndex = 0
|
||||||
@@ -1010,6 +1126,54 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
AddBtn.IsChecked = False
|
AddBtn.IsChecked = False
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
Case RAWMODE.FROM_SAW
|
||||||
|
Dim ptAcquired As Point3d
|
||||||
|
' Se inserimento manuale dei punti laser
|
||||||
|
If m_bFromDraw Then
|
||||||
|
If Not IsNothing(m_ptPrev) Then
|
||||||
|
ptAcquired = m_ptPrev
|
||||||
|
ptAcquired.ToLoc(New Frame3d(m_ptTableMin))
|
||||||
|
Else
|
||||||
|
m_CurrProjPage.SetErrorMessage(EgtMsg(90532)) ' Errore nell'acquisizione del punto
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' altrimenti da macchina
|
||||||
|
Else
|
||||||
|
If Not AcquireSawPoint(ptAcquired) Then
|
||||||
|
m_CurrProjPage.SetErrorMessage(EgtMsg(90532)) ' Errore nell'acquisizione del punto
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' Limito il punto a stare nella tavola con franco pari al kerf
|
||||||
|
If ptAcquired.x < m_RawKerf Then ptAcquired.x = m_RawKerf + SAFE_RAW_DIST
|
||||||
|
If ptAcquired.y < m_RawKerf Then ptAcquired.y = m_RawKerf + SAFE_RAW_DIST
|
||||||
|
If ptAcquired.x > m_dTableLength - m_RawKerf Then ptAcquired.x = m_dTableLength - m_RawKerf - SAFE_RAW_DIST
|
||||||
|
If ptAcquired.y > m_dTableWidth - m_RawKerf Then ptAcquired.y = m_dTableWidth - m_RawKerf - SAFE_RAW_DIST
|
||||||
|
' Aggiusto Z punto movimentato (è in locale al tavolo)
|
||||||
|
ptAcquired.z = m_CurrentMachine.dAdditionalTable + m_RawHeight
|
||||||
|
'Porto il punto nel riferimento del grezzo
|
||||||
|
Dim frRaw As New Frame3d
|
||||||
|
EgtGetGroupGlobFrame(m_CurrProjPage.m_nRawId, frRaw)
|
||||||
|
ptAcquired.LocToLoc(New Frame3d(m_ptTableMin), frRaw)
|
||||||
|
m_ptPrev.LocToLoc(New Frame3d(m_ptTableMin), frRaw)
|
||||||
|
If m_bptLast Then
|
||||||
|
If Point3d.SameApprox(ptAcquired, m_ptLast) Then
|
||||||
|
AddBtn.IsChecked = False
|
||||||
|
Exit Sub
|
||||||
|
End If
|
||||||
|
Dim NewLine As Integer = EgtCreateLine(m_CurrProjPage.m_nRawId, m_ptLast, ptAcquired)
|
||||||
|
EgtSetColor(NewLine, m_KerfCol)
|
||||||
|
m_CurveXKerfList.Add(NewLine)
|
||||||
|
Else
|
||||||
|
m_bptLast = True
|
||||||
|
End If
|
||||||
|
m_ptLast = ptAcquired
|
||||||
|
If m_CurveXKerfList.Count > 1 Then
|
||||||
|
OkBtn.IsEnabled = True
|
||||||
|
CloseBtn.IsEnabled = True
|
||||||
|
End If
|
||||||
|
AddBtn.IsChecked = False
|
||||||
|
EgtDraw()
|
||||||
Case RAWMODE.DAMAGED
|
Case RAWMODE.DAMAGED
|
||||||
' Verifico ci sia almeno una zona rovinata
|
' Verifico ci sia almeno una zona rovinata
|
||||||
If EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_DAMAGED) = GDB_ID.NULL Then
|
If EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_DAMAGED) = GDB_ID.NULL Then
|
||||||
@@ -1068,6 +1232,54 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
AddBtn.IsChecked = False
|
AddBtn.IsChecked = False
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
Case RAWMODE.DAMAGED_BY_SAW
|
||||||
|
Dim ptAcquired As Point3d
|
||||||
|
' Se inserimento manuale dei punti laser
|
||||||
|
If m_bFromDraw Then
|
||||||
|
If Not IsNothing(m_ptPrev) Then
|
||||||
|
ptAcquired = m_ptPrev
|
||||||
|
ptAcquired.ToLoc(New Frame3d(m_ptTableMin))
|
||||||
|
Else
|
||||||
|
m_CurrProjPage.SetErrorMessage(EgtMsg(90532)) ' Errore nell'acquisizione del punto
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
' altrimenti da macchina
|
||||||
|
Else
|
||||||
|
If Not AcquireSawPoint(ptAcquired) Then
|
||||||
|
m_CurrProjPage.SetErrorMessage(EgtMsg(90532)) ' Errore nell'acquisizione del punto
|
||||||
|
Return
|
||||||
|
End If
|
||||||
|
End If
|
||||||
|
' Limito il punto a stare nella tavola con franco pari al kerf
|
||||||
|
If ptAcquired.x < m_RawKerf Then ptAcquired.x = m_RawKerf + SAFE_RAW_DIST
|
||||||
|
If ptAcquired.y < m_RawKerf Then ptAcquired.y = m_RawKerf + SAFE_RAW_DIST
|
||||||
|
If ptAcquired.x > m_dTableLength - m_RawKerf Then ptAcquired.x = m_dTableLength - m_RawKerf - SAFE_RAW_DIST
|
||||||
|
If ptAcquired.y > m_dTableWidth - m_RawKerf Then ptAcquired.y = m_dTableWidth - m_RawKerf - SAFE_RAW_DIST
|
||||||
|
' Aggiusto Z punto movimentato (è in locale al tavolo)
|
||||||
|
ptAcquired.z = m_CurrentMachine.dAdditionalTable + m_RawHeight
|
||||||
|
'Porto il punto nel riferimento del grezzo
|
||||||
|
Dim frRaw As New Frame3d
|
||||||
|
EgtGetGroupGlobFrame(m_CurrProjPage.m_nRawId, frRaw)
|
||||||
|
ptAcquired.LocToLoc(New Frame3d(m_ptTableMin), frRaw)
|
||||||
|
m_ptPrev.LocToLoc(New Frame3d(m_ptTableMin), frRaw)
|
||||||
|
If m_bptLast Then
|
||||||
|
If Point3d.SameApprox(ptAcquired, m_ptLast) Then
|
||||||
|
AddBtn.IsChecked = False
|
||||||
|
Exit Sub
|
||||||
|
End If
|
||||||
|
Dim NewLine As Integer = EgtCreateLine(m_CurrProjPage.m_nRawId, m_ptLast, ptAcquired)
|
||||||
|
EgtSetColor(NewLine, m_KerfCol)
|
||||||
|
m_CurveXDamagedAreaList.Add(NewLine)
|
||||||
|
Else
|
||||||
|
m_bptLast = True
|
||||||
|
End If
|
||||||
|
m_ptLast = ptAcquired
|
||||||
|
If m_CurveXDamagedAreaList.Count > 1 Then
|
||||||
|
OkBtn.IsEnabled = True
|
||||||
|
CloseBtn.IsEnabled = True
|
||||||
|
End If
|
||||||
|
AddBtn.IsChecked = False
|
||||||
|
EgtDraw()
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -1099,6 +1311,28 @@ Public Class RawPartPageUC
|
|||||||
Return True
|
Return True
|
||||||
End Function
|
End Function
|
||||||
|
|
||||||
|
Private Function AcquireSawPoint(ByRef ptAcquired As Point3d) As Boolean
|
||||||
|
Dim ptTipP1 As Point3d
|
||||||
|
' Recupero la posizione macchina
|
||||||
|
Dim dL1, dL2, dL3, dR1, dR2 As Double
|
||||||
|
If Not m_MainWindow.m_CNCommunication.GetAxesPositions(dL1, dL2, dL3, dR1, dR2) Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
' Recupero dati utensile e testa corrente
|
||||||
|
Dim sTool As String = ""
|
||||||
|
Dim sHead As String = ""
|
||||||
|
Dim nExit As Integer = 0
|
||||||
|
EgtGetCalcTool(sTool, sHead, nExit)
|
||||||
|
' Trasformo in posizione punta utensile in basso
|
||||||
|
If Not EgtGetCalcTipFromPositions(dL1, dL2, dL3, dR1, dR2, True, ptTipP1) Then
|
||||||
|
Return False
|
||||||
|
End If
|
||||||
|
' Porto il tip nell'origine tavola
|
||||||
|
ptAcquired = ptTipP1
|
||||||
|
ptAcquired.ToLoc(New Frame3d(m_ptTableMin))
|
||||||
|
Return True
|
||||||
|
End Function
|
||||||
|
|
||||||
Private Sub RemoveBtn_Click(sender As Object, e As RoutedEventArgs) Handles RemoveBtn.Click
|
Private Sub RemoveBtn_Click(sender As Object, e As RoutedEventArgs) Handles RemoveBtn.Click
|
||||||
Select Case m_ActiveRawMode
|
Select Case m_ActiveRawMode
|
||||||
Case RAWMODE.RECTANGLE
|
Case RAWMODE.RECTANGLE
|
||||||
@@ -1126,6 +1360,26 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
RemoveBtn.IsChecked = False
|
RemoveBtn.IsChecked = False
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
Case RAWMODE.FROM_SAW
|
||||||
|
If m_CurveXKerfList.Count > 0 Then
|
||||||
|
If m_CurveXKerfList.Count = 1 Then
|
||||||
|
' Aggiorno ptLast con primo punto
|
||||||
|
EgtStartPoint(m_CurveXKerfList(m_CurveXKerfList.Count - 1), m_ptLast)
|
||||||
|
' Cancello ultima linea
|
||||||
|
EgtErase(m_CurveXKerfList(m_CurveXKerfList.Count - 1))
|
||||||
|
m_CurveXKerfList.RemoveAt(m_CurveXKerfList.Count - 1)
|
||||||
|
Else
|
||||||
|
' Cancello ultima linea
|
||||||
|
EgtErase(m_CurveXKerfList(m_CurveXKerfList.Count - 1))
|
||||||
|
m_CurveXKerfList.RemoveAt(m_CurveXKerfList.Count - 1)
|
||||||
|
' Aggiorno ptLast
|
||||||
|
EgtEndPoint(m_CurveXKerfList(m_CurveXKerfList.Count - 1), m_ptLast)
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
m_bptLast = False
|
||||||
|
End If
|
||||||
|
RemoveBtn.IsChecked = False
|
||||||
|
EgtDraw()
|
||||||
Case RAWMODE.DAMAGED
|
Case RAWMODE.DAMAGED
|
||||||
' Verifico ci sia almeno una zona rovinata
|
' Verifico ci sia almeno una zona rovinata
|
||||||
If EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_DAMAGED) = GDB_ID.NULL Then
|
If EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_DAMAGED) = GDB_ID.NULL Then
|
||||||
@@ -1136,6 +1390,46 @@ Public Class RawPartPageUC
|
|||||||
DeleteBtn.IsChecked = False
|
DeleteBtn.IsChecked = False
|
||||||
m_nPtMode = If(RemoveBtn.IsChecked(), PTMODE.REMOVE, PTMODE.MOVE)
|
m_nPtMode = If(RemoveBtn.IsChecked(), PTMODE.REMOVE, PTMODE.MOVE)
|
||||||
m_nPtDmgMode = DMGMODE.NONE
|
m_nPtDmgMode = DMGMODE.NONE
|
||||||
|
Case RAWMODE.DAMAGED_BY_LASER
|
||||||
|
If m_CurveXDamagedAreaList.Count > 0 Then
|
||||||
|
If m_CurveXDamagedAreaList.Count = 1 Then
|
||||||
|
' Aggiorno ptLast con primo punto
|
||||||
|
EgtStartPoint(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1), m_ptLast)
|
||||||
|
' Cancello ultima linea
|
||||||
|
EgtErase(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1))
|
||||||
|
m_CurveXDamagedAreaList.RemoveAt(m_CurveXDamagedAreaList.Count - 1)
|
||||||
|
Else
|
||||||
|
' Cancello ultima linea
|
||||||
|
EgtErase(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1))
|
||||||
|
m_CurveXDamagedAreaList.RemoveAt(m_CurveXDamagedAreaList.Count - 1)
|
||||||
|
' Aggiorno ptLast
|
||||||
|
EgtEndPoint(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1), m_ptLast)
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
m_bptLast = False
|
||||||
|
End If
|
||||||
|
RemoveBtn.IsChecked = False
|
||||||
|
EgtDraw()
|
||||||
|
Case RAWMODE.DAMAGED_BY_SAW
|
||||||
|
If m_CurveXDamagedAreaList.Count > 0 Then
|
||||||
|
If m_CurveXDamagedAreaList.Count = 1 Then
|
||||||
|
' Aggiorno ptLast con primo punto
|
||||||
|
EgtStartPoint(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1), m_ptLast)
|
||||||
|
' Cancello ultima linea
|
||||||
|
EgtErase(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1))
|
||||||
|
m_CurveXDamagedAreaList.RemoveAt(m_CurveXDamagedAreaList.Count - 1)
|
||||||
|
Else
|
||||||
|
' Cancello ultima linea
|
||||||
|
EgtErase(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1))
|
||||||
|
m_CurveXDamagedAreaList.RemoveAt(m_CurveXDamagedAreaList.Count - 1)
|
||||||
|
' Aggiorno ptLast
|
||||||
|
EgtEndPoint(m_CurveXDamagedAreaList(m_CurveXDamagedAreaList.Count - 1), m_ptLast)
|
||||||
|
End If
|
||||||
|
Else
|
||||||
|
m_bptLast = False
|
||||||
|
End If
|
||||||
|
RemoveBtn.IsChecked = False
|
||||||
|
EgtDraw()
|
||||||
End Select
|
End Select
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
@@ -1758,6 +2052,18 @@ Public Class RawPartPageUC
|
|||||||
' Recupero origine tavola rispetto allo 0 macchina
|
' Recupero origine tavola rispetto allo 0 macchina
|
||||||
Dim TableRef As Point3d
|
Dim TableRef As Point3d
|
||||||
EgtGetTableRef(1, TableRef)
|
EgtGetTableRef(1, TableRef)
|
||||||
|
' imposto modo automatico
|
||||||
|
Select Case m_MainWindow.m_CNCommunication.m_nNCType
|
||||||
|
Case 1, 2
|
||||||
|
' in attesa di verifica
|
||||||
|
Case 3
|
||||||
|
Dim nResult As Short = m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_WriteCncMode(0)
|
||||||
|
EgtOutLog("Impostata modalità automatica: esito " & nResult.ToString)
|
||||||
|
Case 4
|
||||||
|
' FANUC - Manual:7, Edit:1
|
||||||
|
Dim nResult As Short = m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_WriteCncMode(7)
|
||||||
|
EgtOutLog("Impostata modalità manuale: esito " & nResult.ToString)
|
||||||
|
End Select
|
||||||
' Recupero file LUA
|
' Recupero file LUA
|
||||||
EgtLuaExecFile(m_CurrentMachine.sMachDir() & "\DirectCmd\RawProbing.lua")
|
EgtLuaExecFile(m_CurrentMachine.sMachDir() & "\DirectCmd\RawProbing.lua")
|
||||||
' Imposto parametri
|
' Imposto parametri
|
||||||
@@ -1795,6 +2101,11 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
m_MainWindow.m_CurrentProjectPageUC.ClearMessage()
|
||||||
EgtOutLog("RawProbing : sent NC program")
|
EgtOutLog("RawProbing : sent NC program")
|
||||||
|
' Se fanuc passo in modalità AUTO e attivo
|
||||||
|
If m_MainWindow.m_CNCommunication.m_nNCType = 4 Then
|
||||||
|
Dim nResult As Short = m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_WriteCncMode(0)
|
||||||
|
EgtOutLog("Impostata modalità automatica: esito " & nResult.ToString)
|
||||||
|
End If
|
||||||
' Aspetto e lo avvio
|
' Aspetto e lo avvio
|
||||||
System.Threading.Thread.Sleep(300)
|
System.Threading.Thread.Sleep(300)
|
||||||
m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_CycleStart()
|
m_MainWindow.m_CNCommunication.m_CN.DGeneralFunctions_CycleStart()
|
||||||
@@ -1860,6 +2171,10 @@ Public Class RawPartPageUC
|
|||||||
Else
|
Else
|
||||||
RawThickness *= ONEMM / 1000
|
RawThickness *= ONEMM / 1000
|
||||||
End If
|
End If
|
||||||
|
' Se fanuc il dato è in mm (NON MICRON)
|
||||||
|
If m_MainWindow.m_CNCommunication.m_nNCType = 4 Then
|
||||||
|
RawThickness *= 1000
|
||||||
|
End If
|
||||||
' Sottraggo eventuale spessore sovratavola
|
' Sottraggo eventuale spessore sovratavola
|
||||||
RawThickness -= m_CurrentMachine.dAdditionalTable
|
RawThickness -= m_CurrentMachine.dAdditionalTable
|
||||||
' Imposto spessore misurato come altezza grezzo
|
' Imposto spessore misurato come altezza grezzo
|
||||||
@@ -1976,6 +2291,26 @@ Public Class RawPartPageUC
|
|||||||
End If
|
End If
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub VerifySawDefinig()
|
||||||
|
If m_bIsRawDefiningBySaw Then
|
||||||
|
If m_CurveXKerfList.Count > 1 Then
|
||||||
|
CloseRawBySaw()
|
||||||
|
Else
|
||||||
|
' Elimino tutti i segmenti disegnati
|
||||||
|
For Each nEntityId As Integer In m_CurveXKerfList
|
||||||
|
If EgtGetType(nEntityId) = GDB_TY.CRV_LINE Then
|
||||||
|
EgtErase(nEntityId)
|
||||||
|
End If
|
||||||
|
Next
|
||||||
|
' Azzero lista e punto di partenza
|
||||||
|
m_CurveXKerfList.Clear()
|
||||||
|
' Creo rettangolo
|
||||||
|
UpdateRawPart()
|
||||||
|
End If
|
||||||
|
m_bIsRawDefiningBySaw = False
|
||||||
|
End If
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub LoadFromMachine()
|
Private Sub LoadFromMachine()
|
||||||
' Elimino grezzo già presente
|
' Elimino grezzo già presente
|
||||||
EgtErase(EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_RAW_SOLID))
|
EgtErase(EgtGetFirstNameInGroup(m_CurrProjPage.m_nRawId, NAME_RAW_SOLID))
|
||||||
@@ -1993,6 +2328,10 @@ Public Class RawPartPageUC
|
|||||||
Select Case m_ActiveRawMode
|
Select Case m_ActiveRawMode
|
||||||
Case RAWMODE.DAMAGED_BY_LASER
|
Case RAWMODE.DAMAGED_BY_LASER
|
||||||
CloseDamagedAreaByLaser()
|
CloseDamagedAreaByLaser()
|
||||||
|
Case RAWMODE.DAMAGED_BY_SAW
|
||||||
|
CloseDamagedAreaBySaw()
|
||||||
|
Case RAWMODE.FROM_SAW
|
||||||
|
CloseRawBySaw()
|
||||||
Case Else
|
Case Else
|
||||||
CloseRawByLaser()
|
CloseRawByLaser()
|
||||||
End Select
|
End Select
|
||||||
@@ -2036,6 +2375,42 @@ Public Class RawPartPageUC
|
|||||||
CloseBtn.IsEnabled = False
|
CloseBtn.IsEnabled = False
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub CloseRawBySaw()
|
||||||
|
' Verifico ci siano punti
|
||||||
|
If m_CurveXKerfList.Count() = 0 Then Return
|
||||||
|
' Recupero punto iniziale prima linea del grezzo
|
||||||
|
Dim ptStart As Point3d
|
||||||
|
EgtStartPoint(m_CurveXKerfList(0), ptStart)
|
||||||
|
m_CurveXKerfList.Add(EgtCreateLine(m_CurrProjPage.m_nRawId, m_ptLast, ptStart))
|
||||||
|
' Trasformo lista di curve in un array
|
||||||
|
Dim CurveXKerfArray As Integer() = m_CurveXKerfList.ToArray
|
||||||
|
' Creo contorno kerf
|
||||||
|
Dim nKerfId As Integer = EgtCreateCurveCompoByChain(m_CurrProjPage.m_nRawId, m_CurveXKerfList.Count, CurveXKerfArray, ptStart, True)
|
||||||
|
EgtSetName(nKerfId, NAME_KERF)
|
||||||
|
EgtSetColor(nKerfId, m_KerfCol)
|
||||||
|
' Pulisco lista entità del grezzo
|
||||||
|
m_CurveXKerfList.Clear()
|
||||||
|
' Aggiorno il grezzo comprese dimensioni e posizione
|
||||||
|
UpdateRawPartKerf()
|
||||||
|
' Salvo il valore del kerf (sempre in mm)
|
||||||
|
Dim dKerf As Double = 0
|
||||||
|
StringToLen(KerfTxBx.Text, dKerf)
|
||||||
|
If dKerf < 0 Then
|
||||||
|
EgtSetInfo(m_CurrProjPage.m_nRawId, KEY_INVERT_KERF, -1)
|
||||||
|
Else
|
||||||
|
EgtSetInfo(m_CurrProjPage.m_nRawId, KEY_INVERT_KERF, 1)
|
||||||
|
End If
|
||||||
|
EgtSetInfo(m_CurrProjPage.m_nRawId, KEY_KERF, m_RawKerf)
|
||||||
|
' Segno flag che indica fine della definizione
|
||||||
|
m_bIsRawDefiningBySaw = False
|
||||||
|
' Elimino primo punto per prossimo grezzo
|
||||||
|
m_bptLast = False
|
||||||
|
' Aggiorno visualizzazione
|
||||||
|
EgtDraw()
|
||||||
|
' Disattivo il bottone chiudi grezzo
|
||||||
|
CloseBtn.IsEnabled = False
|
||||||
|
End Sub
|
||||||
|
|
||||||
#Region "Damaged Area"
|
#Region "Damaged Area"
|
||||||
|
|
||||||
Private Sub AddNewDamagedArea()
|
Private Sub AddNewDamagedArea()
|
||||||
@@ -2092,6 +2467,32 @@ Public Class RawPartPageUC
|
|||||||
CloseBtn.IsEnabled = False
|
CloseBtn.IsEnabled = False
|
||||||
End Sub
|
End Sub
|
||||||
|
|
||||||
|
Private Sub CloseDamagedAreaBySaw()
|
||||||
|
' Verifico ci siano punti
|
||||||
|
If m_CurveXDamagedAreaList.Count() = 0 Then Return
|
||||||
|
' Recupero punto iniziale prima linea del grezzo
|
||||||
|
Dim ptStart As Point3d
|
||||||
|
EgtStartPoint(m_CurveXDamagedAreaList(0), ptStart)
|
||||||
|
' creao la linea che va dal primo punto all'ultimo
|
||||||
|
m_CurveXDamagedAreaList.Add(EgtCreateLine(m_CurrProjPage.m_nRawId, m_ptLast, ptStart))
|
||||||
|
' Trasformo lista di curve in un array
|
||||||
|
Dim CurveXDamagedAreaArray As Integer() = m_CurveXDamagedAreaList.ToArray
|
||||||
|
' Creo contorno kerf
|
||||||
|
Dim nDmgId As Integer = EgtCreateCurveCompoByChain(m_CurrProjPage.m_nRawId, m_CurveXDamagedAreaList.Count, CurveXDamagedAreaArray, ptStart, True)
|
||||||
|
EgtSetName(nDmgId, NAME_DAMAGED)
|
||||||
|
EgtSetColor(nDmgId, m_KerfCol)
|
||||||
|
' Pulisco lista entità del grezzo
|
||||||
|
m_CurveXDamagedAreaList.Clear()
|
||||||
|
' Segno flag che indica fine della definizione
|
||||||
|
m_bIsRawDefiningBySaw = False
|
||||||
|
' Elimino primo punto per prossimo grezzo
|
||||||
|
m_bptLast = False
|
||||||
|
' Aggiorno visualizzazione
|
||||||
|
EgtDraw()
|
||||||
|
' Disattivo il bottone chiudi grezzo
|
||||||
|
CloseBtn.IsEnabled = False
|
||||||
|
End Sub
|
||||||
|
|
||||||
Private Sub RemoveDamagedArea()
|
Private Sub RemoveDamagedArea()
|
||||||
' Elimino area rovinata selezionata
|
' Elimino area rovinata selezionata
|
||||||
EgtErase(m_nSelDmg)
|
EgtErase(m_nSelDmg)
|
||||||
|
|||||||
|
After Width: | Height: | Size: 534 B |
|
After Width: | Height: | Size: 1.1 KiB |
|
After Width: | Height: | Size: 610 B |
|
After Width: | Height: | Size: 742 B |
|
After Width: | Height: | Size: 1.4 KiB |
|
After Width: | Height: | Size: 1.9 KiB |
|
Before Width: | Height: | Size: 6.4 KiB After Width: | Height: | Size: 6.5 KiB |
|
Before Width: | Height: | Size: 857 B After Width: | Height: | Size: 26 KiB |
|
After Width: | Height: | Size: 857 B |