프로젝트

일반

사용자정보

통계
| 개정판:

hytos / DTI_PID / SPPIDConverter / Main.vb @ a31687ed

이력 | 보기 | 이력해설 | 다운로드 (365 KB)

1
Imports System.IO
2
Imports System.Data.SqlClient
3
Imports System.Data.SQLite
4
Imports Plaice
5
Imports Llama
6
Imports ComUtil.MessageLog.CEventLog
7

    
8
Imports System.Threading
9

    
10
Public Class Main
11
    'Dim _Mapping_DB As DataTable = New DataTable()
12
    Dim _Mapping_DB As DataSet = New DataSet()
13
    Dim _Attribute_DB As DataTable = New DataTable()
14
    Dim _PIDSymbol_DB As DataTable = New DataTable()
15
    Dim _ResultModeling_DT As DataTable = New DataTable()
16
    Dim _AllLine_DT As New DataTable()
17
    Dim _AllSymbol_DT As New DataTable()
18
    Dim _ModelingLine_Dt As New DataTable()
19
    Dim _ModelingSymbol_Dt As New DataTable()
20
    Dim _Placement As New Placement
21
    Dim _DWG_X = 0.875 '0.695 '1 '
22
    Dim _DWG_Y = 0.617 '0.585 '0.8 '
23
    'Dim _DWG_X = 0.842 '0.695 '1 '
24
    'Dim _DWG_Y = 0.614 '0.585 '0.8 '
25
    Public _IMG_X = 0
26
    Public _IMG_Y = 0
27
    Dim _Unit As String
28
    'Drawing 전역변수
29
    Dim _objPIDADrawing As Object
30
    '현재선택한 폴더경로
31
    Dim _selectFolderPath As String
32
    Private _Main_trd As Thread
33
    Private _Opc_trd As Thread
34
    Private _CompleteConvert As Boolean = False
35
    Private _DrawingsList As List(Of Drawing)
36
    Private _iPipeLineNocnt As Integer
37
    Private _iPipecnt As Integer
38
    Private _iFittingcnt As Integer
39
    Private _iValvecnt As Integer
40
    Private _iInstrumentcnt As Integer
41
    Private _iEquipmentcnt As Integer
42
    Private _iNozzlecnt As Integer
43
    Private _iPipintOpccnt As Integer
44
    Private _allItem As Integer
45
    Private _Itemcnt As Integer
46
    Dim _Gembox As New CGembox()
47

    
48
    Dim PipeRunPoint As Dictionary(Of String, List(Of PointdInfo)) = New Dictionary(Of String, List(Of PointdInfo))
49

    
50
    Private Sub Main_Load(sender As Object, e As EventArgs) Handles MyBase.Load
51
        LoadDB()
52
    End Sub
53
    ''' <summary>
54
    ''' brief
55
    ''' </summary>
56

    
57
    Private Sub LoadDB()
58
        If My.Settings.DBPath <> "" And My.Settings.Plant_Hierarchy <> "" Then
59
            Dim sDBPath As String = My.Settings.DBPath
60

    
61
            _Gembox.isLoadFile(My.Settings.SymbolLibrary)
62
            _Mapping_DB = _Gembox.LoadFileFunc()
63
            _Attribute_DB = Load_DB(sDBPath, _DB_TABLE_ATTRIBUTE)
64
            _PIDSymbol_DB = Load_DB(sDBPath, _DB_TABLE_SYMBOLNAME)
65
            _ResultModeling_DT = ModelingResult_Dt()
66
        Else
67
            MessageBox.Show("설정값을 먼저 확인해주세요")
68
        End If
69
    End Sub
70

    
71
    Private Function GetDataFromMappingDB(ByVal sSymbolName As String, ByVal sColumn As String) As String
72
        Dim sValue As String = ""
73
        For Each oDt As DataTable In _Mapping_DB.Tables
74
            If oDt.Rows.Count > 0 Then
75
                Dim oSelectRow() As DataRow = oDt.Select("[img_symbolname] = '" + sSymbolName + "'")
76
                If oSelectRow.Length = 1 Then
77
                    If sColumn = _DB_COLUMN_MAPPING_SPPID_SYMBOLNAME Then
78
                        sValue = oSelectRow(0).Item("SYM FILE NAME").ToString()
79
                    ElseIf sColumn = _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH Then
80
                        sValue = "\" & oSelectRow(0).Item("SYMBOL PATH").ToString() & "\" & oSelectRow(0).Item("SYM FILE NAME").ToString()
81
                    ElseIf sColumn = _DB_COLUMN_MAPPING_SPPID_COMPTPYE Then
82
                        sValue = oSelectRow(0).Item("ITEM TYPE").ToString()
83
                    ElseIf sColumn = _DB_COLUMN_MAPPING_SPPID_CLASS Then
84
                        sValue = oSelectRow(0).Item("CLASS").ToString()
85
                    Else
86
                        sValue = oSelectRow(0).Item("SYMBOL PATH").ToString() & "\" & oSelectRow(0).Item("SYM FILE NAME").ToString()
87
                    End If
88
                End If
89
            End If
90
        Next
91
        Return sValue
92
    End Function
93

    
94
    Private Function GetAttributeMapping(ByVal sAttributeName As String, ByVal sColumn As String) As String
95
        Dim sSPPIDAttribute As String = ""
96
        If _Attribute_DB.Rows.Count > 0 Then
97
            Dim oSelectRow() As DataRow = _Attribute_DB.Select("[pid_attribute] = '" + sAttributeName + "'")
98
            If oSelectRow.Length = 1 Then
99
                sSPPIDAttribute = oSelectRow(0).Item(sColumn).ToString()
100
            End If
101
        End If
102
        Return sSPPIDAttribute
103
    End Function
104

    
105

    
106

    
107
    Private Function LoadSymbolInXml(ByVal sXmlPath As String) As Drawing
108
        Try
109
            ''  _TempSymbolDt = Symbol_Dt()
110
            Dim CDrawing As Drawing = New Drawing()
111
            '     Dim oDt As DataTable = LoadSymbol_DT()
112
            Dim oElement As XElement = XElement.Load(sXmlPath)
113
            If oElement IsNot Nothing Then
114
                CDrawing.DwgName = oElement.Element(_XML_DWGNAME).Value
115
                CDrawing.Size = oElement.Element(_XML_DWGSIZE).Value
116
                SplitLocation(CDrawing.Size, _IMG_X, _IMG_Y)
117
                '' 이것이 무엇인지 확인 필요
118
                'CDrawing.Unit = oElement.Element(_XML_UNIT).Value
119

    
120
                CDrawing.LINES = LoadLines(oElement)
121
                CDrawing.SYMBOLS = LoadSymbols(oElement)
122
                CDrawing.LINENUMBERS = LoadLineNumbers(oElement)
123
                CDrawing.TRIMLINES = LoadTrimLines(oElement)
124

    
125

    
126
                'Dim oLineno_list As New List(Of Line_no)
127
                'Dim oEqp_list As New List(Of Eqp_no)
128
                'Dim oTrim_Lineno_list As New List(Of Line_no)
129
                'oLineno_list = LoadLineNo(oElement, _XML_CATEGORY_LINENO)
130
                'For Each oEqpNo As Object In oElement.Elements(_XML_CATEGORY_EQUIPMENT)
131
                '    Dim CEqp_no As Eqp_no = New Eqp_no()
132
                '    Dim oSymbol_Dt As DataTable = Symbol_Dt()
133
                '    Dim oAttribute_Dt As DataTable = Attribute_Dt()
134
                '    Dim sUid As String = ""
135
                '    For Each oSymbol As Object In oEqpNo.Elements(_XML_CATEGORY_SYMBOL)
136
                '        Try
137
                '            Dim oAddrow As DataRow = oSymbol_Dt.NewRow()
138
                '            Dim oEleObj As XElement
139
                '            Dim sParentName As String
140
                '            Dim sName As String
141
                '            Dim sLocation As String
142
                '            Dim sSize As String
143
                '            Dim sAngle As String
144
                '            Dim sOriginalPoint As String = ""
145
                '            Dim sConnectionPoint As String = ""
146
                '            Dim sConnectionUids As String = ""
147
                '            Dim sConnArray As String()
148
                '            Dim sSizeArray As String()
149
                '            Dim sLocationArray As String()
150
                '            Dim sChild As String = ""
151
                '            Dim dCenterPos_x As Double = 0.0
152
                '            Dim dCenterPos_y As Double = 0.0
153
                '            Dim dDwgCenterPos_x As Double = 0.0
154
                '            Dim dDwgCenterPos_y As Double = 0.0
155
                '            Dim dConn1Pos_x As Double = 0.0
156
                '            Dim dConn1Pos_y As Double = 0.0
157
                '            Dim dConn2Pos_x As Double = 0.0
158
                '            Dim dConn2Pos_y As Double = 0.0
159
                '            Dim dConn3Pos_x As Double = 0.0
160
                '            Dim dConn3Pos_y As Double = 0.0
161
                '            Dim dConn4Pos_x As Double = 0.0
162
                '            Dim dConn4Pos_y As Double = 0.0
163
                '            Dim dDwg_Conn1Pos_x As Double = 0.0
164
                '            Dim dDwg_Conn1Pos_y As Double = 0.0
165
                '            Dim dDwg_Conn2Pos_x As Double = 0.0
166
                '            Dim dDwg_Conn2Pos_y As Double = 0.0
167
                '            Dim dDwg_Conn3Pos_x As Double = 0.0
168
                '            Dim dDwg_Conn3Pos_y As Double = 0.0
169
                '            Dim dDwg_Conn4Pos_x As Double = 0.0
170
                '            Dim dDwg_Conn4Pos_y As Double = 0.0
171
                '            Dim sOwnerUid As String = ""
172
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_UID)
173
                '            sUid = oEleObj.Value
174
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_PARENT)
175
                '            sParentName = oEleObj.Value
176
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_NAME)
177
                '            sName = oEleObj.Value
178
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_LOCATION)
179
                '            sLocation = oEleObj.Value
180
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_SIZE)
181
                '            sSize = oEleObj.Value
182
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_ANGLE)
183
                '            sAngle = oEleObj.Value
184
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_CONNECTIONPOINT)
185
                '            sConnectionPoint = oEleObj.Value
186
                '            oEleObj = oSymbol.Element(_XML_SYMBOL_CHILD)
187
                '            sChild = oEleObj.Value
188

    
189
                '            If sName = "NOZZLE" Then
190
                '                oEleObj = oSymbol.Element(_XML_SYMBOL_OWNER)
191
                '                sOwnerUid = oEleObj.Value
192
                '            End If
193
                '            Try
194
                '                oEleObj = oSymbol.Element(_XML_SYMBOL_ORIGINALPOINT)
195
                '                sOriginalPoint = oEleObj.Value
196
                '            Catch ex As Exception
197

    
198
                '            End Try
199
                '            oAddrow(_XML_SYMBOL_OWNER) = sOwnerUid
200
                '            oAddrow(_XML_SYMBOL_Conn1_Uid) = ""
201
                '            oAddrow(_XML_SYMBOL_Conn2_Uid) = ""
202
                '            oAddrow(_XML_SYMBOL_Conn3_Uid) = ""
203
                '            oAddrow(_XML_SYMBOL_Conn4_Uid) = ""
204
                '            ConvertPointBystring(sOriginalPoint, dCenterPos_x, dCenterPos_y)
205
                '            dDwgCenterPos_x = dCenterPos_x
206
                '            dDwgCenterPos_y = dCenterPos_y
207
                '            ConvertPointByImage(dDwgCenterPos_x, dDwgCenterPos_y, _IMG_X, _IMG_Y)
208
                '            oAddrow(_XML_SYMBOL_CENTERPOINT_X) = dCenterPos_x
209
                '            oAddrow(_XML_SYMBOL_CENTERPOINT_Y) = dCenterPos_y
210
                '            oAddrow(_XML_SYMBOL_DWG_CENTERPOINT_X) = dDwgCenterPos_x
211
                '            oAddrow(_XML_SYMBOL_DWG_CENTERPOINT_Y) = dDwgCenterPos_y
212
                '            sConnArray = sConnectionPoint.Split("/")
213
                '            sSizeArray = sSize.Split(",")
214
                '            sLocationArray = sLocation.Split(",")
215
                '            If sConnArray.Length > 4 Then
216
                '                MessageBox.Show(sConnArray.Length)
217
                '            End If
218
                '            For i = 0 To sConnArray.Length - 1
219
                '                If i = 0 Then
220
                '                    oAddrow(_XML_SYMBOL_Conn1_Point) = sConnArray(i)
221
                '                    ConvertPointBystring(sConnArray(i), dConn1Pos_x, dConn1Pos_y)
222
                '                    dDwg_Conn1Pos_x = dConn1Pos_x
223
                '                    dDwg_Conn1Pos_y = dConn1Pos_y
224
                '                    ConvertPointByImage(dDwg_Conn1Pos_x, dDwg_Conn1Pos_y, _IMG_X, _IMG_Y)
225
                '                    oAddrow(_XML_SYMBOL_CONN1_POINT_X) = dConn1Pos_x
226
                '                    oAddrow(_XML_SYMBOL_CONN1_POINT_Y) = dConn1Pos_y
227
                '                    oAddrow(_XML_SYMBOL_DWG_CONN1_POINT_X) = dDwg_Conn1Pos_x
228
                '                    oAddrow(_XML_SYMBOL_DWG_CONN1_POINT_Y) = dDwg_Conn1Pos_y
229
                '                ElseIf i = 1 Then
230
                '                    oAddrow(_XML_SYMBOL_Conn2_Point) = sConnArray(i)
231
                '                    ConvertPointBystring(sConnArray(i), dConn2Pos_x, dConn2Pos_y)
232
                '                    dDwg_Conn2Pos_x = dConn2Pos_x
233
                '                    dDwg_Conn2Pos_y = dConn2Pos_y
234
                '                    ConvertPointByImage(dDwg_Conn2Pos_x, dDwg_Conn2Pos_y, _IMG_X, _IMG_Y)
235
                '                    oAddrow(_XML_SYMBOL_CONN2_POINT_X) = dConn2Pos_x
236
                '                    oAddrow(_XML_SYMBOL_CONN2_POINT_Y) = dConn2Pos_y
237
                '                    oAddrow(_XML_SYMBOL_DWG_CONN2_POINT_X) = dDwg_Conn2Pos_x
238
                '                    oAddrow(_XML_SYMBOL_DWG_CONN2_POINT_Y) = dDwg_Conn2Pos_y
239
                '                ElseIf i = 2 Then
240
                '                    oAddrow(_XML_SYMBOL_Conn3_Point) = sConnArray(i)
241
                '                    ConvertPointBystring(sConnArray(i), dConn3Pos_x, dConn3Pos_y)
242
                '                    dDwg_Conn3Pos_x = dConn3Pos_x
243
                '                    dDwg_Conn3Pos_y = dConn3Pos_y
244
                '                    ConvertPointByImage(dDwg_Conn3Pos_x, dDwg_Conn3Pos_y, _IMG_X, _IMG_Y)
245
                '                    oAddrow(_XML_SYMBOL_CONN3_POINT_X) = dConn3Pos_x
246
                '                    oAddrow(_XML_SYMBOL_CONN3_POINT_Y) = dConn3Pos_y
247
                '                    oAddrow(_XML_SYMBOL_DWG_CONN3_POINT_X) = dDwg_Conn3Pos_x
248
                '                    oAddrow(_XML_SYMBOL_DWG_CONN3_POINT_Y) = dDwg_Conn3Pos_y
249
                '                ElseIf i = 3 Then
250
                '                    oAddrow(_XML_SYMBOL_Conn4_Point) = sConnArray(i)
251
                '                    ConvertPointBystring(sConnArray(i), dConn4Pos_x, dConn4Pos_y)
252
                '                    dDwg_Conn4Pos_x = dConn4Pos_x
253
                '                    dDwg_Conn4Pos_y = dConn4Pos_y
254
                '                    ConvertPointByImage(dDwg_Conn4Pos_x, dDwg_Conn4Pos_y, _IMG_X, _IMG_Y)
255
                '                    oAddrow(_XML_SYMBOL_CONN4_POINT_X) = dConn4Pos_x
256
                '                    oAddrow(_XML_SYMBOL_CONN4_POINT_Y) = dConn4Pos_y
257
                '                    oAddrow(_XML_SYMBOL_DWG_CONN4_POINT_X) = dDwg_Conn4Pos_x
258
                '                    oAddrow(_XML_SYMBOL_DWG_CONN4_POINT_Y) = dDwg_Conn4Pos_y
259
                '                End If
260
                '            Next
261

    
262
                '            Dim sXLength As String = ""
263
                '            Dim sYLength As String = ""
264
                '            Dim dMin_x As Double = 0
265
                '            Dim dMax_x As Double = 0
266
                '            Dim dMin_y As Double = 0
267
                '            Dim dMax_y As Double = 0
268

    
269
                '            For i = 0 To sSizeArray.Length - 1
270
                '                If i = 0 Then
271
                '                    sXLength = sSizeArray(i)
272
                '                ElseIf i = 1 Then
273
                '                    sYLength = sSizeArray(i)
274
                '                End If
275
                '            Next
276

    
277
                '            For i = 0 To sLocationArray.Length - 1
278
                '                If i = 0 Then
279
                '                    dMin_x = sLocationArray(i)
280
                '                    dMax_x = dMin_x + sXLength
281
                '                ElseIf i = 1 Then
282
                '                    'Y축은 반전
283
                '                    dMax_y = sLocationArray(i)
284
                '                    dMin_y = dMax_y + sYLength
285
                '                End If
286
                '            Next
287
                '            ConvertPointByImage(dMin_x, dMin_y, _IMG_X, _IMG_Y)
288
                '            ConvertPointByImage(dMax_x, dMax_y, _IMG_X, _IMG_Y)
289
                '            oAddrow(_XML_SYMBOL_MIN_X) = dMin_x
290
                '            oAddrow(_XML_SYMBOL_MAX_X) = dMax_x
291
                '            oAddrow(_XML_SYMBOL_MIN_Y) = dMin_y
292
                '            oAddrow(_XML_SYMBOL_MAX_Y) = dMax_y
293
                '            oAddrow(_XML_SYMBOL_UID) = sUid
294
                '            oAddrow(_XML_SYMBOL_NAME) = IO.Path.GetFileNameWithoutExtension(GetDataFromMappingDB(sParentName, _DB_COLUMN_MAPPING_SPPID_SYMBOLNAME))
295
                '            oAddrow(_XML_SYMBOL_LOCATION) = sLocation
296
                '            oAddrow(_XML_SYMBOL_SIZE) = sSize
297
                '            oAddrow(_XML_SYMBOL_ANGLE) = sAngle
298
                '            oAddrow(_XML_SYMBOL_SYSTEMPATH) = GetDataFromMappingDB(sParentName, _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH)
299
                '            oAddrow(_XML_SYMBOL_TYPE) = GetDataFromMappingDB(sParentName, _DB_COLUMN_MAPPING_SPPID_COMPTPYE)
300
                '            oAddrow(_XML_SYMBOL_CLASS) = GetDataFromMappingDB(sParentName, _DB_COLUMN_MAPPING_SPPID_CLASS)
301
                '            oAddrow(_XML_SYMBOL_ORIGINALPOINT) = sOriginalPoint
302
                '            oAddrow(_XML_SYMBOL_CONNECTIONPOINT) = sConnectionPoint
303
                '            oAddrow(_XML_SYMBOL_DRAWING_TF) = "FALSE"
304
                '            oAddrow(_XML_SYMBOL_CHILD) = sChild
305
                '            '   _AllSymbol_DT.Rows.Add(oAddrow)
306
                '            oSymbol_Dt.Rows.Add(oAddrow)
307
                '        Catch ex As Exception
308
                '        End Try
309
                '    Next
310
                '    CEqp_no.Uid = sUid
311
                '    CEqp_no.Dt_Equipment = oSymbol_Dt
312
                '    CEqp_no.Dt_Attribute = oAttribute_Dt
313
                '    oEqp_list.Add(CEqp_no)
314
                'Next
315
                'oTrim_Lineno_list = LoadLineNo(oElement, _XML_CATEGORY_TRIM_LINENO)
316
                'CDrawing.Line_nos = oLineno_list
317
                'CDrawing.Eqp_nos = oEqp_list
318
                'CDrawing.TrimLine_nos = oTrim_Lineno_list
319

    
320
            End If
321
            Return CDrawing
322
        Catch ex As Exception
323
            Return Nothing
324
        End Try
325

    
326
    End Function
327

    
328
    Private Function FindConnection(ByVal oLine_Dt As DataTable, ByVal oSymbol_Dt As DataTable, ByVal sUid As String, ByVal dPos_x As Double, ByVal dPos_y As Double) As String
329

    
330
        Dim sReturnUid As String = ""
331
        Try
332
            Dim oFindLineRow As DataRow() = oLine_Dt.Select(
333
            "[" & _XML_LINE_DWG_STARTPOINT_X & "] >= '" & dPos_x - 0.001 & "' And " &
334
            "[" & _XML_LINE_DWG_STARTPOINT_X & "] <= '" & dPos_x + 0.001 & "' And " &
335
            "[" & _XML_LINE_DWG_STARTPOINT_Y & "] >= '" & dPos_y - 0.001 & "' And " &
336
            "[" & _XML_LINE_DWG_STARTPOINT_Y & "] <= '" & dPos_y + 0.001 & "' And " &
337
            "[" & _XML_LINE_UID & "] <> '" & sUid & "' And " &
338
            "[" & _XML_LINE_Conn1_Uid & "] = ''")
339
            If oFindLineRow.Length = 0 Then
340
                oFindLineRow = oLine_Dt.Select(
341
                "[" & _XML_LINE_DWG_ENDPOINT_X & "] >= '" & dPos_x - 0.001 & "' And " &
342
                "[" & _XML_LINE_DWG_ENDPOINT_X & "] <= '" & dPos_x + 0.001 & "' And " &
343
                "[" & _XML_LINE_DWG_ENDPOINT_Y & "] >= '" & dPos_y - 0.001 & "' And " &
344
                "[" & _XML_LINE_DWG_ENDPOINT_Y & "] <= '" & dPos_y + 0.001 & "' And " &
345
                "[" & _XML_LINE_UID & "] <> '" & sUid & "' And " &
346
                "[" & _XML_LINE_Conn2_Uid & "] = ''")
347
                If oFindLineRow.Length = 0 Then
348
                    oFindLineRow = oSymbol_Dt.Select(
349
              "[" & _XML_SYMBOL_DWG_CONN1_POINT_X & "] >= '" & dPos_x - 0.001 & "' And " &
350
              "[" & _XML_SYMBOL_DWG_CONN1_POINT_X & "] <= '" & dPos_x + 0.001 & "' And " &
351
              "[" & _XML_SYMBOL_DWG_CONN1_POINT_Y & "] >= '" & dPos_y - 0.001 & "' And " &
352
              "[" & _XML_SYMBOL_DWG_CONN1_POINT_Y & "] <= '" & dPos_y + 0.001 & "' And " &
353
              "[" & _XML_SYMBOL_UID & "] <> '" & sUid & "' And " &
354
              "[" & _XML_SYMBOL_Conn1_Uid & "] = ''")
355
                    If oFindLineRow.Length = 0 Then
356
                        oFindLineRow = oSymbol_Dt.Select(
357
                   "[" & _XML_SYMBOL_DWG_CONN2_POINT_X & "] >= '" & dPos_x - 0.001 & "' And " &
358
                   "[" & _XML_SYMBOL_DWG_CONN2_POINT_X & "] <= '" & dPos_x + 0.001 & "' And " &
359
                   "[" & _XML_SYMBOL_DWG_CONN2_POINT_Y & "] >= '" & dPos_y - 0.001 & "' And " &
360
                   "[" & _XML_SYMBOL_DWG_CONN2_POINT_Y & "] <= '" & dPos_y + 0.001 & "' And " &
361
                   "[" & _XML_SYMBOL_UID & "] <> '" & sUid & "' And " &
362
                   "[" & _XML_SYMBOL_Conn2_Uid & "] = ''")
363
                        If oFindLineRow.Length = 0 Then
364
                        Else
365
                            oFindLineRow(0)(_XML_SYMBOL_Conn2_Uid) = sUid
366
                            sReturnUid = oFindLineRow(0)(_XML_SYMBOL_UID).ToString()
367
                        End If
368
                    Else
369
                        oFindLineRow(0)(_XML_SYMBOL_Conn1_Uid) = sUid
370
                        sReturnUid = oFindLineRow(0)(_XML_SYMBOL_UID).ToString()
371
                    End If
372
                Else
373
                    oFindLineRow(0)(_XML_LINE_Conn2_Uid) = sUid
374
                    sReturnUid = oFindLineRow(0)(_XML_LINE_UID).ToString()
375
                End If
376
            Else
377
                oFindLineRow(0)(_XML_LINE_Conn1_Uid) = sUid
378
                sReturnUid = oFindLineRow(0)(_XML_LINE_UID).ToString()
379
            End If
380
        Catch ex As Exception
381

    
382
        End Try
383

    
384
        Return sReturnUid
385
    End Function
386

    
387

    
388
    Private Function SetConnectionInfo(ByRef oLine_Dt As DataTable, ByRef oSymbol_Dt As DataTable)
389
        Try
390
            For Each oLineInfo In oLine_Dt.Rows
391
                Dim sLineUid As String = oLineInfo(_XML_LINE_UID).ToString()
392
                Dim dStartPos_x As Double = oLineInfo(_XML_LINE_DWG_STARTPOINT_X)
393
                Dim dStartPos_y As Double = oLineInfo(_XML_LINE_DWG_STARTPOINT_Y)
394
                Dim dEndPos_x As Double = oLineInfo(_XML_LINE_DWG_ENDPOINT_X)
395
                Dim dEndPos_y As Double = oLineInfo(_XML_LINE_DWG_ENDPOINT_Y)
396
                Dim sConn1Uid As String = ""
397
                Dim sConn2Uid As String = ""
398
                sConn1Uid = FindConnection(oLine_Dt, oSymbol_Dt, sLineUid, dStartPos_x, dStartPos_y)
399
                If sConn1Uid <> "" Then
400
                    oLineInfo(_XML_LINE_Conn1_Uid) = sConn1Uid
401
                End If
402
                sConn2Uid = FindConnection(oLine_Dt, oSymbol_Dt, sLineUid, dEndPos_x, dEndPos_y)
403
                If sConn2Uid <> "" Then
404
                    oLineInfo(_XML_LINE_Conn2_Uid) = sConn2Uid
405
                End If
406
            Next
407
            For Each oSymbolInfo In oSymbol_Dt.Rows
408
                Dim sSymbolUid As String = oSymbolInfo(_XML_SYMBOL_UID).ToString()
409
                Dim dConn1Pos_x As Double = oSymbolInfo(_XML_SYMBOL_DWG_CONN1_POINT_X)
410
                Dim dConn1Pos_y As Double = oSymbolInfo(_XML_SYMBOL_DWG_CONN1_POINT_Y)
411
                Dim sConn1Uid As String = ""
412
                Dim sConn2Uid As String = ""
413
                sConn1Uid = FindConnection(oLine_Dt, oSymbol_Dt, sSymbolUid, dConn1Pos_x, dConn1Pos_y)
414
                If sConn1Uid <> "" Then
415
                    oSymbolInfo(_XML_SYMBOL_Conn1_Uid) = sConn1Uid
416
                End If
417
                Try
418
                    Dim dConn2Pos_x As Double = oSymbolInfo(_XML_SYMBOL_DWG_CONN2_POINT_X)
419
                    Dim dConn2Pos_y As Double = oSymbolInfo(_XML_SYMBOL_DWG_CONN2_POINT_Y)
420
                    sConn2Uid = FindConnection(oLine_Dt, oSymbol_Dt, sSymbolUid, dConn2Pos_x, dConn2Pos_y)
421
                    If sConn2Uid <> "" Then
422
                        oSymbolInfo(_XML_SYMBOL_Conn2_Uid) = sConn2Uid
423
                    End If
424
                Catch ex As Exception
425
                End Try
426
            Next
427
        Catch ex As Exception
428
        End Try
429
    End Function
430

    
431
    Private Function GetFlowDirection(ByRef dStart_x As Double, ByRef dStart_y As Double, ByRef dEnd_x As Double, ByRef dEnd_y As Double, ByRef sDirection As String, ByRef sFlowdirection As String) As Boolean
432
        Dim bValidLine As Boolean = True
433
        If Math.Abs(dStart_x - dEnd_x) > Math.Abs(dStart_y - dEnd_y) Then
434
            If dStart_x > dEnd_x Then
435
                sDirection = "X"
436
                sFlowdirection = "Left_x"
437
                If Math.Abs(dStart_y - dEnd_y) < 5 Then
438
                    dEnd_y = dStart_y
439
                End If
440
            Else
441
                sDirection = "X"
442
                sFlowdirection = "Right_x"
443
                If Math.Abs(dStart_y - dEnd_y) < 5 Then
444
                    dEnd_y = dStart_y
445
                End If
446
            End If
447
            If Math.Abs(dStart_x - dEnd_x) <= 15 Then
448
                bValidLine = False
449
            End If
450
        Else
451
            If dStart_y > dEnd_y Then
452
                sDirection = "Y"
453
                sFlowdirection = "Down_y"
454
                If Math.Abs(dStart_x - dEnd_x) < 5 Then
455
                    dEnd_x = dStart_x
456
                End If
457

    
458
            Else
459
                sDirection = "Y"
460
                sFlowdirection = "Up_y"
461
                If Math.Abs(dStart_x - dEnd_x) < 5 Then
462
                    dEnd_x = dStart_x
463
                End If
464
            End If
465
            If Math.Abs(dStart_y - dEnd_y) <= 20 Then
466
                bValidLine = False
467
            End If
468
        End If
469
        Return bValidLine
470
    End Function
471

    
472
    Private Function LoadLines(ByVal oElement As XElement) As List(Of Line)
473
        Dim result As List(Of Line) = New List(Of Line)
474

    
475
        Dim lineInfos As XElement = oElement.Element(_XML_LINEINFOS)
476

    
477
        For Each oLine As XElement In lineInfos.Elements(_XML_LINEINFOS_LINE)
478
            Dim _line As Line = New Line()
479
            Try
480
                _line.UID = oLine.Element(_XML_LINEINFOS_LINE_UID).Value
481
                _line.STARTPOINT = oLine.Element(_XML_LINEINFOS_LINE_STARTPOINT).Value
482
                _line.ENDPOINT = oLine.Element(_XML_LINEINFOS_LINE_ENDPOINT).Value
483
                _line.TYPE = oLine.Element(_XML_LINEINFOS_LINE_TYPE).Value
484
                _line.AREA = oLine.Element(_XML_LINEINFOS_LINE_AREA).Value
485
                _line.CONNECTORS = GetConnector(oLine)
486
                result.Add(_line)
487
            Catch ex As Exception
488

    
489
            End Try
490
        Next
491

    
492
        Return result
493
    End Function
494

    
495
    Private Function LoadSymbols(ByVal oElement As XElement) As List(Of Symbol)
496
        Dim result As List(Of Symbol) = New List(Of Symbol)
497

    
498
        Dim symbols As XElement = oElement.Element(_XML_SYMBOLS)
499

    
500
        For Each oSymbol As XElement In symbols.Elements(_XML_SYMBOLS_SYMBOL)
501
            Dim _symbol As Symbol = New Symbol()
502
            Try
503
                _symbol.UID = oSymbol.Element(_XML_SYMBOLS_SYMBOL_UID).Value
504
                _symbol.NAME = oSymbol.Element(_XML_SYMBOLS_SYMBOL_NAME).Value
505
                _symbol.TYPE = oSymbol.Element(_XML_SYMBOLS_SYMBOL_TYPE).Value
506
                _symbol.ORIGINALPOINT = oSymbol.Element(_XML_SYMBOLS_SYMBOL_ORIGINALPOINT).Value
507
                _symbol.CONNECTORS = GetConnector(oSymbol)
508
                _symbol.LOCATION = oSymbol.Element(_XML_SYMBOLS_SYMBOL_LOCATION).Value
509
                _symbol.SIZE = oSymbol.Element(_XML_SYMBOLS_SYMBOL_SIZE).Value
510
                _symbol.ANGLE = oSymbol.Element(_XML_SYMBOLS_SYMBOL_ANGLE).Value
511
                _symbol.PARENT = oSymbol.Element(_XML_SYMBOLS_SYMBOL_PARENT).Value
512
                _symbol.CHILD = oSymbol.Element(_XML_SYMBOLS_SYMBOL_CHILD).Value
513
                _symbol.HASINSTRUMENTLABEL = oSymbol.Element(_XML_SYMBOLS_SYMBOL_HASINSTRUMENTLABEL).Value
514
                _symbol.AREA = oSymbol.Element(_XML_SYMBOLS_SYMBOL_AREA).Value
515
                _symbol.CURRENTPOINTMODEINDEX = oSymbol.Element(_XML_SYMBOLS_SYMBOL_CURRENTPOINTMODEINDEX).Value
516

    
517
                result.Add(_symbol)
518
            Catch ex As Exception
519

    
520
            End Try
521
        Next
522

    
523
        Return result
524
    End Function
525

    
526
    Private Function LoadLineNumbers(ByVal oElement As XElement) As List(Of LineNumber)
527
        Dim result As List(Of LineNumber) = New List(Of LineNumber)
528

    
529
        Dim lineNos As XElement = oElement.Element(_XML_LINENOS)
530

    
531
        For Each oLineNo As XElement In lineNos.Elements(_XML_LINENOS_LINENO)
532
            Dim _lineNo As LineNumber = New LineNumber()
533
            Try
534
                _lineNo.UID = oLineNo.Element(_XML_LINEINFOS_LINE_UID).Value
535

    
536
                _lineNo.SYMBOLRUNITEMS = GetSymbolRunItems(oLineNo)
537
                _lineNo.LINERUNITEMS = GetLineRunItems(oLineNo)
538

    
539
                result.Add(_lineNo)
540
            Catch ex As Exception
541

    
542
            End Try
543
        Next
544

    
545
        Return result
546
    End Function
547

    
548
    Private Function LoadTrimLines(ByVal oElement As XElement) As List(Of LineNumber)
549
        Dim result As List(Of LineNumber) = New List(Of LineNumber)
550

    
551
        Dim trimNos As XElement = oElement.Element(_XML_TRIMLINENOS)
552

    
553
        For Each oTrimLine As XElement In trimNos.Elements(_XML_TRIMLINENOS_TRIM_LINE_NO)
554
            Dim _lineNo As LineNumber = New LineNumber()
555
            Try
556
                _lineNo.UID = oTrimLine.Element(_XML_LINEINFOS_LINE_UID).Value
557

    
558
                _lineNo.SYMBOLRUNITEMS = GetSymbolRunItems(oTrimLine)
559
                _lineNo.LINERUNITEMS = GetLineRunItems(oTrimLine)
560

    
561
                result.Add(_lineNo)
562
            Catch ex As Exception
563

    
564
            End Try
565
        Next
566

    
567
        Return result
568
    End Function
569

    
570
    Private Function GetSymbolRunItems(ByVal oElement As XElement) As List(Of String)
571
        Dim result As List(Of String) = New List(Of String)
572

    
573
        Dim oRun As XElement = oElement.Element(_XML_RUN)
574

    
575
        For Each oSymbol As XElement In oRun.Elements(_XML_RUN_SYMBOL)
576
            result.Add(oSymbol.Element(_XML_SYMBOLS_SYMBOL_UID))
577
        Next
578

    
579
        Return result
580
    End Function
581

    
582
    Private Function GetLineRunItems(ByVal oElement As XElement) As List(Of String)
583
        Dim result As List(Of String) = New List(Of String)
584

    
585
        Dim oRun As XElement = oElement.Element(_XML_RUN)
586

    
587
        For Each oLine As XElement In oRun.Elements(_XML_RUN_LINE)
588
            result.Add(oLine.Element(_XML_LINEINFOS_LINE_UID))
589
        Next
590

    
591
        Return result
592
    End Function
593

    
594

    
595

    
596
    Private Function GetConnector(ByVal oElement As XElement) As List(Of Connector)
597
        Dim result As List(Of Connector) = New List(Of Connector)
598
        Dim oElementConnectors As XElement = oElement.Element(_XML_CONNECTORS)
599
        For Each oConnector As XElement In oElementConnectors.Elements(_XML_CONNECTORS_CONNECTOR)
600
            Dim _connector As Connector = New Connector()
601
            Try
602
                _connector.CONNECTEDITEM = oConnector.Element(_XML_CONNECTORS_CONNECTOR_CONNECTEDITEM).Value
603
                _connector.CONNECTPOINT = oConnector.Element(_XML_CONNECTORS_CONNECTOR_CONNECTPOINT).Value
604
                _connector.SCENECONNECTPOINT = oConnector.Element(_XML_CONNECTORS_CONNECTOR_SCENECONNECTPOINT).Value
605
                result.Add(_connector)
606
            Catch ex As Exception
607
            End Try
608
        Next
609

    
610
        Return result
611
    End Function
612

    
613
    Private Function LoadLineNo(ByVal oElement As XElement, ByVal sLineType As String) As List(Of Line_no)
614

    
615
        Dim oLineno_list As New List(Of Line_no)
616
        For Each oLineNo As Object In oElement.Elements(sLineType)
617
            Dim CLineNo As Line_no = New Line_no()
618
            Try
619
                CLineNo.Uid = oLineNo.Element(_XML_LINENO_UID).Value
620
                CLineNo.Text = oLineNo.Element(_XML_LINENO_TEXT).Value
621
                CLineNo.Location = oLineNo.Element(_XML_LINENO_LOCATION).Value
622
                CLineNo.Angle = oLineNo.Element(_XML_LINENO_ANGLE).Value
623
                CLineNo.SystemPath = "\Piping\Labels - Piping Segments\Kemya Line Number.sym" 'GetDataFromMappingDB(_XML_CATEGORY_LINENO, _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH)
624
            Catch ex As Exception
625
            End Try
626
            Dim oLine_Dt As DataTable = Line_Dt()
627
            Dim oSymbol_Dt As DataTable = Symbol_Dt()
628
            Dim oAttribute_Dt As DataTable = Attribute_Dt()
629
            Dim iRunCnt As Integer = 0
630
            For Each oRun As Object In oLineNo.Elements(_XML_CATEGORY_RUN)
631
                iRunCnt = iRunCnt + 1
632
                Dim sRunName As String = CLineNo.Text & "_" & iRunCnt
633
                For Each oMERGEDLine As Object In oRun.Elements(_XML_CATEGORY_MERGEDLINE)
634
                    For Each oLine As Object In oMERGEDLine.Elements(_XML_CATEGORY_LINE)
635
                        Try
636
                            Dim oAddrow As DataRow = oLine_Dt.NewRow()
637
                            Dim oEleObj As XElement
638
                            Dim sUid As String
639
                            Dim sStartpoint As String
640
                            Dim sEndpoint As String
641
                            Dim sType As String
642
                            Dim sConnectionUids As String = ""
643
                            Dim dStartPos_x As Double = 0.0
644
                            Dim dStartPos_y As Double = 0.0
645
                            Dim dEndPos_x As Double = 0.0
646
                            Dim dEndPos_y As Double = 0.0
647
                            Dim dDWG_StartPos_x As Double = 0.0
648
                            Dim dDWG_StartPos_y As Double = 0.0
649
                            Dim dDWG_EndPos_x As Double = 0.0
650
                            Dim dDWG_EndPos_y As Double = 0.0
651
                            oEleObj = oLine.Element(_XML_LINE_UID)
652
                            sUid = oEleObj.Value
653

    
654
                            If oLine_Dt.Select(_XML_LINE_UID & "='" & sUid & "'").Length = 0 Then
655
                                oEleObj = oLine.Element(_XML_LINE_STARTPOINT)
656
                                sStartpoint = oEleObj.Value
657
                                oEleObj = oLine.Element(_XML_LINE_ENDPOINT)
658
                                sEndpoint = oEleObj.Value
659
                                oEleObj = oLine.Element(_XML_LINE_TYPE)
660
                                sType = oEleObj.Value
661

    
662
                                oAddrow(_XML_LINE_Conn1_Uid) = ""
663
                                oAddrow(_XML_LINE_Conn2_Uid) = ""
664
                                oAddrow(_XML_LINE_UID) = sUid
665
                                oAddrow(_XML_LINE_RUNNAME) = sRunName
666
                                oAddrow(_XML_LINE_LINENOUID) = CLineNo.Uid
667
                                oAddrow(_XML_LINENO_TEXT) = CLineNo.Text
668
                                oAddrow(_XML_LINE_STARTPOINT) = sStartpoint
669
                                oAddrow(_XML_LINE_ENDPOINT) = sEndpoint
670
                                If sUid = "0bda520b-9c01-4dc1-9ddd-73adb5f7a871" Then
671
                                    MsgBox("")
672
                                End If
673
                                ConvertPointBystring(sStartpoint, dStartPos_x, dStartPos_y)
674
                                ConvertPointBystring(sEndpoint, dEndPos_x, dEndPos_y)
675
                                Dim sDirection As String = ""
676
                                Dim sFlowDirection As String = ""
677
                                Dim bValidLine As Boolean = GetFlowDirection(dStartPos_x, dStartPos_y, dEndPos_x, dEndPos_y, sDirection, sFlowDirection)
678
                                oAddrow(_XML_LINE_FlowDirection) = sFlowDirection
679
                                oAddrow(_XML_LINE_Direction) = sDirection
680
                                oAddrow(_XML_LINE_ValieLine) = bValidLine
681
                                dDWG_StartPos_x = dStartPos_x
682
                                dDWG_StartPos_y = dStartPos_y
683
                                ConvertPointByImage(dDWG_StartPos_x, dDWG_StartPos_y, _IMG_X, _IMG_Y)
684
                                dDWG_EndPos_x = dEndPos_x
685
                                dDWG_EndPos_y = dEndPos_y
686
                                ConvertPointByImage(dDWG_EndPos_x, dDWG_EndPos_y, _IMG_X, _IMG_Y)
687

    
688
                                oAddrow(_XML_LINE_STARTPOINT_X) = dStartPos_x
689
                                oAddrow(_XML_LINE_STARTPOINT_Y) = dStartPos_y
690
                                oAddrow(_XML_LINE_ENDPOINT_X) = dEndPos_x
691
                                oAddrow(_XML_LINE_ENDPOINT_Y) = dEndPos_y
692

    
693
                                oAddrow(_XML_LINE_DWG_STARTPOINT_X) = dDWG_StartPos_x
694
                                oAddrow(_XML_LINE_DWG_STARTPOINT_Y) = dDWG_StartPos_y
695
                                oAddrow(_XML_LINE_DWG_ENDPOINT_X) = dDWG_EndPos_x
696
                                oAddrow(_XML_LINE_DWG_ENDPOINT_Y) = dDWG_EndPos_y
697

    
698
                                oAddrow(_XML_LINE_SYSTEMPATH) = GetDataFromMappingDB(_XML_CATEGORY_LINE, _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH)
699
                                If oAddrow(_XML_LINE_SYSTEMPATH) = "" Then
700
                                    MessageBox.Show("")
701
                                End If
702
                                oAddrow(_XML_LINE_DRAWING_TF) = "FALSE"
703
                                oAddrow(_XML_LINE_TYPE) = sType
704
                                '  _AllLine_DT.Rows.Add(oAddrow)
705
                                oLine_Dt.Rows.Add(oAddrow)
706
                            Else
707
                            End If
708
                        Catch ex As Exception
709
                        End Try
710
                    Next
711
                Next
712

    
713
                For Each oSymbol As Object In oRun.Elements(_XML_CATEGORY_SYMBOL)
714
                    Try
715

    
716
                        Dim oAddrow As DataRow = oSymbol_Dt.NewRow()
717
                        Dim oEleObj As XElement
718
                        Dim sUid As String
719
                        Dim sName As String
720
                        Dim sLocation As String
721
                        Dim sSize As String
722
                        Dim sAngle As String
723
                        Dim sOriginalPoint As String = ""
724
                        Dim sConnectionPoint As String = ""
725
                        Dim sConnectionUids As String = ""
726
                        Dim sConnArray As String()
727
                        Dim sSizeArray As String()
728
                        Dim sLocationArray As String()
729
                        Dim sChild As String = ""
730
                        Dim dCenterPos_x As Double = 0.0
731
                        Dim dCenterPos_y As Double = 0.0
732
                        Dim dDwgCenterPos_x As Double = 0.0
733
                        Dim dDwgCenterPos_y As Double = 0.0
734

    
735
                        Dim dConn1Pos_x As Double = 0.0
736
                        Dim dConn1Pos_y As Double = 0.0
737
                        Dim dConn2Pos_x As Double = 0.0
738
                        Dim dConn2Pos_y As Double = 0.0
739
                        Dim dConn3Pos_x As Double = 0.0
740
                        Dim dConn3Pos_y As Double = 0.0
741
                        Dim dConn4Pos_x As Double = 0.0
742
                        Dim dConn4Pos_y As Double = 0.0
743

    
744
                        Dim dDwg_Conn1Pos_x As Double = 0.0
745
                        Dim dDwg_Conn1Pos_y As Double = 0.0
746
                        Dim dDwg_Conn2Pos_x As Double = 0.0
747
                        Dim dDwg_Conn2Pos_y As Double = 0.0
748
                        Dim dDwg_Conn3Pos_x As Double = 0.0
749
                        Dim dDwg_Conn3Pos_y As Double = 0.0
750
                        Dim dDwg_Conn4Pos_x As Double = 0.0
751
                        Dim dDwg_Conn4Pos_y As Double = 0.0
752

    
753
                        oEleObj = oSymbol.Element(_XML_SYMBOL_UID)
754
                        sUid = oEleObj.Value
755
                        oEleObj = oSymbol.Element(_XML_SYMBOL_PARENT)
756
                        sName = oEleObj.Value
757
                        oEleObj = oSymbol.Element(_XML_SYMBOL_LOCATION)
758
                        sLocation = oEleObj.Value
759
                        oEleObj = oSymbol.Element(_XML_SYMBOL_SIZE)
760
                        sSize = oEleObj.Value
761
                        oEleObj = oSymbol.Element(_XML_SYMBOL_ANGLE)
762
                        sAngle = oEleObj.Value
763
                        oEleObj = oSymbol.Element(_XML_SYMBOL_CONNECTIONPOINT)
764
                        sConnectionPoint = oEleObj.Value
765
                        oEleObj = oSymbol.Element(_XML_SYMBOL_CHILD)
766
                        sChild = oEleObj.Value
767
                        Try
768
                            oEleObj = oSymbol.Element(_XML_SYMBOL_ORIGINALPOINT)
769
                            sOriginalPoint = oEleObj.Value
770
                        Catch ex As Exception
771

    
772
                        End Try
773
                        'oEleObj = oSymbol.Element(_XML_LINE_CONNS)
774
                        'sConnectionUids = oEleObj.Value
775
                        'sConnArray = sConnectionUids.Split(",")
776
                        'If sConnArray.Length > 4 Then
777
                        '    MessageBox.Show(sConnArray.Length)
778
                        'End If
779
                        'For i = 0 To sConnArray.Length - 1
780
                        '    If i = 0 Then
781
                        '        oAddrow(_XML_SYMBOL_Conn1_Uid) = sConnArray(i)
782
                        '    ElseIf i = 1 Then
783
                        '        oAddrow(_XML_SYMBOL_Conn2_Uid) = sConnArray(i)
784
                        '    ElseIf i = 2 Then
785
                        '        oAddrow(_XML_SYMBOL_Conn3_Uid) = sConnArray(i)
786
                        '    ElseIf i = 3 Then
787
                        '        oAddrow(_XML_SYMBOL_Conn4_Uid) = sConnArray(i)
788
                        '    End If
789
                        'Next
790
                        oAddrow(_XML_SYMBOL_Conn1_Uid) = ""
791
                        oAddrow(_XML_SYMBOL_Conn2_Uid) = ""
792
                        oAddrow(_XML_SYMBOL_Conn3_Uid) = ""
793
                        oAddrow(_XML_SYMBOL_Conn4_Uid) = ""
794
                        ConvertPointBystring(sOriginalPoint, dCenterPos_x, dCenterPos_y)
795
                        dDwgCenterPos_x = dCenterPos_x
796
                        dDwgCenterPos_y = dCenterPos_y
797
                        ConvertPointByImage(dDwgCenterPos_x, dDwgCenterPos_y, _IMG_X, _IMG_Y)
798

    
799
                        oAddrow(_XML_SYMBOL_CENTERPOINT_X) = dCenterPos_x
800
                        oAddrow(_XML_SYMBOL_CENTERPOINT_Y) = dCenterPos_y
801
                        oAddrow(_XML_SYMBOL_DWG_CENTERPOINT_X) = dDwgCenterPos_x
802
                        oAddrow(_XML_SYMBOL_DWG_CENTERPOINT_Y) = dDwgCenterPos_y
803
                        sConnArray = sConnectionPoint.Split("/")
804
                        sSizeArray = sSize.Split(",")
805
                        sLocationArray = sLocation.Split(",")
806
                        If sConnArray.Length > 4 Then
807
                            MessageBox.Show(sConnArray.Length)
808
                        End If
809
                        For i = 0 To sConnArray.Length - 1
810
                            If i = 0 Then
811
                                oAddrow(_XML_SYMBOL_Conn1_Point) = sConnArray(i)
812
                                ConvertPointBystring(sConnArray(i), dConn1Pos_x, dConn1Pos_y)
813
                                dDwg_Conn1Pos_x = dConn1Pos_x
814
                                dDwg_Conn1Pos_y = dConn1Pos_y
815
                                ConvertPointByImage(dDwg_Conn1Pos_x, dDwg_Conn1Pos_y, _IMG_X, _IMG_Y)
816

    
817
                                oAddrow(_XML_SYMBOL_CONN1_POINT_X) = dConn1Pos_x
818
                                oAddrow(_XML_SYMBOL_CONN1_POINT_Y) = dConn1Pos_y
819
                                oAddrow(_XML_SYMBOL_DWG_CONN1_POINT_X) = dDwg_Conn1Pos_x
820
                                oAddrow(_XML_SYMBOL_DWG_CONN1_POINT_Y) = dDwg_Conn1Pos_y
821
                            ElseIf i = 1 Then
822
                                oAddrow(_XML_SYMBOL_Conn2_Point) = sConnArray(i)
823
                                ConvertPointBystring(sConnArray(i), dConn2Pos_x, dConn2Pos_y)
824
                                dDwg_Conn2Pos_x = dConn2Pos_x
825
                                dDwg_Conn2Pos_y = dConn2Pos_y
826
                                ConvertPointByImage(dDwg_Conn2Pos_x, dDwg_Conn2Pos_y, _IMG_X, _IMG_Y)
827
                                oAddrow(_XML_SYMBOL_CONN2_POINT_X) = dConn2Pos_x
828
                                oAddrow(_XML_SYMBOL_CONN2_POINT_Y) = dConn2Pos_y
829
                                oAddrow(_XML_SYMBOL_DWG_CONN2_POINT_X) = dDwg_Conn2Pos_x
830
                                oAddrow(_XML_SYMBOL_DWG_CONN2_POINT_Y) = dDwg_Conn2Pos_y
831
                            ElseIf i = 2 Then
832
                                oAddrow(_XML_SYMBOL_Conn3_Point) = sConnArray(i)
833
                                ConvertPointBystring(sConnArray(i), dConn3Pos_x, dConn3Pos_y)
834
                                dDwg_Conn3Pos_x = dConn3Pos_x
835
                                dDwg_Conn3Pos_y = dConn3Pos_y
836
                                ConvertPointByImage(dDwg_Conn3Pos_x, dDwg_Conn3Pos_y, _IMG_X, _IMG_Y)
837
                                oAddrow(_XML_SYMBOL_CONN3_POINT_X) = dConn3Pos_x
838
                                oAddrow(_XML_SYMBOL_CONN3_POINT_Y) = dConn3Pos_y
839
                                oAddrow(_XML_SYMBOL_DWG_CONN3_POINT_X) = dDwg_Conn3Pos_x
840
                                oAddrow(_XML_SYMBOL_DWG_CONN3_POINT_Y) = dDwg_Conn3Pos_y
841
                            ElseIf i = 3 Then
842
                                oAddrow(_XML_SYMBOL_Conn4_Point) = sConnArray(i)
843
                                ConvertPointBystring(sConnArray(i), dConn4Pos_x, dConn4Pos_y)
844
                                dDwg_Conn4Pos_x = dConn4Pos_x
845
                                dDwg_Conn4Pos_y = dConn4Pos_y
846
                                ConvertPointByImage(dDwg_Conn4Pos_x, dDwg_Conn4Pos_y, _IMG_X, _IMG_Y)
847
                                oAddrow(_XML_SYMBOL_CONN4_POINT_X) = dConn4Pos_x
848
                                oAddrow(_XML_SYMBOL_CONN4_POINT_Y) = dConn4Pos_y
849
                                oAddrow(_XML_SYMBOL_DWG_CONN4_POINT_X) = dDwg_Conn4Pos_x
850
                                oAddrow(_XML_SYMBOL_DWG_CONN4_POINT_Y) = dDwg_Conn4Pos_y
851
                            End If
852
                        Next
853

    
854
                        Dim sXLength As String = ""
855
                        Dim sYLength As String = ""
856

    
857
                        Dim dMin_x As Double = 0
858
                        Dim dMax_x As Double = 0
859
                        Dim dMin_y As Double = 0
860
                        Dim dMax_y As Double = 0
861

    
862
                        For i = 0 To sSizeArray.Length - 1
863
                            If i = 0 Then
864
                                sXLength = sSizeArray(i)
865
                            ElseIf i = 1 Then
866
                                sYLength = sSizeArray(i)
867
                            End If
868
                        Next
869

    
870
                        For i = 0 To sLocationArray.Length - 1
871
                            If i = 0 Then
872
                                dMin_x = sLocationArray(i)
873
                                dMax_x = dMin_x + sXLength
874
                            ElseIf i = 1 Then
875
                                'Y축은 반전
876
                                dMax_y = sLocationArray(i)
877
                                dMin_y = dMax_y + sYLength
878
                            End If
879
                        Next
880
                        ConvertPointByImage(dMin_x, dMin_y, _IMG_X, _IMG_Y)
881
                        ConvertPointByImage(dMax_x, dMax_y, _IMG_X, _IMG_Y)
882

    
883
                        oAddrow(_XML_SYMBOL_MIN_X) = dMin_x
884
                        oAddrow(_XML_SYMBOL_MAX_X) = dMax_x
885
                        oAddrow(_XML_SYMBOL_MIN_Y) = dMin_y
886
                        oAddrow(_XML_SYMBOL_MAX_Y) = dMax_y
887
                        oAddrow(_XML_SYMBOL_UID) = sUid
888
                        oAddrow(_XML_LINE_LINENOUID) = CLineNo.Uid
889
                        oAddrow(_XML_SYMBOL_RUNNAME) = sRunName
890
                        oAddrow(_XML_LINENO_TEXT) = CLineNo.Text
891
                        oAddrow(_XML_SYMBOL_NAME) = IO.Path.GetFileNameWithoutExtension(GetDataFromMappingDB(sName, _DB_COLUMN_MAPPING_SPPID_SYMBOLNAME))
892
                        oAddrow(_XML_SYMBOL_LOCATION) = sLocation
893
                        oAddrow(_XML_SYMBOL_SIZE) = sSize
894
                        oAddrow(_XML_SYMBOL_ANGLE) = sAngle
895
                        oAddrow(_XML_SYMBOL_SYSTEMPATH) = GetDataFromMappingDB(sName, _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH)
896
                        oAddrow(_XML_SYMBOL_TYPE) = GetDataFromMappingDB(sName, _DB_COLUMN_MAPPING_SPPID_COMPTPYE)
897
                        oAddrow(_XML_SYMBOL_CLASS) = GetDataFromMappingDB(sName, _DB_COLUMN_MAPPING_SPPID_CLASS)
898
                        oAddrow(_XML_SYMBOL_ORIGINALPOINT) = sOriginalPoint
899

    
900
                        oAddrow(_XML_SYMBOL_CONNECTIONPOINT) = sConnectionPoint
901
                        oAddrow(_XML_SYMBOL_DRAWING_TF) = "FALSE"
902
                        oAddrow(_XML_SYMBOL_CHILD) = sChild
903
                        '   _AllSymbol_DT.Rows.Add(oAddrow)
904
                        oSymbol_Dt.Rows.Add(oAddrow)
905
                    Catch ex As Exception
906
                    End Try
907
                Next
908

    
909
                For Each oAtrribute As Object In oRun.Elements(_XML_CATEGORY_ATTRIBUTE)
910
                    Try
911
                        Dim oAddrow As DataRow = oAttribute_Dt.NewRow()
912
                        Dim oEleObj As XElement
913
                        Dim sUid As String
914
                        Dim sName As String
915
                        Dim sValue As String
916
                        oEleObj = oAtrribute.Element(_XML_ATTRIBUTE_UID)
917
                        sUid = oEleObj.Value
918
                        oEleObj = oAtrribute.Element(_XML_ATTRIBUTE_NAME)
919
                        sName = oEleObj.Value
920
                        oEleObj = oAtrribute.Element(_XML_ATTRIBUTE_VALUE)
921
                        sValue = oEleObj.Value
922
                        oAddrow(_XML_ATTRIBUTE_UID) = sUid
923
                        oAddrow(_XML_ATTRIBUTE_NAME) = sName
924
                        oAddrow(_XML_ATTRIBUTE_VALUE) = sValue
925
                        oAttribute_Dt.Rows.Add(oAddrow)
926
                    Catch ex As Exception
927
                    End Try
928
                Next
929
            Next
930
            'Line No Attribute
931
            For Each oAtrribute As Object In oLineNo.Elements(_XML_CATEGORY_ATTRIBUTE)
932
                Try
933
                    Dim oAddrow As DataRow = oAttribute_Dt.NewRow()
934
                    Dim oEleObj As XElement
935
                    Dim sUid As String = ""
936
                    Dim sName As String
937
                    Dim sValue As String
938

    
939
                    oEleObj = oAtrribute.Element(_XML_ATTRIBUTE_UID)
940
                    sUid = oEleObj.Value
941
                    oEleObj = oAtrribute.Element(_XML_ATTRIBUTE_NAME)
942
                    sName = oEleObj.Value
943
                    oEleObj = oAtrribute.Element(_XML_ATTRIBUTE_VALUE)
944
                    sValue = oEleObj.Value
945
                    oAddrow(_XML_ATTRIBUTE_UID) = sUid
946
                    oAddrow(_XML_ATTRIBUTE_NAME) = sName
947
                    oAddrow(_XML_ATTRIBUTE_VALUE) = sValue
948
                    oAttribute_Dt.Rows.Add(oAddrow)
949
                Catch ex As Exception
950
                End Try
951
            Next
952
            SetConnectionInfo(oLine_Dt, oSymbol_Dt)
953
            _AllLine_DT.Merge(oLine_Dt)
954
            _AllSymbol_DT.Merge(oSymbol_Dt)
955
            CLineNo.Dt_Line = oLine_Dt
956
            CLineNo.Dt_Symbol = oSymbol_Dt
957
            CLineNo.Dt_Attribute = oAttribute_Dt
958
            oLineno_list.Add(CLineNo)
959
        Next
960
        Return oLineno_list
961
    End Function
962

    
963
    Public Sub ConvertPointByImage(ByRef dX As Double, ByRef dY As Double, ByVal dDwgX As Double, ByVal dDwgY As Double)
964

    
965
        Dim calcx As Double = 0
966
        Dim calcy As Double = 0
967
        calcx = (dX * _DWG_X) / dDwgX 'Math.Round((dX * _DWG_X) / dDwgX, 2)
968
        'calcx = Math.Round(calcx, 4, MidpointRounding.)
969
        calcx = Math.Truncate(calcx * 1000) / 1000
970
        calcy = _DWG_Y - ((dY * _DWG_Y) / dDwgY) '_DWG_Y - Math.Round((dY * _DWG_Y) / dDwgY, 2)
971
        '   calcy = Math.Round(calcy, 4)
972
        calcy = Math.Truncate(calcy * 1000) / 1000
973
        dX = calcx
974
        dY = calcy
975
    End Sub
976
    '@brief Convert To SPPID
977
    '@author : Gyusu Park
978
    '@date : 2018-04-10
979
    '@history:
980
    Private Sub SplitLocation(ByVal sLocation As String, ByRef dX As Double, ByRef dY As Double)
981

    
982
        Dim opointstr As String() = Split(sLocation, ",")
983
        If (opointstr.Length > 1) Then
984
            If IsNumeric(opointstr(0)) And IsNumeric(opointstr(1)) Then
985
                dX = opointstr(0)
986
                dY = opointstr(1)
987
            End If
988
        End If
989

    
990
    End Sub
991

    
992
    Private Function Load_DB(ByVal sDBPath As String, ByVal sTableName As String) As DataTable
993

    
994
        Try
995
            Dim oDt As New DataTable
996
            Dim sConnectionstring As String = "Data Source=" & sDBPath & ";Version=3;Synchronous=Off;UTF8Encoding=True;"
997
            Dim conn As SQLiteConnection = New SQLiteConnection(sConnectionstring)
998
            conn.Open()
999
            Dim sQuery As String = "Select * from " & sTableName
1000
            Dim cmd As SQLiteCommand = conn.CreateCommand()
1001
            Dim adapter As SQLiteDataAdapter = New SQLiteDataAdapter(sQuery, conn)
1002
            Dim oDataSet As DataSet = New DataSet()
1003
            adapter.Fill(oDataSet)
1004
            oDt = oDataSet.Tables(0)
1005
            Return oDt
1006
        Catch ex As Exception
1007
            Return Nothing
1008
        End Try
1009
    End Function
1010

    
1011
    Private Function LoadAllDrawing() As DataTable
1012
        SetListBoxItems(ListBox_Result, "도면정보 로드중....")
1013
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "도면정보 로드중....")
1014
        Dim oDt As DataTable = Drawing_Dt()
1015
        Dim sHierarchy As String = My.Settings.Plant_Hierarchy
1016
        Dim files() As String
1017
        files = Directory.GetFiles(sHierarchy, "*.pid", SearchOption.AllDirectories)
1018
        For Each FileName As String In files
1019
            Dim sName As String = FileName
1020
            Dim oAddRow As DataRow = oDt.NewRow()
1021
            oAddRow("Name") = Path.GetFileNameWithoutExtension(sName)
1022
            oAddRow("Path") = FileName
1023
            oDt.Rows.Add(oAddRow)
1024
        Next
1025
        Return oDt
1026
    End Function
1027

    
1028
    Dim _XMLList As ListView = New ListView()
1029

    
1030
    Private Function CheckOpenDrawing() As Boolean
1031
        Try
1032

    
1033
            Dim lobjDatasource As Object
1034
            _Placement = CreateObject("Plaice.Placement", "")
1035
            lobjDatasource = _Placement.PIDDataSource
1036
            Return True
1037
        Catch ex As Exception
1038
            Return False
1039
        End Try
1040

    
1041
    End Function
1042

    
1043

    
1044
    Private Sub Btn_Convert_Click(sender As Object, e As EventArgs) Handles Btn_Convert.Click
1045
        Main_Tab.SelectedIndex = 1
1046
        ListBox_Result.Items.Clear()
1047
        Me.ProgressBar_Status.Visible = True
1048
        ProgressBar_Status.Maximum = 100
1049
        ProgressBar_Status.Value = 0
1050
        InitItemCount()
1051
        _Main_trd = New Thread(AddressOf ThreadConvert)
1052
        _Main_trd.IsBackground = True
1053
        _Main_trd.Start()
1054
        FineOPCForm()
1055
    End Sub
1056

    
1057
    Private Sub FineOPCForm()
1058
        _Opc_trd = New Thread(AddressOf ThreadOPCRemove)
1059
        _Opc_trd.IsBackground = True
1060
        _Opc_trd.Start()
1061
    End Sub
1062

    
1063

    
1064
    Dim _objPIDAutoApp As Object
1065

    
1066
    Private Function OpenSPPID(ByVal oDwg_Dt As DataTable, ByVal sDwgName As String) As Boolean
1067
        Dim bCheckOpen As Boolean = False
1068
        '   Dim sDwgName As String = Path.GetFileNameWithoutExtension(oDwgPath)
1069
        SetListBoxItems(ListBox_Result, sDwgName & " 도면 Open....")
1070
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, sDwgName & " 도면 Open....")
1071
        _objPIDAutoApp = CreateObject("PIDAutomation.Application")
1072

    
1073
        Dim sPath As String = OpenDrawing(oDwg_Dt, sDwgName)
1074
        If sPath <> "" Then
1075
            Process.Start(sPath)
1076
        Else
1077
            Return bCheckOpen
1078
        End If
1079

    
1080
        Dim bCheckOpenDrawing As Boolean = False
1081
        While (True)
1082
            bCheckOpenDrawing = CheckOpenDrawing()
1083
            If bCheckOpenDrawing = True Then
1084
                bCheckOpen = True
1085
                Exit While
1086
            Else
1087
                Thread.Sleep(2000)
1088
            End If
1089
        End While
1090

    
1091

    
1092
        Return bCheckOpen
1093
    End Function
1094

    
1095
    Private Function GetDrawing(ByVal sDwgName As String) As Drawing
1096
        For Each CDrawing In _DrawingsList
1097
            If CDrawing.DwgName.ToUpper() = sDwgName.ToUpper() Then
1098
                Return CDrawing
1099
            End If
1100
        Next
1101
        Return Nothing
1102
    End Function
1103

    
1104
    Private Function GetLineNo(ByVal CDrawing As Drawing, ByVal sLineNoUid As String) As Line_no
1105
        For Each CLineNo In CDrawing.Line_nos
1106
            If CLineNo.Uid = sLineNoUid Then
1107
                Return CLineNo
1108
            End If
1109
        Next
1110
        Return Nothing
1111
    End Function
1112

    
1113
    Private Function GetTrimLineNo(ByVal CDrawing As Drawing, ByVal sLineNoUid As String) As Line_no
1114
        For Each CLineNo In CDrawing.TrimLine_nos
1115
            If CLineNo.Uid = sLineNoUid Then
1116
                Return CLineNo
1117
            End If
1118
        Next
1119
        Return Nothing
1120
    End Function
1121

    
1122

    
1123

    
1124
    Private Function GetPipeFromConnection(ByVal CDrawing As Drawing, ByVal sSymbolUid As String, ByRef sConnTypeNo As String) As DataTable
1125
        For Each CLineNo In CDrawing.Line_nos
1126
            Dim odt As DataTable = CLineNo.Dt_Line
1127
            If odt.Rows.Count > 0 Then
1128
                If odt.Rows(0)(_XML_LINE_Conn1_Uid).ToString = sSymbolUid Then
1129
                    sConnTypeNo = "1"
1130
                    Return odt
1131
                ElseIf odt.Rows(0)(_XML_LINE_Conn2_Uid).ToString() = sSymbolUid Then
1132
                    sConnTypeNo = "2"
1133
                    Return odt
1134
                End If
1135
            End If
1136
        Next
1137
        Return New DataTable
1138
    End Function
1139

    
1140
    Private Function GetSymbolFromConnection(ByVal CDrawing As Drawing, ByVal sSymbolUid As String, ByRef sConnTypeNo As String) As DataTable
1141
        For Each CLineNo In CDrawing.Line_nos
1142
            Dim odt As DataTable = CLineNo.Dt_Symbol
1143
            If odt.Rows.Count > 0 Then
1144
                If odt.Rows(0)(_XML_SYMBOL_Conn1_Uid).ToString = sSymbolUid Then
1145
                    sConnTypeNo = "1"
1146
                    Return odt
1147
                ElseIf odt.Rows(0)(_XML_SYMBOL_Conn2_Uid).ToString() = sSymbolUid Then
1148
                    sConnTypeNo = "2"
1149
                    Return odt
1150
                ElseIf odt.Rows(0)(_XML_SYMBOL_Conn3_Uid).ToString() = sSymbolUid Then
1151
                    sConnTypeNo = "3"
1152
                    Return odt
1153
                ElseIf odt.Rows(0)(_XML_SYMBOL_Conn4_Uid).ToString() = sSymbolUid Then
1154
                    sConnTypeNo = "4"
1155
                    Return odt
1156
                End If
1157
            End If
1158
        Next
1159
        Return New DataTable
1160
    End Function
1161

    
1162
    Private Function GetEqpNo(ByVal CDrawing As Drawing, ByVal sEqpUid As String) As Eqp_no
1163
        For Each CEqpNo In CDrawing.Eqp_nos
1164
            If CEqpNo.Uid = sEqpUid Then
1165
                Return CEqpNo
1166
            End If
1167
        Next
1168
        Return Nothing
1169
    End Function
1170
    Public Function ConvertPointBystring(ByVal sPoint As String, ByRef dX As Double, ByRef dY As Double) As Boolean
1171
        Try
1172
            Dim opointstr As String() = Split(sPoint, ",")
1173
            If (opointstr.Length > 1) Then
1174
                If IsNumeric(opointstr(0)) And IsNumeric(opointstr(1)) Then
1175
                    dX = opointstr(0)
1176
                    dY = opointstr(1)
1177

    
1178
                Else
1179
                    dX = 0
1180
                    dY = 0
1181
                    Return False
1182
                End If
1183
            End If
1184
            Return True
1185
        Catch ex As Exception
1186
            Return False
1187
        End Try
1188
    End Function
1189

    
1190

    
1191
    Dim _DrawLine_Dt As DataTable = DrawLind_Dt()
1192

    
1193

    
1194
    Private Sub AddModelingLine(ByVal dStart_x As Double, ByVal dStart_y As Double, ByVal dEnd_x As Double, ByVal dEnd_y As Double, ByVal sUid As String)
1195
        Dim oAddRow = _DrawLine_Dt.NewRow()
1196
        oAddRow(_XML_LINE_UID) = sUid
1197
        oAddRow(_XML_LINE_STARTPOINT_X) = dStart_x
1198
        oAddRow(_XML_LINE_STARTPOINT_Y) = dStart_y
1199
        oAddRow(_XML_LINE_ENDPOINT_X) = dEnd_x
1200
        oAddRow(_XML_LINE_ENDPOINT_Y) = dEnd_y
1201
        _DrawLine_Dt.Rows.Add(oAddRow)
1202
    End Sub
1203

    
1204
    Private Sub PlaceEquipment(ByVal sUid As String, ByVal oSymbol_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal sEqpName As String)
1205
        Try
1206
            Dim oSymbolRow() As DataRow = oSymbol_Dt.Select(_XML_SYMBOL_UID & " = '" + sUid + "'")
1207
            Dim oAttributeRow() As DataRow
1208
            If oAttribute_Dt.Rows.Count > 0 Then
1209
                oAttributeRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sUid + "'")
1210
            End If
1211
            If oSymbolRow.Length > 0 Then
1212
                Dim oDatasource As Object = _Placement.PIDDataSource
1213
                Dim sSymbolName As String = oSymbolRow(0)(_XML_SYMBOL_NAME).ToString()
1214
                Dim sSymbolCompType As String = oSymbolRow(0)(_XML_SYMBOL_TYPE).ToString()
1215
                Dim sSystemPath As String = oSymbolRow(0)(_XML_SYMBOL_SYSTEMPATH).ToString()
1216
                Dim sClass As String = oSymbolRow(0)(_XML_SYMBOL_CLASS).ToString()
1217
                Dim sLocation As String = oSymbolRow(0)(_XML_SYMBOL_LOCATION).ToString()
1218
                Dim sOriginalPoint As String = oSymbolRow(0)(_XML_SYMBOL_ORIGINALPOINT).ToString()
1219
                Dim dAngle As Double = 0.0
1220
                If IsNumeric(oSymbolRow(0)(_XML_SYMBOL_ANGLE).ToString()) Then
1221
                    dAngle = Double.Parse(oSymbolRow(0)(_XML_SYMBOL_ANGLE).ToString())
1222
                End If
1223
                Dim dLocationX As Double = 0.0
1224
                Dim dLocationY As Double = 0.0
1225
                ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY)
1226
                Dim dX As Double = dLocationX
1227
                Dim dY As Double = dLocationY
1228
                ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
1229
                Dim oReturnSymbol As LMSymbol = Nothing
1230
                If sSymbolCompType.ToUpper() = "NOZZLE" Then
1231
                    Dim sOwnerUid As String = oSymbolRow(0)(_XML_SYMBOL_OWNER).ToString()
1232
                    Dim oFineRow() As DataRow = _ModelingSymbol_Dt.Select("Uid = '" & sOwnerUid & "'")
1233
                    If oFineRow.Length = 1 Then
1234
                        Dim sEqpModelID As String = oFineRow(0)(_XML_SYMBOL_SPID).ToString()
1235

    
1236
                        Dim objVessel As LMVessel
1237
                        objVessel = _Placement.PIDDataSource.GetVessel(sEqpModelID)
1238
                        Dim oVesselLocation As LMLocations = objVessel.Locations
1239
                        Dim oEqpSymbol As LMSymbol = _Placement.PIDDataSource.GetSymbol(objVessel.Representations.Nth(1).Id)
1240

    
1241
                        Dim objNozzle As LMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY,
1242
                                                    TargetItem:=oEqpSymbol.AsLMRepresentation)
1243
                        SetListBoxItems(ListBox_Result, "Place Nozzle.." & sUid & " (" & dLocationX & "," & dLocationY & ")..." & _iEquipmentcnt & " count ")
1244
                        _iNozzlecnt = _iNozzlecnt + 1
1245
                        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Nozzle : " & sUid)
1246
                        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Nozzle Name : " & sSymbolName)
1247
                        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
1248
                        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "OriginalPoint : " & dLocationX & "," & dLocationY)
1249
                        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Nozzle Count : " & _iNozzlecnt)
1250
                    End If
1251
                Else
1252
                    oReturnSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
1253
                    SetListBoxItems(ListBox_Result, "Place Equipment.." & sUid & " (" & dLocationX & "," & dLocationY & ")..." & _iEquipmentcnt & " count ")
1254
                    _iEquipmentcnt = _iEquipmentcnt + 1
1255
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Equipment : " & sUid)
1256
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Equipment Name : " & sSymbolName)
1257
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
1258
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "OriginalPoint : " & dLocationX & "," & dLocationY)
1259
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Equipment Count : " & _iEquipmentcnt)
1260
                End If
1261
                '모델링 된 Symbol 데이터 테이블 저장
1262
                Dim oAddRow As DataRow = _ModelingSymbol_Dt.NewRow
1263
                oAddRow(_XML_SYMBOL_UID) = sUid
1264
                oAddRow(_XML_SYMBOL_SPID) = oReturnSymbol.ModelItemID
1265
                oAddRow(_XML_SYMBOL_LMSYMBOL) = oReturnSymbol
1266
                oAddRow(_XML_SYMBOL_DRAWING_TF) = "TRUE"
1267
                oAddRow(_XML_SYMBOL_CENTERPOINT_X) = dLocationX
1268
                oAddRow(_XML_SYMBOL_CENTERPOINT_Y) = dLocationY
1269
                _ModelingSymbol_Dt.Rows.Add(oAddRow)
1270
            End If
1271
        Catch ex As Exception
1272
        End Try
1273
    End Sub
1274

    
1275
    Private Function PlacePipingOPC(ByVal sUid As String, ByVal oOPCRow As DataRow, ByVal oAttribute_Dt As DataTable, ByVal sLineNoText As String) As LMSymbol
1276
        Try
1277
            Dim oAttributeRow() As DataRow
1278
            If oAttribute_Dt.Rows.Count > 0 Then
1279
                oAttributeRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sUid + "'")
1280
            End If
1281
            Dim oDatasource As Object = _Placement.PIDDataSource
1282
            Dim sSymbolCompType As String = oOPCRow(_XML_SYMBOL_TYPE).ToString()
1283
            Dim sSystemPath As String = oOPCRow(_XML_SYMBOL_SYSTEMPATH).ToString()
1284
            Dim sClass As String = oOPCRow(_XML_SYMBOL_CLASS).ToString()
1285
            Dim sLocation As String = oOPCRow(_XML_SYMBOL_LOCATION).ToString()
1286
            Dim sOriginalPoint As String = oOPCRow(_XML_SYMBOL_ORIGINALPOINT).ToString()
1287
            Dim dAngle As Double = 0.0
1288
            If IsNumeric(oOPCRow(_XML_SYMBOL_ANGLE).ToString()) Then
1289
                dAngle = Double.Parse(oOPCRow(_XML_SYMBOL_ANGLE).ToString())
1290
            End If
1291

    
1292
            Dim dLocationX As Double = 0.0
1293
            Dim dLocationY As Double = 0.0
1294
            Dim dX As Double = 0.0
1295
            Dim dY As Double = 0.0
1296
            Dim oLMSymbol As LMSymbol = Nothing
1297
            If ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY) Then
1298
                dX = dLocationX
1299
                dY = dLocationY
1300
                ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
1301
                _iPipintOpccnt = _iPipintOpccnt + 1
1302
                oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
1303
                '모델링된 형상은 Drawing True 로 처리
1304
                oOPCRow(_XML_SYMBOL_DRAWING_TF) = "TRUE"
1305
                SetListBoxItems(ListBox_Result, "Place Piping OPC.." & sUid & " (" & dLocationX & "," & dLocationY & ")..." & _iPipintOpccnt & " count ")
1306
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Piping OPC : " & sUid & "")
1307
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "LineNo : " & sLineNoText)
1308
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection1 : " & oOPCRow(_XML_SYMBOL_Conn1_Uid).ToString())
1309
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection2 : " & oOPCRow(_XML_SYMBOL_Conn2_Uid).ToString())
1310
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
1311
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "OriginalPoint : " & dLocationX & "," & dLocationY)
1312
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "OPC Count : " & _iPipintOpccnt)
1313

    
1314
                Dim dConn_X1 As Double, dConn_Y1 As Double, dConn_X2 As Double, dConn_Y2 As Double
1315
                _Placement.PIDConnectPointLocation(oLMSymbol, 1, dConn_X1, dConn_Y1)
1316
                _Placement.PIDConnectPointLocation(oLMSymbol, 2, dConn_X2, dConn_Y2)
1317

    
1318
                'Dim oAddrow As DataRow = _ResultModeling_DT.NewRow()
1319
                'oAddrow(_Modeling_Uid) = sUid
1320
                'oAddrow(_Modeling_Location_X) = dLocationX
1321
                'oAddrow(_Modeling_Location_Y) = dLocationY
1322
                'oAddrow(_Modeling_LineNoUid) = sLineUid
1323
                'oAddrow(_Modeling_Type) = sSymbolCompType
1324
                'oAddrow(_Modeling_Connection1_X) = dConn_X1
1325
                'oAddrow(_Modeling_Connection1_Y) = dConn_Y1
1326
                'oAddrow(_Modeling_Connection2_X) = dConn_X2
1327
                'oAddrow(_Modeling_Connection2_X) = dConn_Y2
1328
                'oAddrow(_Modeling_LMSymbol) = oLMSymbol
1329

    
1330
                '_ResultModeling_DT.Rows.Add(oAddrow)
1331
            End If
1332
            _Itemcnt = _Itemcnt + 1
1333
            Dim dCalcProgressValue As Double = (_Itemcnt / _allItem) * 100
1334
            SetProgressbar(ProgressBar_Status, dCalcProgressValue)
1335
            Label_Progress.Text = Math.Round(dCalcProgressValue, 0) & "%"
1336
            Return oLMSymbol
1337
        Catch ex As Exception
1338

    
1339
        End Try
1340
        Return Nothing
1341

    
1342
    End Function
1343

    
1344
    Private Sub AddProgress()
1345
        _Itemcnt = _Itemcnt + 1
1346
        Dim dCalcProgressValue As Double = (_Itemcnt / _allItem) * 100
1347
        SetProgressbar(ProgressBar_Status, dCalcProgressValue)
1348
        Label_Progress.Text = Math.Round(dCalcProgressValue, 0) & "%"
1349
    End Sub
1350
    Private Function DrawSymbol(ByVal sUid As String, ByVal oSymbol_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal oLine_Dt As DataTable) As Boolean
1351
        Try
1352

    
1353
            Dim oSymbolRow() As DataRow = oSymbol_Dt.Select(_XML_SYMBOL_UID & " = '" + sUid + "'")
1354
            Dim oAttributeRow() As DataRow
1355
            If oAttribute_Dt.Rows.Count > 0 Then
1356
                oAttributeRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sUid + "'")
1357
            End If
1358

    
1359
            If oSymbolRow.Length > 0 Then
1360
                Dim oDatasource As Object = _Placement.PIDDataSource
1361
                Dim sSymbolCompType As String = oSymbolRow(0)(_XML_SYMBOL_TYPE).ToString()
1362
                Dim sSystemPath As String = oSymbolRow(0)(_XML_SYMBOL_SYSTEMPATH).ToString()
1363
                Dim sClass As String = oSymbolRow(0)(_XML_SYMBOL_CLASS).ToString()
1364
                Dim sLocation As String = oSymbolRow(0)(_XML_SYMBOL_LOCATION).ToString()
1365
                Dim sOriginalPoint As String = oSymbolRow(0)(_XML_SYMBOL_ORIGINALPOINT).ToString()
1366
                Dim dAngle As Double = 0.0
1367
                If IsNumeric(oSymbolRow(0)(_XML_SYMBOL_ANGLE).ToString()) Then
1368
                    dAngle = Double.Parse(oSymbolRow(0)(_XML_SYMBOL_ANGLE).ToString())
1369
                End If
1370

    
1371
                Dim objSymbol As LMSymbol
1372
                Dim dLocationX As Double = 0.0
1373
                Dim dLocationY As Double = 0.0
1374
                Dim dX As Double = 0.0
1375
                Dim dY As Double = 0.0
1376

    
1377
                If ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY) Then
1378
                    dX = dLocationX
1379
                    dY = dLocationY
1380
                    If sSymbolCompType = "" Or sSymbolCompType = "Piping OPC's" Then
1381
                        FindConnectionLine(oLine_Dt, dX, dY)
1382
                    End If
1383

    
1384
                    ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
1385
                    Dim oInstrument As LMInstrument
1386
                    If sSymbolCompType.ToUpper() = _SYMBOL_INSTUMENT.ToUpper() Then
1387
                        _iInstrumentcnt = _iInstrumentcnt + 1
1388
                        objSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
1389
                        SetListBoxItems(ListBox_Result, "Place Instrument..(" & dLocationX & "," & dLocationY & ")..." & _iInstrumentcnt & " count ")
1390
                        oInstrument = oDatasource.GetInstrument(objSymbol.ModelItemID)
1391
                        Try
1392
                            If oAttributeRow.Length > 0 Then
1393
                                For Each oAttribute In oAttributeRow
1394
                                    Try
1395
                                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
1396
                                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
1397
                                        Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
1398
                                        oInstrument.Attributes(sSPPIDAttribute).Value = sPIDValue
1399
                                    Catch ex As Exception
1400

    
1401
                                    End Try
1402

    
1403
                                Next
1404
                                oInstrument.Commit()
1405
                            End If
1406
                        Catch ex As Exception
1407
                        End Try
1408
                    ElseIf sSymbolCompType.ToUpper() = _DB_FITTINGS.ToUpper() Then
1409
                        _iValvecnt = _iValvecnt + 1
1410
                        _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
1411
                        SetListBoxItems(ListBox_Result, "Place Valve..(" & dLocationX & "," & dLocationY & ")..." & _iValvecnt & " count ")
1412

    
1413
                    ElseIf sSymbolCompType.ToUpper() = _SYMBOL_FITTINGS.ToUpper() Then
1414
                        _iFittingcnt = _iFittingcnt + 1
1415
                        If sSystemPath.Contains(",") Then
1416

    
1417
                            Dim sDuplicatePath As String() = sSystemPath.Split(",")
1418
                            Dim sMainSymbol As String = ""
1419
                            Dim sSubSymbol As String = ""
1420
                            For Each sPath In sDuplicatePath
1421
                                If sMainSymbol = "" Then
1422
                                    sMainSymbol = sPath.Replace(vbLf, "")
1423
                                Else
1424
                                    sSubSymbol = sPath.Replace(vbLf, "")
1425
                                End If
1426
                            Next
1427
                            Dim oSymbolObj As LMSymbol = _Placement.PIDPlaceSymbol(sMainSymbol, dX, dY, , dAngle)
1428
                            Dim dConnpos_x As Double = 0.0
1429
                            Dim dConnpos_y As Double = 0.0
1430
                            _Placement.PIDConnectPointLocation(oSymbolObj, 2, dConnpos_x, dConnpos_y)
1431
                            '   _Placement.PIDPlaceSymbol(sSubSymbol, dConnpos_x, dConnpos_y, dAngle, TargetItem:=oSymbolObj.AsLMRepresentation)
1432
                            _Placement.PIDPlaceSymbol(sSubSymbol, dConnpos_x, dConnpos_y,, dAngle)
1433

    
1434
                        Else
1435
                            _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
1436
                        End If
1437

    
1438

    
1439
                        SetListBoxItems(ListBox_Result, "Place Fitting..(" & dLocationX & "," & dLocationY & ")..." & _iFittingcnt & " count ")
1440
                    ElseIf sSymbolCompType.ToUpper() = _SYMBOL_INSTUMENT.ToUpper() And sClass.ToUpper() = _SYMBOL_ACTUATORS.ToUpper() Then
1441
                        _iFittingcnt = _iFittingcnt + 1
1442
                        Dim sDuplicatePath As String() = sSystemPath.Split(",")
1443
                        Dim sMainSymbol As String = ""
1444
                        Dim sSubSymbol As String = ""
1445
                        For Each sPath In sDuplicatePath
1446
                            If sMainSymbol = "" Then
1447
                                sMainSymbol = sPath.Replace(vbLf, "")
1448
                            Else
1449
                                sSubSymbol = sPath.Replace(vbLf, "")
1450
                            End If
1451
                        Next
1452
                        Dim oSymbolObj As LMSymbol = _Placement.PIDPlaceSymbol(sMainSymbol, dX, dY, , dAngle)
1453
                        Dim dSymbolpos_x As Double = oSymbolObj.XCoordinate
1454
                        Dim dSymbolpos_y As Double = oSymbolObj.YCoordinate
1455
                        _Placement.PIDPlaceSymbol(sSubSymbol, dSymbolpos_x, dSymbolpos_y, , dAngle, TargetItem:=oSymbolObj.AsLMAItem)
1456

    
1457
                    Else
1458
                        _iFittingcnt = _iFittingcnt + 1
1459
                        _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
1460
                        SetListBoxItems(ListBox_Result, "Place Fitting..(" & dLocationX & "," & dLocationY & ")..." & _iFittingcnt & " count ")
1461
                    End If
1462

    
1463
                End If
1464
                _Itemcnt = _Itemcnt + 1
1465
                Dim dCalcProgressValue As Double = (_Itemcnt / _allItem) * 100
1466
                SetProgressbar(ProgressBar_Status, dCalcProgressValue)
1467
                Label_Progress.Text = Math.Round(dCalcProgressValue, 0) & "%"
1468
            End If
1469

    
1470
        Catch ex As Exception
1471
            Return False
1472
        End Try
1473
    End Function
1474

    
1475

    
1476
    Private Sub FindConnectionLine(ByVal oLine_Dt As DataTable, ByRef dx As Double, ByRef dy As Double)
1477

    
1478
        Try
1479
            For Each oRow In oLine_Dt.Rows
1480
                Dim sStartpoint As String = oRow(_XML_LINE_STARTPOINT).ToString()
1481
                Dim sEndpoint As String = oRow(_XML_LINE_ENDPOINT).ToString()
1482
                Dim d기준s_x As Double = 0
1483
                Dim d기준s_y As Double = 0
1484
                Dim d기준e_x As Double = 0
1485
                Dim d기준e_y As Double = 0
1486
                ConvertPointBystring(sStartpoint, d기준s_x, d기준s_y)
1487
                ConvertPointBystring(sEndpoint, d기준e_x, d기준e_y)
1488
                If dx + 300 > d기준s_x And dx - 300 < d기준s_x And dy + 300 > d기준s_y And dy - 300 < d기준s_y Then
1489
                    dx = d기준s_x
1490
                    dy = d기준s_y
1491
                ElseIf dx + 300 > d기준e_x And dx - 300 < d기준e_x And dy + 300 > d기준e_y And dy - 300 < d기준e_y Then
1492
                    dx = d기준e_x
1493
                    dy = d기준e_y
1494
                End If
1495
            Next
1496
        Catch ex As Exception
1497
        End Try
1498
    End Sub
1499

    
1500

    
1501
    Dim _라인보정기준값 As Integer = 10
1502

    
1503
    Private Function 라인보정(ByRef oLine_Dt As DataTable, ByVal sUid As String, ByRef dsx As Double, ByRef dsy As Double,
1504
                                      ByRef dex As Double, ByRef dey As Double)
1505
        Try
1506
            Dim bCheck라인 As Boolean = False
1507
            '일치하는 Line 찾기
1508
            For Each oRow In oLine_Dt.Rows
1509
                Dim sStartpoint As String = oRow(_XML_LINE_STARTPOINT).ToString()
1510
                Dim sEndpoint As String = oRow(_XML_LINE_ENDPOINT).ToString()
1511
                Dim sBUid As String = oRow(_XML_LINE_UID).ToString()
1512
                If sBUid <> sUid Then
1513
                    Dim d기준s_x As Double = 0
1514
                    Dim d기준s_y As Double = 0
1515
                    Dim d기준e_x As Double = 0
1516
                    Dim d기준e_y As Double = 0
1517
                    ConvertPointBystring(sStartpoint, d기준s_x, d기준s_y)
1518
                    ConvertPointBystring(sEndpoint, d기준e_x, d기준e_y)
1519

    
1520
                    If (dsx = d기준s_x And dsy = d기준s_y) Or (dsx = d기준e_x And dsy = d기준e_y) Or
1521
                       (dex = d기준s_x And dey = d기준s_y) Or (dex = d기준e_x And dey = d기준e_y) Then
1522
                        bCheck라인 = True
1523
                    End If
1524
                End If
1525
            Next
1526

    
1527
            If bCheck라인 = False Then
1528
                For Each oRow In oLine_Dt.Rows
1529
                    Dim sStartpoint As String = oRow(_XML_LINE_STARTPOINT).ToString()
1530
                    Dim sEndpoint As String = oRow(_XML_LINE_ENDPOINT).ToString()
1531
                    Dim sBUid As String = oRow(_XML_LINE_UID).ToString()
1532
                    If sBUid <> sUid Then
1533
                        Dim d기준s_x As Double = 0
1534
                        Dim d기준s_y As Double = 0
1535
                        Dim d기준e_x As Double = 0
1536
                        Dim d기준e_y As Double = 0
1537
                        ConvertPointBystring(sStartpoint, d기준s_x, d기준s_y)
1538
                        ConvertPointBystring(sEndpoint, d기준e_x, d기준e_y)
1539
                        If ((dsx - _라인보정기준값 <= d기준s_x And dsx + _라인보정기준값 >= d기준s_x) And (dsy - _라인보정기준값 <= d기준s_y And dsy + _라인보정기준값 >= d기준s_y)) Then
1540
                            oRow(_XML_LINE_STARTPOINT) = dsx & "," & dsy
1541
                            bCheck라인 = True
1542
                            Exit For
1543
                        ElseIf ((dsx - _라인보정기준값 <= d기준e_x And dsx + _라인보정기준값 >= d기준e_x) And (dsy - _라인보정기준값 <= d기준e_y And dsy + _라인보정기준값 >= d기준e_y)) Then
1544
                            oRow(_XML_LINE_ENDPOINT) = dsx & "," & dsy
1545
                            bCheck라인 = True
1546
                            Exit For
1547
                        ElseIf ((dex - _라인보정기준값 <= d기준s_x And dex + _라인보정기준값 >= d기준s_x) And (dey - _라인보정기준값 <= d기준s_y And dey + _라인보정기준값 >= d기준s_y)) Then
1548
                            oRow(_XML_LINE_STARTPOINT) = dex & "," & dey
1549
                            bCheck라인 = True
1550
                            Exit For
1551
                        ElseIf ((dex - _라인보정기준값 <= d기준e_x And dex + _라인보정기준값 >= d기준e_x) And (dey - _라인보정기준값 <= d기준e_y And dey + _라인보정기준값 >= d기준e_y)) Then
1552
                            oRow(_XML_LINE_ENDPOINT) = dex & "," & dey
1553
                            bCheck라인 = True
1554
                            Exit For
1555
                        End If
1556

    
1557
                    End If
1558
                Next
1559
            End If
1560

    
1561
            Return bCheck라인
1562
        Catch ex As Exception
1563
            Return False
1564
        End Try
1565

    
1566

    
1567
    End Function
1568

    
1569
    Private Function FindOverlapLine(ByVal oLine_Dt As DataTable, ByVal sUid As String, ByRef dsx As Double, ByRef dsy As Double,
1570
                                      ByRef dex As Double, ByRef dey As Double)
1571
        Try
1572
            Dim bCheckOverlap As Boolean = False
1573
            For Each oRow In oLine_Dt.Rows
1574
                Dim sStartpoint As String = oRow(_XML_LINE_STARTPOINT).ToString()
1575
                Dim sEndpoint As String = oRow(_XML_LINE_ENDPOINT).ToString()
1576
                Dim sBUid As String = oRow(_XML_LINE_UID).ToString()
1577
                If sBUid <> sUid Then
1578
                    Dim d기준s_x As Double = 0
1579
                    Dim d기준s_y As Double = 0
1580
                    Dim d기준e_x As Double = 0
1581
                    Dim d기준e_y As Double = 0
1582
                    ConvertPointBystring(sStartpoint, d기준s_x, d기준s_y)
1583
                    ConvertPointBystring(sEndpoint, d기준e_x, d기준e_y)
1584
                    If (d기준s_x <= dsx And d기준e_x >= dex And
1585
                        d기준s_y <= dsy And d기준e_y >= dey) Then
1586
                        '겹쳐서 오버되는 길이가 오버되지 않는 길이의 10%미만일때 겹치는 y축좌표를 겹치는점까지 설정
1587
                        If dsy - d기준s_y > d기준e_y - dey Then
1588
                            Dim dResultCalc As Double = ((d기준e_y - dey) / (dsy - d기준s_y)) * 100
1589
                            If dResultCalc < 10 Then
1590
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1591
                                Dim dCalcY As Double = Math.Abs(d기준s_y - d기준e_y)
1592
                                Dim dCalcStartX As Double = Math.Abs(dsx - d기준s_x)
1593
                                Dim dCalcStartY As Double = (dCalcY * dCalcStartX) / dCalcX
1594
                                If dCalcStartY = 0 Then
1595
                                    dey = d기준e_y
1596
                                Else
1597
                                    dey = dCalcStartY
1598
                                End If
1599
                            End If
1600
                        Else
1601
                            '  Dim dResultCalc As Double = ((dsy - d기준s_y) / (d기준e_y - dey)) * 100
1602
                            Dim dResultCalc As Double = ((d기준e_y - dey) / (dsy - d기준s_y)) * 100
1603
                            If dResultCalc < 10 Then
1604
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1605
                                Dim dCalcY As Double = Math.Abs(d기준e_y - d기준s_y)
1606
                                Dim dCalcStartX As Double = Math.Abs(dsx - d기준s_x)
1607
                                Dim dCalcStartY As Double = (dCalcY * dCalcStartX) / dCalcX
1608
                                If dCalcStartY = 0 Then
1609
                                    dsy = d기준s_y
1610
                                Else
1611
                                    dsy = dCalcStartY
1612
                                End If
1613
                            End If
1614
                        End If
1615
                        bCheckOverlap = True
1616
                    ElseIf (d기준s_x <= dsx And d기준e_x >= dex) And
1617
                            d기준s_y <= dey And d기준e_y >= dsy Then
1618
                        '겹쳐서 오버되는 길이가 오버되지 않는 길이의 10%미만일때 겹치는 y축좌표를 겹치는점까지 설정
1619
                        If dey - d기준s_y > d기준e_y - dsy Then
1620
                            Dim dResultCalc As Double = ((d기준e_y - dey) / (dsy - d기준s_y)) * 100
1621
                            If dResultCalc < 10 Then
1622
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1623
                                Dim dCalcY As Double = Math.Abs(d기준s_y - d기준e_y)
1624
                                Dim dCalcStartX As Double = Math.Abs(dsx - d기준s_x)
1625
                                Dim dCalcStartY As Double = (dCalcY * dCalcStartX) / dCalcX
1626
                                If dCalcStartY = 0 Then
1627
                                    dsy = d기준e_y
1628
                                Else
1629
                                    dsy = dCalcStartY
1630
                                End If
1631

    
1632
                            End If
1633
                            '겹쳐서 오버되는 길이가 오버되지 않는 길이의 10%미만일때 겹치는 y축좌표를 겹치는점까지 설정
1634
                        Else
1635
                            '  Dim dResultCalc As Double = (Math.Abs((dsy - d기준s_y)) / Math.Abs((d기준e_y - dey))) * 100
1636
                            Dim dResultCalc As Double = ((d기준e_y - dey) / (dsy - d기준s_y)) * 100
1637
                            If dResultCalc < 10 Then
1638
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1639
                                Dim dCalcY As Double = Math.Abs(d기준e_y - d기준s_y)
1640
                                Dim dCalcStartX As Double = Math.Abs(dsx - d기준s_x)
1641
                                Dim dCalcStartY As Double = (dCalcY * dCalcStartX) / dCalcX
1642
                                If dCalcStartY = 0 Then
1643
                                    dey = d기준e_y
1644
                                Else
1645
                                    dey = dCalcStartY
1646
                                End If
1647
                            End If
1648
                        End If
1649
                        bCheckOverlap = True
1650
                    ElseIf (d기준s_x <= dsx And d기준e_x >= dex) And
1651
                            d기준s_y <= dey And d기준e_y >= dsy Then
1652

    
1653
                        If dsx - d기준s_x > d기준e_x - dex Then
1654
                            Dim dResultCalc As Double = ((d기준e_x - dex) / (dsx - d기준s_x)) * 100
1655
                            If dResultCalc < 10 Then
1656
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1657
                                Dim dCalcY As Double = Math.Abs(d기준s_y - d기준e_y)
1658
                                Dim dCalcStartY As Double = Math.Abs(dsy - d기준s_y)
1659
                                Dim dCalcStartX As Double = (dCalcX * dCalcStartY) / dCalcY
1660
                                If dCalcStartX = 0 Then
1661
                                    dex = d기준e_x
1662
                                Else
1663
                                    dex = dCalcStartX
1664
                                End If
1665
                            End If
1666
                        Else
1667
                            '  Dim dResultCalc As Double = ((dsy - d기준s_y) / (d기준e_y - dey)) * 100
1668
                            Dim dResultCalc As Double = ((d기준e_x - dex) / (dsx - d기준s_x)) * 100
1669
                            If dResultCalc < 10 Then
1670
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1671
                                Dim dCalcY As Double = Math.Abs(d기준e_y - d기준s_y)
1672
                                Dim dCalcStartY As Double = Math.Abs(dsy - d기준s_y)
1673
                                Dim dCalcStartX As Double = (dCalcX * dCalcStartY) / dCalcY
1674
                                If dCalcStartX = 0 Then
1675
                                    dsx = d기준s_x
1676
                                Else
1677
                                    dsx = dCalcStartX
1678
                                End If
1679
                            End If
1680
                        End If
1681
                        bCheckOverlap = True
1682
                    ElseIf (d기준s_x <= dsx And d기준e_x >= dex) And
1683
                            d기준s_y <= dey And d기준e_y >= dsy Then
1684

    
1685
                        If dex - d기준s_x > d기준e_x - dsx Then
1686
                            Dim dResultCalc As Double = ((d기준e_x - dex) / (dsx - d기준s_x)) * 100
1687
                            If dResultCalc < 10 Then
1688
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1689
                                Dim dCalcY As Double = Math.Abs(d기준s_y - d기준e_y)
1690
                                Dim dCalcStartY As Double = Math.Abs(dsy - d기준s_y)
1691
                                Dim dCalcStartX As Double = (dCalcX * dCalcStartY) / dCalcY
1692
                                If dCalcStartX = 0 Then
1693
                                    dsx = d기준e_x
1694
                                Else
1695
                                    dsx = dCalcStartX
1696
                                End If
1697
                            End If
1698
                        Else
1699
                            ' Dim dResultCalc As Double = ((dsy - d기준s_y) / (d기준e_y - dey)) * 100
1700
                            Dim dResultCalc As Double = ((d기준e_x - dex) / (dsx - d기준s_x)) * 100
1701
                            If dResultCalc < 10 Then
1702
                                Dim dCalcX As Double = Math.Abs(d기준e_x - d기준s_x)
1703
                                Dim dCalcY As Double = Math.Abs(d기준e_y - d기준s_y)
1704
                                Dim dCalcStartY As Double = Math.Abs(dsy - d기준s_y)
1705
                                Dim dCalcStartX As Double = (dCalcX * dCalcStartY) / dCalcY
1706
                                If dCalcStartX = 0 Then
1707
                                    dex = d기준s_x
1708
                                Else
1709
                                    dex = dCalcStartX
1710
                                End If
1711
                            End If
1712

    
1713
                        End If
1714
                        bCheckOverlap = True
1715
                    End If
1716
                End If
1717
            Next
1718

    
1719
            Return bCheckOverlap
1720
        Catch ex As Exception
1721
            Return False
1722
        End Try
1723
    End Function
1724

    
1725
    Private Sub CalcSperateLine(ByRef dStartX As Double, ByRef dStartY As Double,
1726
                                      ByRef dEndX As Double, ByRef dEndY As Double)
1727
        Try
1728
            Dim dRange As Double = 1 'Line 전체 길이의 10%씩 늘이기
1729
            If Math.Abs(dStartX - dEndX) > Math.Abs(dStartY - dEndY) Then
1730
                Dim dCalc_x As Double = Math.Abs(dStartX - dEndX) * 0.1
1731
                If dStartX > dEndX Then
1732
                    dStartX = dStartX + dCalc_x
1733
                    dEndX = dEndX - dCalc_x
1734
                Else
1735
                    dEndX = dEndX + dCalc_x
1736
                    dStartX = dStartX - dCalc_x
1737
                End If
1738
            Else
1739
                Dim dCalc_y As Double = Math.Abs(dStartY - dEndY) * 0.1
1740
                If dStartY > dEndY Then
1741
                    dStartY = dStartY + dCalc_y
1742
                    dEndY = dEndY - dCalc_y
1743
                Else
1744
                    dEndY = dEndY + dCalc_y
1745
                    dStartY = dStartY - dCalc_y
1746
                End If
1747
            End If
1748

    
1749
        Catch ex As Exception
1750

    
1751
        End Try
1752

    
1753

    
1754
    End Sub
1755

    
1756
    Private Function DrawLineNo(ByVal oPipeRun_Dt As DataTable, ByVal CLine_No As Line_no) As Boolean
1757
        Try
1758
            Dim oDatasource As Object = _Placement.PIDDataSource
1759
            Dim sLocation = CLine_No.Location
1760
            Dim dLocationx As Double = 0.0
1761
            Dim dLocationy As Double = 0.0
1762
            Dim dX As Double = 0.0
1763
            Dim dY As Double = 0.0
1764
            If ConvertPointBystring(sLocation, dLocationx, dLocationy) Then
1765
                dX = dLocationx
1766
                dY = dLocationy
1767
                For Each oRow In oPipeRun_Dt.Rows
1768
                    Dim dStartx As Double = Double.Parse(oRow("startx").ToString())
1769
                    Dim dStarty As Double = Double.Parse(oRow("starty").ToString())
1770
                    Dim dEndx As Double = Double.Parse(oRow("endx").ToString())
1771
                    Dim dEndy As Double = Double.Parse(oRow("endy").ToString())
1772
                    Dim dStartSum As Double = Math.Abs(dStartx - dLocationx) + Math.Abs(dStarty - dLocationy)
1773
                    Dim dEndSum As Double = Math.Abs(dEndx - dLocationx) + Math.Abs(dEndy - dLocationy)
1774
                    If dStartSum > dEndSum Then
1775
                        oRow("value") = dEndSum
1776
                    Else
1777
                        oRow("value") = dStartSum
1778
                    End If
1779
                Next
1780
                Dim dataView As New DataView(oPipeRun_Dt)
1781
                dataView.Sort = " value asc"
1782
                Dim oDt As DataTable = dataView.ToTable()
1783
                If oDt.Rows.Count > 0 Then
1784
                    Try
1785
                        Dim oPiperun As LMPipeRun = CType(oDt.Rows(0)("Piperun"), LMPipeRun)
1786
                        ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
1787
                        Dim dLineNoLocation(2) As Double
1788
                        dLineNoLocation(1) = dX
1789
                        dLineNoLocation(2) = dY
1790
                        'Label
1791
                        Dim sSystemPath As String = CLine_No.SystemPath
1792
                        Dim dAngle As Double = CLine_No.Angle
1793
                        Dim labelpersist As LMLabelPersist
1794
                        For Each representation In oPiperun.Representations
1795
                            If representation.RepresentationType = "Connector" Then
1796
                                labelpersist = _Placement.PIDPlaceLabel(sSystemPath,
1797
                                dLineNoLocation,, dAngle, LabeledItem:=representation)
1798
                                _iPipeLineNocnt = _iPipeLineNocnt + 1
1799
                                SetListBoxItems(ListBox_Result, "Place PipeLineNo Label.." & CLine_No.Uid & " (" & dLocationx & "," & dLocationy & ")..." & _iPipeLineNocnt & " count ")
1800
                                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Pipe : " & CLine_No.Uid & "")
1801
                                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "LineNo : " & CLine_No.Text)
1802
                                'ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
1803
                                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Origina lPoint : " & dLocationx & "," & dLocationy)
1804
                                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "PipeLineNo Count : " & _iPipeLineNocnt)
1805
                            End If
1806
                        Next
1807
                    Catch ex As Exception
1808
                    End Try
1809
                End If
1810
                Return True
1811
            Else
1812
                Return False
1813
            End If
1814
        Catch ex As Exception
1815
            Return False
1816
        End Try
1817
    End Function
1818

    
1819

    
1820
    Private Sub InitItemCount()
1821
        _iPipeLineNocnt = 0
1822
        _iPipecnt = 1
1823
        _iFittingcnt = 1
1824
        _iValvecnt = 0
1825
        _iInstrumentcnt = 0
1826
        _iEquipmentcnt = 0
1827
        _iNozzlecnt = 1
1828
        _iPipintOpccnt = 0
1829
    End Sub
1830

    
1831
    Private Function GetAllCheckNodeCount() As Integer
1832
        _allItem = 0
1833
        For i = 0 To Tree_Result.Nodes.Count - 1
1834
            For j = 0 To Tree_Result.Nodes(i).Nodes.Count - 1
1835
                For k = 0 To Tree_Result.Nodes(i).Nodes(j).Nodes.Count - 1
1836
                    For l = 0 To Tree_Result.Nodes(i).Nodes(j).Nodes(k).Nodes.Count - 1
1837
                        If Tree_Result.Nodes(i).Nodes(j).Nodes(k).Nodes(l).Checked = True Then
1838
                            _allItem = _allItem + 1
1839
                        End If
1840
                    Next
1841
                Next
1842
            Next
1843
        Next
1844
        Return _allItem
1845
    End Function
1846

    
1847

    
1848
    ''' <summary>
1849
    ''' Equipment 모델링
1850
    ''' </summary>
1851
    Private Sub EquipmentModeling(ByVal oDwg_Dt As DataTable)
1852
        For Each oDrwing As TreeNode In Tree_Result.Nodes
1853
            For Each oDwgNode As TreeNode In oDrwing.Nodes
1854
                Dim sDwgName As String = Path.GetFileNameWithoutExtension(oDwgNode.Text)
1855
                Dim CDrawing As Drawing = GetDrawing(sDwgName)
1856
                If CDrawing IsNot Nothing Then
1857
                    If OpenSPPID(oDwg_Dt, oDwgNode.Text) Then
1858

    
1859
                        For Each oNode As TreeNode In oDwgNode.Nodes
1860
                            Dim iItemcnt As Integer = 0
1861
                            Dim sNodeUid As String = oNode.Name
1862
                            Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
1863
                            '1.Equipment
1864
                            '2.Piping OPC
1865
                            '3.OPC 시작되는 Line
1866
                            'Equipment 생성
1867
                            Dim CEqpNo As Eqp_no = GetEqpNo(CDrawing, sNodeUid)
1868
                            If CEqpNo IsNot Nothing Then
1869
                                Dim oSymbol_Dt As DataTable = CEqpNo.Dt_Equipment
1870
                                Dim oAttribute_Dt As DataTable = CEqpNo.Dt_Attribute
1871
                                For Each oSymbolNode As TreeNode In oNode.Nodes
1872
                                    If oSymbolNode.Checked Then
1873
                                        Dim sUid As String = oSymbolNode.Name
1874
                                        PlaceEquipment(sUid, oSymbol_Dt, oAttribute_Dt, CEqpNo.Text)
1875
                                    End If
1876
                                Next
1877
                            End If
1878
                        Next
1879
                    End If
1880
                End If
1881
            Next
1882
        Next
1883
    End Sub
1884

    
1885
    Private Sub ManualCheckNode(ByRef oDt As DataTable)
1886
        For Each oDrwing As TreeNode In Tree_Result.Nodes
1887
            For Each oDwgNode As TreeNode In oDrwing.Nodes
1888
                For Each oNode As TreeNode In oDwgNode.Nodes
1889
                    For Each oSymbolNode As TreeNode In oNode.Nodes
1890
                        Dim sUid As String = oSymbolNode.Name
1891
                        'Dim oSelectRows() As DataRow = oDt.Select("[" & _XML_SYMBOL_UID & "] = '" & sUid &
1892
                        '                                      "' And [" & _XML_SYMBOL_DRAWING_TF & "] = 'False'")
1893
                        If oSymbolNode.Checked Then
1894
                            Dim oSelectRows() As DataRow = oDt.Select("[" & _XML_SYMBOL_UID & "] = '" & sUid & "'")
1895
                            If oSelectRows.Length = 1 Then
1896
                                oSelectRows(0)(_XML_SYMBOL_DRAWING_TF) = "FALSE"
1897
                                If oSymbolNode.Checked Then
1898
                                    oSelectRows(0)(_XML_SYMBOL_Check) = "TRUE"
1899
                                Else
1900
                                    oSelectRows(0)(_XML_SYMBOL_Check) = "FALSE"
1901
                                End If
1902
                            End If
1903
                        End If
1904
                    Next
1905
                Next
1906
            Next
1907
        Next
1908

    
1909
    End Sub
1910

    
1911
    Private Function FinalSymbolModeling(ByVal oCurrentSymbolRow As DataRow, ByVal oLine_Dt As DataTable, ByVal oSymbol_Dt As DataTable,
1912
                                  ByVal oAttribute_Dt As DataTable) As String
1913
        Dim sReturnUid As String = ""
1914
        Dim sOriginalPoint As String = ""
1915
        Dim dOriginal_x As Double = 0.0
1916
        Dim dOriginal_y As Double = 0.0
1917
        Dim dConn1_x As Double = 0.0
1918
        Dim dConn1_y As Double = 0.0
1919
        Dim dConn2_x As Double = 0.0
1920
        Dim dConn2_y As Double = 0.0
1921
        Dim dConn3_x As Double = 0.0
1922
        Dim dConn3_y As Double = 0.0
1923
        Dim dConn4_x As Double = 0.0
1924
        Dim dConn4_y As Double = 0.0
1925
        Dim sUid As String = oCurrentSymbolRow(_XML_SYMBOL_UID)
1926
        Dim sSystemPath As String = oCurrentSymbolRow(_XML_SYMBOL_SYSTEMPATH).ToString()
1927
        Dim dAngle As Double = oCurrentSymbolRow(_XML_SYMBOL_ANGLE)
1928
        Dim sLineNoText As String = oCurrentSymbolRow(_XML_LINENO_TEXT)
1929
        Dim sLineNoUid As String = oCurrentSymbolRow(_XML_LINE_LINENOUID).ToString()
1930
        sOriginalPoint = oCurrentSymbolRow(_XML_SYMBOL_ORIGINALPOINT).ToString()
1931
        Dim sSymbolCompType As String = oCurrentSymbolRow(_XML_SYMBOL_TYPE).ToString()
1932
        ConvertPointBystring(sOriginalPoint, dOriginal_x, dOriginal_y)
1933
        ConvertPointByImage(dOriginal_x, dOriginal_y, _IMG_X, _IMG_Y)
1934
        Dim sChildItem As String = oCurrentSymbolRow(_XML_SYMBOL_CHILD)
1935
        'Connection 정보 체크, 모델링 되어 있는지 유무
1936
        '양 커넥션의 모델링 유무를 체크한다.
1937
        Dim sConn1Uid As String = oCurrentSymbolRow(_XML_SYMBOL_Conn1_Uid).ToString()
1938
        Dim sConn2Uid As String = oCurrentSymbolRow(_XML_SYMBOL_Conn2_Uid).ToString()
1939
        Dim sConn3Uid As String = oCurrentSymbolRow(_XML_SYMBOL_Conn3_Uid).ToString()
1940
        Dim sConn4Uid As String = oCurrentSymbolRow(_XML_SYMBOL_Conn4_Uid).ToString()
1941
        Dim sConn1Type As String = ""
1942
        Dim sConn2Type As String = ""
1943
        Dim sConn3Type As String = ""
1944
        Dim sConn4Type As String = ""
1945
        Dim oConn1Rows() As DataRow = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "] = '" & sConn1Uid & "'")
1946
        If oConn1Rows.Length = 0 Then
1947
            oConn1Rows = oLine_Dt.Select("[" & _XML_LINE_UID & "] = '" & sConn1Uid & "'")
1948
            If oConn1Rows.Length = 1 Then
1949
                sConn1Type = "Line"
1950
            End If
1951
        Else
1952
            sConn1Type = "Symbol"
1953
        End If
1954

    
1955
        Dim oConn2Rows() As DataRow = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "] = '" & sConn2Uid & "'")
1956
        If oConn2Rows.Length = 0 Then
1957
            oConn2Rows = oLine_Dt.Select("[" & _XML_LINE_UID & "] = '" & sConn2Uid & "'")
1958
            If oConn2Rows.Length = 1 Then
1959
                sConn2Type = "Line"
1960
            End If
1961
        Else
1962
            sConn2Type = "Symbol"
1963
        End If
1964

    
1965
        Dim oConn3Rows() As DataRow = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "] = '" & sConn3Uid & "'")
1966
        If oConn3Rows.Length = 0 Then
1967
            oConn3Rows = oLine_Dt.Select("[" & _XML_LINE_UID & "] = '" & sConn3Uid & "'")
1968
            If oConn3Rows.Length = 1 Then
1969
                sConn3Type = "Line"
1970
            End If
1971
        Else
1972
            sConn3Type = "Symbol"
1973
        End If
1974

    
1975
        Dim oConn4Rows() As DataRow = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "] = '" & sConn4Uid & "'")
1976
        If oConn4Rows.Length = 0 Then
1977
            oConn4Rows = oLine_Dt.Select("[" & _XML_LINE_UID & "] = '" & sConn4Uid & "'")
1978
            If oConn4Rows.Length = 1 Then
1979
                sConn4Type = "Line"
1980
            End If
1981
        Else
1982
            sConn4Type = "Symbol"
1983
        End If
1984

    
1985
        Dim oStartLMConnector As LMConnector = Nothing
1986
        Dim oEndLMConnector As LMConnector = Nothing
1987
        Dim objInputs As PlaceRunInputs
1988
        objInputs = New PlaceRunInputs
1989
        Dim iModelingType As Integer = 0
1990
        If sConn1Type <> "" Then
1991
            ConvertPoint(oCurrentSymbolRow(_XML_SYMBOL_Conn1_Point).ToString(), dConn1_x, dConn1_y)
1992
        End If
1993
        If sConn2Type <> "" Then
1994
            ConvertPoint(oCurrentSymbolRow(_XML_SYMBOL_Conn2_Point).ToString(), dConn2_x, dConn2_y)
1995
        End If
1996
        If sConn3Type <> "" Then
1997
            ConvertPoint(oCurrentSymbolRow(_XML_SYMBOL_Conn3_Point).ToString(), dConn3_x, dConn3_y)
1998
        End If
1999
        If sConn4Type <> "" Then
2000
            ConvertPoint(oCurrentSymbolRow(_XML_SYMBOL_Conn4_Point).ToString(), dConn4_x, dConn4_y)
2001
        End If
2002

    
2003
        Dim sFirstUid As String = ""
2004
        Dim sSecondUid As String = ""
2005
        Dim oLMSymbol As LMSymbol = Nothing
2006
        Dim dPreConn_x As Double = 0
2007
        Dim dPreConn_y As Double = 0
2008
        Dim sStartConnectionUid As String = ""
2009
        Dim sEndConnectionUid As String = ""
2010
        If sConn1Type <> "" And sConn2Type <> "" Then
2011
            If sConn1Type = "Line" Then
2012
                CheckConnectionLine(dConn1_x, dConn1_y, oStartLMConnector, sStartConnectionUid)
2013
            Else
2014
                CheckConnectionSymbolToSymbol(oConn1Rows, dConn1_x, dConn1_y, oStartLMConnector)
2015
            End If
2016

    
2017
            If sConn2Type = "Line" Then
2018
                CheckConnectionLine(dConn2_x, dConn2_y, oEndLMConnector, sEndConnectionUid)
2019
            Else
2020
                CheckConnectionSymbolToSymbol(oConn2Rows, dConn2_x, dConn2_y, oEndLMConnector)
2021
            End If
2022

    
2023
            sFirstUid = CheckExistModeling(oConn1Rows(0))
2024
            sSecondUid = CheckExistModeling(oConn2Rows(0))
2025
            Dim oCurrentLMConnector As LMConnector = Nothing
2026

    
2027
        ElseIf sConn1Type <> "" And sConn2Type = "" Then
2028
            If sConn1Type = "Line" Then
2029
                CheckConnectionLine(dConn1_x, dConn1_y, oStartLMConnector, sStartConnectionUid)
2030
            Else
2031
                CheckConnectionSymbolToSymbol(oConn1Rows, dConn1_x, dConn1_y, oStartLMConnector)
2032
                dOriginal_x = dConn1_x
2033
                dOriginal_y = dConn1_y
2034
            End If
2035

    
2036
            sFirstUid = CheckExistModeling(oConn1Rows(0))
2037

    
2038
        ElseIf sConn1Type = "" And sConn2Type <> "" Then
2039

    
2040
            If sConn1Type = "Line" Then
2041
                CheckConnectionLine(dConn2_x, dConn2_y, oEndLMConnector, sEndConnectionUid)
2042
            Else
2043
                CheckConnectionSymbolToSymbol(oConn2Rows, dConn2_x, dConn2_y, oEndLMConnector)
2044
                dOriginal_x = dConn2_x
2045
                dOriginal_y = dConn2_y
2046
            End If
2047
            sSecondUid = CheckExistModeling(oConn2Rows(0))
2048

    
2049
        ElseIf sConn3Type <> "" And sConn4Type <> "" Then
2050
            If sConn1Type = "Line" Then
2051
                CheckConnectionLine(dConn3_x, dConn3_y, oStartLMConnector, sStartConnectionUid)
2052
            Else
2053
                CheckConnectionSymbolToSymbol(oConn3Rows, dConn3_x, dConn3_y, oStartLMConnector)
2054
            End If
2055

    
2056
            If sConn2Type = "Line" Then
2057
                CheckConnectionLine(dConn4_x, dConn4_y, oEndLMConnector, sEndConnectionUid)
2058
            Else
2059
                CheckConnectionSymbolToSymbol(oConn4Rows, dConn4_x, dConn4_y, oEndLMConnector)
2060
            End If
2061

    
2062
            sFirstUid = CheckExistModeling(oConn3Rows(0))
2063
            sSecondUid = CheckExistModeling(oConn4Rows(0))
2064

    
2065
        ElseIf sConn3Type <> "" And sConn4Type = "" Then
2066
            If sConn1Type = "Line" Then
2067
                CheckConnectionLine(dConn3_x, dConn3_y, oStartLMConnector, sStartConnectionUid)
2068
            Else
2069
                CheckConnectionSymbolToSymbol(oConn3Rows, dConn3_x, dConn3_y, oStartLMConnector)
2070
                dOriginal_x = dConn3_x
2071
                dOriginal_y = dConn3_y
2072
            End If
2073

    
2074
            sFirstUid = CheckExistModeling(oConn3Rows(0))
2075

    
2076
        ElseIf sConn3Type = "" And sConn4Type <> "" Then
2077
            If sConn2Type = "Line" Then
2078
                CheckConnectionLine(dConn4_x, dConn4_y, oEndLMConnector, sEndConnectionUid)
2079
            Else
2080
                CheckConnectionSymbolToSymbol(oConn4Rows, dConn4_x, dConn4_y, oEndLMConnector)
2081
                dOriginal_x = dConn4_x
2082
                dOriginal_y = dConn4_y
2083
            End If
2084

    
2085
            sSecondUid = CheckExistModeling(oConn4Rows(0))
2086

    
2087
        Else
2088

    
2089
        End If
2090

    
2091
        If sFirstUid <> "" And sSecondUid <> "" Then
2092
            sReturnUid = sSecondUid
2093
        ElseIf sFirstUid <> "" And sSecondUid = "" Then
2094
            sReturnUid = sFirstUid
2095
        ElseIf sFirstUid <> "" And sSecondUid = "" Then
2096
            sReturnUid = sFirstUid
2097
        ElseIf sSecondUid <> "" And sFirstUid = "" Then
2098
            sReturnUid = sSecondUid
2099
        ElseIf sSecondUid <> "" And sFirstUid = "" Then
2100
            sReturnUid = sSecondUid
2101
        Else
2102
            sReturnUid = ""
2103
        End If
2104

    
2105
        If sSymbolCompType.ToUpper() = _SYMBOL_INSTUMENT.ToUpper() Then
2106
            oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dOriginal_x, dOriginal_y,, dAngle)
2107
            oCurrentSymbolRow(_XML_SYMBOL_LMSYMBOL) = oLMSymbol
2108
        Else
2109
            If oStartLMConnector IsNot Nothing And oEndLMConnector IsNot Nothing Then
2110
                oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dOriginal_x, dOriginal_y,, dAngle)
2111
                oCurrentSymbolRow(_XML_SYMBOL_LMSYMBOL) = oLMSymbol
2112
            ElseIf oStartLMConnector IsNot Nothing And oEndLMConnector Is Nothing Then
2113
                oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dOriginal_x, dOriginal_y,, dAngle,,
2114
                            TargetItem:=oStartLMConnector.AsLMAItem)
2115
                oCurrentSymbolRow(_XML_SYMBOL_LMSYMBOL) = oLMSymbol
2116
            ElseIf oStartLMConnector Is Nothing And oEndLMConnector IsNot Nothing Then
2117
                oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dOriginal_x, dOriginal_y,, dAngle,,
2118
                TargetItem:=oEndLMConnector.AsLMAItem)
2119
                oCurrentSymbolRow(_XML_SYMBOL_LMSYMBOL) = oLMSymbol
2120
            Else
2121
                oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dOriginal_x, dOriginal_y,, dAngle)
2122
                oCurrentSymbolRow(_XML_SYMBOL_LMSYMBOL) = oLMSymbol
2123
            End If
2124
        End If
2125

    
2126
        '모델링 된 Symbol 데이터 테이블 저장
2127
        Dim oAddRow As DataRow = _ModelingSymbol_Dt.NewRow
2128
        oAddRow(_XML_SYMBOL_SPID) = oLMSymbol.ModelItemID
2129
        oAddRow(_XML_SYMBOL_LMSYMBOL) = oLMSymbol
2130
        oAddRow(_XML_SYMBOL_DRAWING_TF) = "TRUE"
2131
        oAddRow(_XML_SYMBOL_CENTERPOINT_X) = dOriginal_x
2132
        oAddRow(_XML_SYMBOL_CENTERPOINT_Y) = dOriginal_y
2133
        oAddRow(_XML_SYMBOL_MIN_X) = oCurrentSymbolRow(_XML_SYMBOL_MIN_X)
2134
        oAddRow(_XML_SYMBOL_MAX_X) = oCurrentSymbolRow(_XML_SYMBOL_MAX_X)
2135
        oAddRow(_XML_SYMBOL_MIN_Y) = oCurrentSymbolRow(_XML_SYMBOL_MIN_Y)
2136
        oAddRow(_XML_SYMBOL_MAX_Y) = oCurrentSymbolRow(_XML_SYMBOL_MAX_Y)
2137
        _ModelingSymbol_Dt.Rows.Add(oAddRow)
2138

    
2139
        If sChildItem <> "" Then
2140
            Dim sConn1_Systempath As String = ""
2141
            Dim sConn2_Systempath As String = ""
2142
            Dim sConn1_Angle As Double = 0
2143
            Dim sConn2_Angle As Double = 0
2144

    
2145
            For Each sDirection In sChildItem.Split("/")
2146
                Dim iType As Integer = 0
2147
                For Each sType In sDirection.Split(",")
2148
                    If sConn1_Systempath = "" Then
2149

    
2150
                        If iType = 0 Then
2151
                            sConn1_Angle = GetChildSymbolDirection(sType)
2152
                            iType = iType + 1
2153
                        Else
2154
                            Dim sStartpoint As String = oCurrentSymbolRow(_XML_SYMBOL_Conn1_Point).ToString()
2155
                            ConvertPointBystring(sStartpoint, dConn1_x, dConn1_y)
2156
                            ConvertPointByImage(dConn1_x, dConn1_y, _IMG_X, _IMG_Y)
2157
                            sConn1_Systempath = GetDataFromMappingDB(sType, _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH)
2158
                            Dim dChildConn1_x As Double = 0
2159
                            Dim dChildConn1_y As Double = 0
2160

    
2161
                            If oLMSymbol IsNot Nothing Then
2162
                                _Placement.PIDConnectPointLocation(oLMSymbol, 1, dChildConn1_x, dChildConn1_y)
2163
                                _Placement.PIDPlaceSymbol(sConn1_Systempath, dChildConn1_x, dChildConn1_y,, sConn1_Angle,,
2164
                                 TargetItem:=oLMSymbol.AsLMAItem)
2165
                            Else
2166
                                _Placement.PIDPlaceSymbol(sConn1_Systempath, dConn1_x, dConn1_y,, sConn1_Angle,,)
2167
                            End If
2168
                        End If
2169

    
2170
                    Else
2171
                        If iType = 0 Then
2172
                            sConn2_Angle = GetChildSymbolDirection(sType)
2173
                            iType = iType + 1
2174
                        Else
2175
                            Dim sEndPoint As String = oCurrentSymbolRow(_XML_SYMBOL_Conn2_Point).ToString()
2176
                            ConvertPointBystring(sEndPoint, dConn2_x, dConn2_y)
2177
                            ConvertPointByImage(dConn2_x, dConn2_y, _IMG_X, _IMG_Y)
2178
                            sConn2_Systempath = GetDataFromMappingDB(sType, _DB_COLUMN_MAPPING_SPPID_SYSTEMPATH)
2179

    
2180
                            Dim dChildConn2_x As Double = 0
2181
                            Dim dChildConn2_y As Double = 0
2182

    
2183
                            If oLMSymbol IsNot Nothing Then
2184
                                _Placement.PIDConnectPointLocation(oLMSymbol, 2, dChildConn2_x, dChildConn2_y)
2185
                                _Placement.PIDPlaceSymbol(sConn1_Systempath, dChildConn2_x, dChildConn2_y,, sConn2_Angle,,
2186
                                        TargetItem:=oLMSymbol.AsLMAItem)
2187
                            Else
2188
                                _Placement.PIDPlaceSymbol(sConn2_Systempath, dChildConn2_x, dChildConn2_y,, sConn2_Angle,,)
2189
                            End If
2190

    
2191
                        End If
2192
                    End If
2193
                Next
2194
            Next
2195
        End If
2196

    
2197
        AddProgress()
2198

    
2199
        SetListBoxItems(ListBox_Result, "Place Fitting.." & sUid & " (" & dOriginal_x & "," & dOriginal_y & ")..." & _iFittingcnt & " count ")
2200
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Fitting : " & sUid)
2201
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "LineNo : " & sLineNoText)
2202
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "ModelingType : " & iModelingType)
2203
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Conn1_Point : " & dConn1_x & "," & dConn1_y)
2204
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Conn2_Point : " & dConn2_x & "," & dConn2_y)
2205
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Conn3_Point : " & dConn3_x & "," & dConn3_y)
2206
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Conn4_Point : " & dConn4_x & "," & dConn4_y)
2207
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection1 : " & oCurrentSymbolRow(_XML_SYMBOL_Conn1_Uid).ToString())
2208
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection2 : " & oCurrentSymbolRow(_XML_SYMBOL_Conn2_Uid).ToString())
2209
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection3 : " & oCurrentSymbolRow(_XML_SYMBOL_Conn3_Uid).ToString())
2210
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection4 : " & oCurrentSymbolRow(_XML_SYMBOL_Conn4_Uid).ToString())
2211
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
2212
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "OriginalPoint : " & dOriginal_x & "," & dOriginal_y)
2213
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Fitting Count : " & _iFittingcnt)
2214
        _iFittingcnt = _iFittingcnt + 1
2215
        oCurrentSymbolRow(_XML_SYMBOL_DRAWING_TF) = "TRUE"
2216

    
2217
        Dim oAttributeRow() As DataRow
2218
        oAttributeRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sUid + "'")
2219
        If oAttribute_Dt.Rows.Count > 0 Then
2220

    
2221
            If sSymbolCompType.ToUpper() = _SYMBOL_INSTUMENT.ToUpper() Then
2222
                Dim oInstrument As LMInstrument
2223
                oInstrument = _Placement.PIDDataSource.GetInstrument(oLMSymbol.ModelItemID)
2224
                Try
2225
                    If oAttributeRow.Length > 0 Then
2226
                        For Each oAttribute In oAttributeRow
2227
                            Try
2228
                                Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
2229
                                Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
2230
                                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
2231
                                oInstrument.Attributes(sSPPIDAttribute).Value = sPIDValue
2232
                            Catch ex As Exception
2233
                            End Try
2234
                        Next
2235
                        oInstrument.Commit()
2236
                    End If
2237
                Catch ex As Exception
2238
                End Try
2239
            Else
2240
                Try
2241
                    If oAttributeRow.Length > 0 And oLMSymbol IsNot Nothing Then
2242
                        For Each oAttribute In oAttributeRow
2243
                            Try
2244
                                Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
2245
                                Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
2246
                                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
2247
                                oLMSymbol.Attributes(sSPPIDAttribute).Value = sPIDValue
2248

    
2249
                            Catch ex As Exception
2250
                            End Try
2251
                        Next
2252
                        oLMSymbol.Commit()
2253
                    End If
2254
                Catch ex As Exception
2255
                End Try
2256
            End If
2257
        End If
2258

    
2259
        Return sReturnUid
2260
    End Function
2261
    Private Function GetChildSymbolDirection(ByVal sDirection As String) As Double
2262
        Dim sReturnDirection As String = ""
2263
        If sDirection.ToUpper() = "RIGHT" Then
2264
            Return 3.14
2265
        ElseIf sDirection.ToUpper() = "LEFT" Then
2266
            Return 0
2267
        ElseIf sDirection.ToUpper = "DOWN" Then
2268
            Return 1.57
2269
        ElseIf sDirection.ToUpper() = "UP" Then
2270
            Return 4.71
2271
        Else
2272
            Return 0
2273
        End If
2274
    End Function
2275

    
2276
    Private Function CheckExistModeling(ByVal oRow As DataRow) As String
2277
        If oRow(_XML_LINE_DRAWING_TF).ToString() = "FALSE" And oRow(_XML_LINE_Check).ToString() = "TRUE" Then
2278
            Return oRow(_XML_LINE_UID).ToString()
2279
        End If
2280
        Return String.Empty
2281
    End Function
2282

    
2283

    
2284
    Private Sub ConvertPoint(ByVal sOriginalPoint As String, ByRef dConn1_x As Double, ByRef dConn1_y As Double)
2285
        ConvertPointBystring(sOriginalPoint, dConn1_x, dConn1_y)
2286
        ConvertPointByImage(dConn1_x, dConn1_y, _IMG_X, _IMG_Y)
2287
    End Sub
2288

    
2289
    Private Function FinalLineModeling(ByVal oCurrentLineRow As DataRow,
2290
                              ByVal oLine_Dt As DataTable, ByVal oSymbol_Dt As DataTable,
2291
                                  ByVal oAttribute_Dt As DataTable) As String
2292
        Dim sReturnUid As String = ""
2293
        Try
2294
            Dim bCheckBranchItem As Boolean = False
2295
            Dim dCenterPos_x As Double = 0.0
2296
            Dim dCenterPos_y As Double = 0.0
2297
            Dim objItem As LMAItem
2298
            Dim sUid As String = oCurrentLineRow(_XML_LINE_UID).ToString()
2299
            Dim sLineType As String = oCurrentLineRow(_XML_LINE_TYPE).ToString()
2300
            Dim sSystemPath As String = GetPipeType(sLineType)
2301
            Dim sLineNoText As String = oCurrentLineRow(_XML_LINENO_TEXT).ToString()
2302
            Dim sLineNoUid As String = oCurrentLineRow(_XML_LINE_LINENOUID).ToString()
2303
            Dim dStart_Dwg_x As Double = oCurrentLineRow(_XML_LINE_DWG_STARTPOINT_X)
2304
            Dim dStart_Dwg_y As Double = oCurrentLineRow(_XML_LINE_DWG_STARTPOINT_Y)
2305
            Dim dEnd_Dwg_x As Double = oCurrentLineRow(_XML_LINE_DWG_ENDPOINT_X)
2306
            Dim dEnd_Dwg_y As Double = oCurrentLineRow(_XML_LINE_DWG_ENDPOINT_Y)
2307
            Dim sPreFlowDirection As String = ""
2308
            Dim sFlowDirection As String = oCurrentLineRow(_XML_LINE_FlowDirection)
2309
            Dim sPreConn1Direction As String = ""
2310
            Dim sPreConn2Direction As String = ""
2311
            Dim sDirection As String = oCurrentLineRow(_XML_LINE_Direction)
2312
            dCenterPos_x = Math.Abs(dStart_Dwg_x + dEnd_Dwg_x) / 2
2313
            dCenterPos_y = Math.Abs(dStart_Dwg_y + dEnd_Dwg_y) / 2
2314
            Dim oPidDataSource As LMADataSource = Nothing
2315
            Try
2316
                oPidDataSource = _Placement.PIDDataSource
2317
            Catch ex As Exception
2318
                CheckOpenDrawing()
2319
                oPidDataSource = _Placement.PIDDataSource
2320
            End Try
2321
            'Connection 정보 체크, 모델링 되어 있는지 유무
2322
            '양 커넥션의 모델링 유무를 체크한다.
2323
            Dim sConn1Uid As String = oCurrentLineRow(_XML_LINE_Conn1_Uid).ToString()
2324
            Dim sConn2Uid As String = oCurrentLineRow(_XML_LINE_Conn2_Uid).ToString()
2325
            Dim sConn1Type As String = ""
2326
            Dim sConn2Type As String = ""
2327
            Dim oConn1Rows() As DataRow = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "] = '" & sConn1Uid & "'")
2328
            If oConn1Rows.Length = 0 Then
2329
                oConn1Rows = oLine_Dt.Select("[" & _XML_LINE_UID & "] = '" & sConn1Uid & "'")
2330
                If oConn1Rows.Length = 1 Then
2331
                    sConn1Type = "Line"
2332
                End If
2333
            Else
2334
                Dim oOriginalPoint As String = oConn1Rows(0)(_XML_SYMBOL_ORIGINALPOINT)
2335
                ConvertPointBystring(oOriginalPoint, dStart_Dwg_x, dStart_Dwg_y)
2336
                ConvertPointByImage(dStart_Dwg_x, dStart_Dwg_y, _IMG_X, _IMG_Y)
2337
                oCurrentLineRow(_XML_LINE_DWG_STARTPOINT_X) = dStart_Dwg_x
2338
                oCurrentLineRow(_XML_LINE_DWG_STARTPOINT_Y) = dStart_Dwg_y
2339
                sConn1Type = "Symbol"
2340
            End If
2341
            Dim oConn2Rows() As DataRow = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "] = '" & sConn2Uid & "'")
2342
            If oConn2Rows.Length = 0 Then
2343
                oConn2Rows = oLine_Dt.Select("[" & _XML_LINE_UID & "] = '" & sConn2Uid & "'")
2344
                If oConn2Rows.Length = 1 Then
2345
                    sConn2Type = "Line"
2346
                End If
2347
            Else
2348
                Dim oOriginalPoint As String = oConn2Rows(0)(_XML_SYMBOL_ORIGINALPOINT)
2349
                ConvertPointBystring(oOriginalPoint, dEnd_Dwg_x, dEnd_Dwg_y)
2350
                ConvertPointByImage(dEnd_Dwg_x, dEnd_Dwg_y, _IMG_X, _IMG_Y)
2351
                oCurrentLineRow(_XML_LINE_DWG_ENDPOINT_X) = dEnd_Dwg_x
2352
                oCurrentLineRow(_XML_LINE_DWG_ENDPOINT_Y) = dEnd_Dwg_y
2353
                sConn2Type = "Symbol"
2354
            End If
2355
            Dim sConn1LineNo As String = ""
2356
            Dim sConn2LineNo As String = ""
2357
            Dim oLMConnector As LMConnector = Nothing
2358
            Dim oStartLMConnector As LMConnector = Nothing
2359
            Dim oEndLMConnector As LMConnector = Nothing
2360
            Dim oLMSymbol1 As LMSymbol = Nothing
2361
            Dim oLMSymbol2 As LMSymbol = Nothing
2362
            Dim objInputs As PlaceRunInputs
2363
            objInputs = New PlaceRunInputs
2364
            Dim iModelingType As Integer = 0
2365
            If sConn1Type = "Line" And sConn2Type = "Line" Then
2366
                iModelingType = 1
2367
            ElseIf sConn1Type = "Line" And sConn2Type = "Symbol" Then
2368
                iModelingType = 1
2369
            ElseIf sConn1Type = "Symbol" And sConn2Type = "Line" Then
2370
                iModelingType = 1
2371
            ElseIf sConn1Type = "Symbol" And sConn2Type = "Symbol" Then
2372
                iModelingType = 1
2373
            ElseIf sConn1Type = "Line" And sConn2Type = "" Then
2374
                iModelingType = 2
2375
            ElseIf sConn1Type = "Symbol" And sConn2Type = "" Then
2376
                iModelingType = 2
2377
            ElseIf sConn1Type = "" And sConn2Type = "Line" Then
2378
                iModelingType = 3
2379
            ElseIf sConn1Type = "" And sConn2Type = "Symbol" Then
2380
                iModelingType = 3
2381
            Else
2382
                iModelingType = 4
2383
            End If
2384
            Dim dPreConnX As Double = 0
2385
            Dim dPreConnY As Double = 0
2386
            Dim sStartConnectionUid As String = ""
2387
            Dim sEndConnectionUid As String = ""
2388
            Dim bAlreadyCheckBranchLine As Boolean = False
2389
            '브런치라인이 먼저있는상태에서 메인라인을 그릴경우..해당되는 브런치라인 수 만큼 라인을 따로 생성 
2390
            If CheckAlreadyBranchLine(sSystemPath, dStart_Dwg_x, dStart_Dwg_y, dEnd_Dwg_x, dEnd_Dwg_y) = False Then
2391

    
2392
                CheckConnectionLine(dStart_Dwg_x, dStart_Dwg_y, oStartLMConnector, sStartConnectionUid)
2393
                If oStartLMConnector Is Nothing Then
2394
                    bCheckBranchItem = UpdateCheckBranchLine(dStart_Dwg_x, dStart_Dwg_y, oStartLMConnector, sStartConnectionUid)
2395
                    If oStartLMConnector Is Nothing Then
2396
                        oLMSymbol1 = CheckConnectionSymbolToLine(oConn1Rows, dStart_Dwg_x, dStart_Dwg_y, dCenterPos_x, dCenterPos_y, oStartLMConnector)
2397
                        If oLMSymbol1 IsNot Nothing Then
2398
                            sConn1Type = "Symbol"
2399
                        Else
2400
                            sConn1Type = ""
2401
                        End If
2402
                    Else
2403
                        sConn1Type = "Line"
2404
                    End If
2405
                Else
2406
                    sConn1Type = "Line"
2407
                End If
2408
                CheckConnectionLine(dEnd_Dwg_x, dEnd_Dwg_y, oEndLMConnector, sEndConnectionUid)
2409
                If oEndLMConnector Is Nothing Then
2410
                    bCheckBranchItem = UpdateCheckBranchLine(dEnd_Dwg_x, dEnd_Dwg_y, oEndLMConnector, sEndConnectionUid)
2411
                    If oEndLMConnector Is Nothing Then
2412
                        oLMSymbol2 = CheckConnectionSymbolToLine(oConn2Rows, dEnd_Dwg_x, dEnd_Dwg_y, dCenterPos_x, dCenterPos_y, oEndLMConnector)
2413
                        If oLMSymbol2 IsNot Nothing Then
2414
                            sConn2Type = "Symbol"
2415
                        End If
2416
                    Else
2417
                        sConn2Type = "Line"
2418
                    End If
2419
                Else
2420
                    sConn2Type = "Line"
2421
                End If
2422
                Dim sFirstUid As String = ""
2423
                Dim sSecondUid As String = ""
2424
                Try
2425
                    If oStartLMConnector Is Nothing And oEndLMConnector Is Nothing Then
2426
                        If oLMSymbol1 Is Nothing Then
2427
                            objInputs.AddPoint(dStart_Dwg_x, dStart_Dwg_y)
2428
                        Else
2429
                            objInputs.AddSymbolTarget(oLMSymbol1, dStart_Dwg_x, dStart_Dwg_y)
2430
                        End If
2431

    
2432
                        If oLMSymbol2 Is Nothing Then
2433
                            objInputs.AddPoint(dEnd_Dwg_x, dEnd_Dwg_y)
2434
                        Else
2435
                            objInputs.AddSymbolTarget(oLMSymbol2, dEnd_Dwg_x, dEnd_Dwg_y)
2436
                        End If
2437

    
2438
                    ElseIf oStartLMConnector IsNot Nothing And oEndLMConnector Is Nothing Then
2439
                        If sConn1Type = "Line" Then
2440
                            objInputs.AddConnectorTarget(oStartLMConnector, dStart_Dwg_x, dStart_Dwg_y)
2441
                        Else
2442
                            objInputs.AddSymbolTarget(oLMSymbol1, dStart_Dwg_x, dStart_Dwg_y)
2443
                        End If
2444
                        If oLMSymbol2 Is Nothing Then
2445
                            objInputs.AddPoint(dEnd_Dwg_x, dEnd_Dwg_y)
2446
                        Else
2447
                            objInputs.AddSymbolTarget(oLMSymbol2, dEnd_Dwg_x, dEnd_Dwg_y)
2448
                        End If
2449

    
2450
                    ElseIf oStartLMConnector Is Nothing And oEndLMConnector IsNot Nothing Then
2451
                        If sConn2Type = "Line" Then
2452
                            objInputs.AddConnectorTarget(oEndLMConnector, dEnd_Dwg_x, dEnd_Dwg_y)
2453
                        Else
2454
                            objInputs.AddSymbolTarget(oLMSymbol2, dEnd_Dwg_x, dEnd_Dwg_y)
2455
                        End If
2456
                        If oLMSymbol1 Is Nothing Then
2457
                            objInputs.AddPoint(dStart_Dwg_x, dStart_Dwg_y)
2458
                        Else
2459
                            objInputs.AddSymbolTarget(oLMSymbol1, dStart_Dwg_x, dStart_Dwg_y)
2460
                        End If
2461

    
2462
                    Else
2463
                        If sConn1Type = "Line" Then
2464
                            objInputs.AddConnectorTarget(oStartLMConnector, dStart_Dwg_x, dStart_Dwg_y)
2465
                        Else
2466
                            objInputs.AddSymbolTarget(oLMSymbol1, dStart_Dwg_x, dStart_Dwg_y)
2467
                        End If
2468
                        If sConn2Type = "Line" Then
2469
                            objInputs.AddConnectorTarget(oEndLMConnector, dEnd_Dwg_x, dEnd_Dwg_y)
2470
                        Else
2471
                            objInputs.AddSymbolTarget(oLMSymbol2, dEnd_Dwg_x, dEnd_Dwg_y)
2472
                        End If
2473

    
2474
                    End If
2475
                    If sConn1Type <> "" And sConn2Type <> "" Then
2476
                        If oConn1Rows.Count > 0 Then
2477
                            sFirstUid = CheckExistModeling(oConn1Rows(0))
2478
                        End If
2479
                        If oConn2Rows.Count > 0 Then
2480
                            sSecondUid = CheckExistModeling(oConn2Rows(0))
2481
                        End If
2482

    
2483
                    ElseIf sConn1Type <> "" And sConn2Type = "" Then
2484
                        If oConn1Rows.Count > 0 Then
2485
                            sFirstUid = CheckExistModeling(oConn1Rows(0))
2486
                        End If
2487

    
2488
                    ElseIf sConn1Type = "" And sConn2Type <> "" Then
2489
                        If oConn2Rows.Count > 0 Then
2490
                            sSecondUid = CheckExistModeling(oConn2Rows(0))
2491
                        End If
2492

    
2493
                    End If
2494

    
2495
                    If sFirstUid <> "" And sSecondUid <> "" Then
2496
                        sReturnUid = sSecondUid
2497
                    ElseIf sFirstUid = "" And sSecondUid <> "" Then
2498
                        sReturnUid = sSecondUid
2499
                    ElseIf sFirstUid <> "" And sSecondUid = "" Then
2500
                        sReturnUid = sFirstUid
2501
                    Else
2502
                        sReturnUid = ""
2503
                    End If
2504
                    _iPipecnt = _iPipecnt + 1
2505

    
2506
                    '배관 모델링
2507
                    Dim oCurrentConnector As LMConnector = LineModeling(objInputs, sSystemPath)
2508

    
2509
                    If oCurrentConnector IsNot Nothing Then
2510
                        oCurrentLineRow(_XML_LINE_LMCONNECTOR) = oCurrentConnector
2511
                        oCurrentLineRow(_XML_LINE_DRAWING_TF) = "TRUE"
2512
                        '로그 출력
2513
                        AddLog(sUid, sSystemPath, dStart_Dwg_x, dStart_Dwg_y, dEnd_Dwg_x, dEnd_Dwg_y, sLineNoText, sConn1Uid, sConn2Uid)
2514
                        Dim oPipeRun As LMPipeRun = oPidDataSource.GetPipeRun(oCurrentConnector.ModelItemID)
2515
                        '배관 속성 입력
2516
                        AddAttribute(oPipeRun, oAttribute_Dt, sLineNoUid)
2517

    
2518
                        Dim sID_1 As String = ""
2519
                        Dim sID_2 As String = ""
2520
                        Dim oAddConnector As LMConnector = Nothing
2521
                        If oStartLMConnector IsNot Nothing Then
2522
                            sID_1 = oStartLMConnector.ModelItemID
2523
                            sID_2 = oCurrentConnector.ModelItemID
2524
                            oAddConnector = oStartLMConnector
2525
                        ElseIf oEndLMConnector IsNot Nothing Then
2526
                            sID_1 = oEndLMConnector.ModelItemID
2527
                            sID_2 = oCurrentConnector.ModelItemID
2528
                            oAddConnector = oEndLMConnector
2529
                        End If
2530
                        If sID_1 <> "" And sID_2 <> "" Then
2531
                            'PipeRun 합치기
2532

    
2533

    
2534
                            If bCheckBranchItem Then
2535
                                '모델링 된 PipeLine 데이터 테이블 저장
2536
                                AddModelingDT(sUid, oCurrentConnector.ModelItemID, oCurrentConnector, dStart_Dwg_x, dStart_Dwg_y, dEnd_Dwg_x, dEnd_Dwg_y)
2537
                            Else
2538
                                JoinPipeRun(sID_1, sID_2)
2539
                                '모델링 된 PipeLine 데이터 테이블 저장
2540
                                AddModelingDT(sUid, sID_1, oAddConnector, dStart_Dwg_x, dStart_Dwg_y, dEnd_Dwg_x, dEnd_Dwg_y)
2541
                            End If
2542
                        Else
2543
                            '모델링 된 PipeLine 데이터 테이블 저장
2544
                            AddModelingDT(sUid, oCurrentConnector.ModelItemID, oCurrentConnector, dStart_Dwg_x, dStart_Dwg_y, dEnd_Dwg_x, dEnd_Dwg_y)
2545
                        End If
2546
                        If bCheckBranchItem = False Then
2547
                            '//2018.09.07 LMControl에 따라서 inconsitency가 달라지는듯 확인
2548
                            If sStartConnectionUid <> "" Then
2549
                                Dim oChangeRow() As DataRow = _ModelingLine_Dt.Select(_XML_LINE_UID & " = '" & sStartConnectionUid & "'")
2550
                                If oChangeRow.Length = 1 Then
2551
                                    oChangeRow(0)(_XML_LINE_SPID) = sID_1
2552
                                    oChangeRow(0)(_XML_LINE_LMCONNECTOR) = oAddConnector
2553
                                End If
2554
                            End If
2555
                            If sEndConnectionUid <> "" Then
2556
                                Dim oChangeRow() As DataRow = _ModelingLine_Dt.Select(_XML_LINE_UID & " = '" & sEndConnectionUid & "'")
2557
                                If oChangeRow.Length = 1 Then
2558
                                    oChangeRow(0)(_XML_LINE_SPID) = sID_1
2559
                                    oChangeRow(0)(_XML_LINE_LMCONNECTOR) = oAddConnector
2560
                                End If
2561
                            End If
2562
                        End If
2563

    
2564
                    Else
2565
                        sReturnUid = ""
2566
                    End If
2567
                Catch ex As Exception
2568
                End Try
2569
            End If
2570
        Catch ex As Exception
2571
        End Try
2572
        Return sReturnUid
2573
        '현재 Uid 모델링
2574
    End Function
2575
    Private Sub AddLog(ByVal sUid As String, ByVal sSystemPath As String,
2576
                             ByVal dStart_Dwg_x As Double, ByVal dStart_Dwg_y As Double, ByVal dEnd_Dwg_x As Double, ByVal dEnd_Dwg_y As Double,
2577
                       ByVal sLineNoText As String, ByVal sConn1Uid As String, ByVal sConn2Uid As String)
2578
        SetListBoxItems(ListBox_Result, "Place Pipe.." & sUid & " (" & dStart_Dwg_x & "," & dStart_Dwg_y & ") - (" & dEnd_Dwg_x & "," & dEnd_Dwg_y & ")..." & _iPipecnt & " count ")
2579
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Pipe : " & sUid)
2580
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "LineNo : " & sLineNoText)
2581
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection1 : " & sConn1Uid)
2582
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection2 : " & sConn2Uid)
2583
        'ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
2584
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "StartPoint : " & dStart_Dwg_x & "," & dStart_Dwg_y)
2585
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "EndPoint : " & dEnd_Dwg_x & "," & dEnd_Dwg_y)
2586
        ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Pipe Count : " & _iPipecnt)
2587
    End Sub
2588

    
2589
    Private Sub AddAttribute(ByVal oPipeRun As LMPipeRun, ByVal oAttribute_Dt As DataTable, ByVal sLineNoUid As String)
2590
        Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
2591
        If oAttributeRow.Length > 0 Then
2592
            For Each oAttribute In oAttributeRow
2593
                Try
2594
                    Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
2595
                    Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
2596
                    If sPIDValue.Contains("'") Then
2597
                        sPIDValue = sPIDValue.Replace("'", """")
2598
                    End If
2599
                    Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
2600
                    oPipeRun.Attributes(sSPPIDAttribute).Value = sPIDValue
2601
                Catch ex As Exception
2602
                End Try
2603
            Next
2604
            oPipeRun.Commit()
2605
        End If
2606
    End Sub
2607

    
2608
    Private Sub AddModelingDT(ByVal sUid As String, ByVal sModelID As String, ByVal oCurrentConnector As LMConnector,
2609
                              ByVal dStart_Dwg_x As Double, ByVal dStart_Dwg_y As Double,
2610
                              ByVal dEnd_Dwg_x As Double, ByVal dEnd_Dwg_y As Double)
2611
        Dim oAddRow As DataRow = _ModelingLine_Dt.NewRow
2612
        oAddRow(_XML_LINE_UID) = sUid
2613
        oAddRow(_XML_LINE_SPID) = sModelID
2614
        oAddRow(_XML_LINE_LMCONNECTOR) = oCurrentConnector
2615
        oAddRow(_XML_LINE_DRAWING_TF) = "TRUE"
2616
        oAddRow(_XML_LINE_DWG_STARTPOINT_X) = dStart_Dwg_x
2617
        oAddRow(_XML_LINE_DWG_STARTPOINT_Y) = dStart_Dwg_y
2618
        oAddRow(_XML_LINE_DWG_ENDPOINT_X) = dEnd_Dwg_x
2619
        oAddRow(_XML_LINE_DWG_ENDPOINT_Y) = dEnd_Dwg_y
2620
        _ModelingLine_Dt.Rows.Add(oAddRow)
2621
    End Sub
2622

    
2623
    Private Function JoinPipeRun(ByVal sID_1 As String, ByVal sID_2 As String) As Boolean
2624
        Try
2625
            Dim objSurvivorItem As LMAItem = Nothing
2626
            Dim oPipeRun1 As LMPipeRun = _Placement.PIDDataSource.GetPipeRun(sID_1)
2627
            Dim oPipeRun2 As LMPipeRun = _Placement.PIDDataSource.GetPipeRun(sID_2)
2628
            _Placement.PIDJoinRuns(oPipeRun1, oPipeRun2)
2629
            Return True
2630
        Catch ex As Exception
2631
            Return False
2632
        End Try
2633
    End Function
2634

    
2635

    
2636
    Private Function LineModeling(ByVal objInputs As PlaceRunInputs, ByVal sSystemPath As String) As LMConnector
2637
        Dim oCurrentConnector As LMConnector = Nothing
2638
        Dim objItem As LMAItem
2639
        objItem = _Placement.PIDCreateItem(sSystemPath)
2640
        Try
2641
            oCurrentConnector = _Placement.PIDPlaceRun(objItem, objInputs)
2642
            AddProgress()
2643
        Catch ex As Exception
2644
        End Try
2645
        Return oCurrentConnector
2646
    End Function
2647

    
2648
    Private Sub InstumentLineModeling(ByVal CLineNo As Line_no, ByVal oNode As TreeNode)
2649
        If CLineNo IsNot Nothing Then
2650
            Dim oLine_Dt As DataTable = CLineNo.Dt_Line
2651
            Dim oSymbol_Dt As DataTable = CLineNo.Dt_Symbol
2652
            Dim oAttribute_Dt As DataTable = CLineNo.Dt_Attribute
2653
            Dim oDrawLinenoLabel As Boolean = False
2654
            For Each oSymbolNode As TreeNode In oNode.Nodes
2655
                If oSymbolNode.Checked Then
2656
                    Try
2657
                        Dim sUid As String = oSymbolNode.Name
2658
                        Dim sLineNoUid As String = CLineNo.Uid
2659
                        Dim sReturnUid = sUid
2660
                        '  FinalModeling(sUid, oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2661
                        While True
2662
                            Dim oLineRows As DataRow() = oLine_Dt.Select(_XML_LINE_UID & " = '" & sReturnUid & "' And [" & _XML_SYMBOL_DRAWING_TF & "] = 'False' And [" &
2663
                                               _XML_SYMBOL_Check & "] = 'TRUE' And [" & _XML_LINE_ValieLine & "] = 'True'")
2664
                            If oLineRows.Count > 0 Then
2665
                                Dim sPipeType As String = oLineRows(0)(_XML_LINE_TYPE).ToString()
2666
                                If sPipeType.ToUpper() <> "PRIMARY" Then
2667
                                    sReturnUid = FinalLineModeling(oLineRows(0), oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2668
                                Else
2669
                                    sReturnUid = ""
2670
                                End If
2671
                            Else
2672
                                sReturnUid = ""
2673
                            End If
2674
                            If sReturnUid = "" Then
2675
                                Exit While
2676
                            End If
2677
                        End While
2678
                    Catch ex As Exception
2679
                    End Try
2680
                End If
2681
            Next
2682
        End If
2683
    End Sub
2684

    
2685
    Private Sub PipeLineModeling(ByVal CLineNo As Line_no, ByVal oNode As TreeNode)
2686
        If CLineNo IsNot Nothing Then
2687
            Dim oLine_Dt As DataTable = CLineNo.Dt_Line
2688
            Dim oSymbol_Dt As DataTable = CLineNo.Dt_Symbol
2689
            Dim oAttribute_Dt As DataTable = CLineNo.Dt_Attribute
2690
            Dim oDrawLinenoLabel As Boolean = False
2691
            Try
2692
                ManualCheckNode(oLine_Dt)
2693
                ManualCheckNode(oSymbol_Dt)
2694
            Catch ex As Exception
2695
            End Try
2696
            For Each oSymbolNode As TreeNode In oNode.Nodes
2697
                If oSymbolNode.Checked Then
2698
                    Try
2699
                        Dim sUid As String = oSymbolNode.Name
2700
                        Dim sLineNoUid As String = CLineNo.Uid
2701
                        Dim sReturnUid = sUid
2702
                        '  FinalModeling(sUid, oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2703
                        While True
2704
                            Dim oLineRows As DataRow() = oLine_Dt.Select(_XML_LINE_UID & " = '" & sReturnUid & "' And [" & _XML_SYMBOL_DRAWING_TF & "] = 'False' And [" &
2705
                                               _XML_SYMBOL_Check & "] = 'TRUE' And [" & _XML_LINE_ValieLine & "] = 'True'")
2706
                            If oLineRows.Count > 0 Then
2707
                                Dim sPipeType As String = oLineRows(0)(_XML_LINE_TYPE).ToString()
2708
                                If sPipeType.ToUpper() = "PRIMARY" Then
2709
                                    sReturnUid = FinalLineModeling(oLineRows(0), oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2710
                                Else
2711
                                    sReturnUid = ""
2712
                                End If
2713

    
2714
                            Else
2715
                                sReturnUid = ""
2716
                            End If
2717
                            If sReturnUid = "" Then
2718
                                Exit While
2719
                            End If
2720
                        End While
2721
                    Catch ex As Exception
2722
                    End Try
2723
                End If
2724
            Next
2725
        End If
2726
    End Sub
2727

    
2728
    Private Sub InstrumentSymbolModeling(ByVal CLineNo As Line_no, ByVal oNode As TreeNode)
2729
        If CLineNo IsNot Nothing Then
2730
            Dim oLine_Dt As DataTable = CLineNo.Dt_Line
2731
            Dim oSymbol_Dt As DataTable = CLineNo.Dt_Symbol
2732
            Dim oAttribute_Dt As DataTable = CLineNo.Dt_Attribute
2733
            Dim oDrawLinenoLabel As Boolean = False
2734
            Try
2735
                ManualCheckNode(oLine_Dt)
2736
                ManualCheckNode(oSymbol_Dt)
2737
            Catch ex As Exception
2738
            End Try
2739
            For Each oSymbolNode As TreeNode In oNode.Nodes
2740
                If oSymbolNode.Checked Then
2741
                    Try
2742
                        Dim sUid As String = oSymbolNode.Name
2743
                        Dim sLineNoUid As String = CLineNo.Uid
2744
                        Dim sReturnUid = sUid
2745
                        '  FinalModeling(sUid, oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2746
                        Dim oSymbolRows As DataRow() = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "]= '" & sReturnUid & "' And [" & _XML_SYMBOL_DRAWING_TF & "] = 'FALSE' And [" &
2747
                                                                           _XML_SYMBOL_Check & "] = 'TRUE'")
2748
                        If oSymbolRows.Count > 0 Then
2749
                            Dim sSymbolType As String = oSymbolRows(0)(_XML_SYMBOL_TYPE).ToString().ToUpper()
2750
                            If sSymbolType = "INSTRUMENT" Then
2751
                                sReturnUid = FinalSymbolModeling(oSymbolRows(0), oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2752
                            End If
2753
                        Else
2754
                            sReturnUid = ""
2755
                        End If
2756
                        If sReturnUid = "" Then
2757
                        End If
2758
                    Catch ex As Exception
2759
                    End Try
2760
                End If
2761
            Next
2762
        End If
2763
    End Sub
2764

    
2765
    Private Sub PipeSymbolModeling(ByVal CLineNo As Line_no, ByVal oNode As TreeNode)
2766
        If CLineNo IsNot Nothing Then
2767
            Dim oLine_Dt As DataTable = CLineNo.Dt_Line
2768
            Dim oSymbol_Dt As DataTable = CLineNo.Dt_Symbol
2769
            Dim oAttribute_Dt As DataTable = CLineNo.Dt_Attribute
2770
            Dim oDrawLinenoLabel As Boolean = False
2771
            Try
2772
                ManualCheckNode(oLine_Dt)
2773
                ManualCheckNode(oSymbol_Dt)
2774
            Catch ex As Exception
2775
            End Try
2776
            For Each oSymbolNode As TreeNode In oNode.Nodes
2777
                If oSymbolNode.Checked Then
2778
                    Try
2779
                        Dim sUid As String = oSymbolNode.Name
2780
                        Dim sLineNoUid As String = CLineNo.Uid
2781
                        Dim sReturnUid = sUid
2782
                        '  FinalModeling(sUid, oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2783
                        Dim oSymbolRows As DataRow() = oSymbol_Dt.Select("[" & _XML_SYMBOL_UID & "]= '" & sReturnUid & "' And [" & _XML_SYMBOL_DRAWING_TF & "] = 'FALSE' And [" &
2784
                                                                           _XML_SYMBOL_Check & "] = 'TRUE'")
2785
                        If oSymbolRows.Count > 0 Then
2786
                            Dim sSymbolType As String = oSymbolRows(0)(_XML_SYMBOL_TYPE).ToString().ToUpper()
2787
                            If sSymbolType <> "INSTRUMENT" Then
2788
                                sReturnUid = FinalSymbolModeling(oSymbolRows(0), oLine_Dt, oSymbol_Dt, oAttribute_Dt)
2789
                            End If
2790
                        Else
2791
                            sReturnUid = ""
2792
                        End If
2793
                        If sReturnUid = "" Then
2794
                        End If
2795
                    Catch ex As Exception
2796
                    End Try
2797
                End If
2798
            Next
2799
        End If
2800
    End Sub
2801

    
2802
    Private Sub PipingModeling()
2803

    
2804
        Try
2805
            For Each oDrwing As TreeNode In Tree_Result.Nodes
2806
                For Each oDwgNode As TreeNode In oDrwing.Nodes
2807
                    Dim sDwgName As String = Path.GetFileNameWithoutExtension(oDwgNode.Text)
2808
                    Dim CDrawing As Drawing = GetDrawing(sDwgName)
2809
                    If CDrawing IsNot Nothing Then
2810
                        Dim iAllLineNoCount As Integer = Tree_Result.Nodes.Count ' GetCheckNodeCount(oLinenoNode)
2811
                        Dim iPipingOPC_count As Integer = 0 ' GetCheckNodeCount(oLinenoNode)
2812

    
2813
                        'PipeModeling
2814
                        For Each oNode As TreeNode In oDwgNode.Nodes
2815
                            Dim iItemcnt As Integer = 0
2816
                            Dim sNodeUid As String = oNode.Name
2817
                            Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
2818
                            Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
2819
                            PipeLineModeling(CLineNo, oNode)
2820
                            Dim CTrimLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
2821
                            PipeLineModeling(CTrimLineNo, oNode)
2822
                        Next
2823

    
2824
                        'Instrument Modeling
2825
                        For Each oNode As TreeNode In oDwgNode.Nodes
2826
                            Dim iItemcnt As Integer = 0
2827
                            Dim sNodeUid As String = oNode.Name
2828
                            Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
2829
                            Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
2830
                            InstrumentSymbolModeling(CLineNo, oNode)
2831
                            Dim CTrimLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
2832
                            InstrumentSymbolModeling(CTrimLineNo, oNode)
2833
                        Next
2834

    
2835
                        'Instrument Line Modeling
2836
                        For Each oNode As TreeNode In oDwgNode.Nodes
2837
                            Dim iItemcnt As Integer = 0
2838
                            Dim sNodeUid As String = oNode.Name
2839
                            Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
2840
                            Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
2841
                            InstumentLineModeling(CLineNo, oNode)
2842
                            Dim CTrimLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
2843
                            InstumentLineModeling(CTrimLineNo, oNode)
2844
                        Next
2845

    
2846
                        'Symbol Modeling
2847
                        For Each oNode As TreeNode In oDwgNode.Nodes
2848
                            Dim iItemcnt As Integer = 0
2849
                            Dim sNodeUid As String = oNode.Name
2850
                            Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
2851
                            Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
2852
                            PipeSymbolModeling(CLineNo, oNode)
2853
                            Dim CTrimLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
2854
                            PipeSymbolModeling(CTrimLineNo, oNode)
2855
                        Next
2856
                    End If
2857
                Next
2858
            Next
2859
        Catch ex As Exception
2860

    
2861
        End Try
2862
    End Sub
2863

    
2864
    Private Sub GetPrimaryLineInNode(ByVal list As List(Of Line), ByVal node As TreeNode)
2865

    
2866
        If node.Tag IsNot Nothing Then
2867
            If TypeOf node.Tag Is Line Then
2868
                Dim line As Line = node.Tag
2869
                If line.TYPE = "Primary" And node.Checked Then
2870
                    list.Add(line)
2871
                End If
2872
            End If
2873
        End If
2874

    
2875
        For Each child As TreeNode In node.Nodes()
2876
            GetPrimaryLineInNode(list, child)
2877
        Next
2878
    End Sub
2879

    
2880
    Private Function FindBranchLine(ByVal lines As List(Of Line)) As List(Of Line)
2881
        Dim branchLines As List(Of Line) = New List(Of Line)
2882

    
2883
        For Each line As Line In lines
2884
            For Each conn As Connector In line.CONNECTORS
2885
                If String.IsNullOrEmpty(conn.CONNECTEDITEM) = False Then
2886
                    If IsBranchLine(conn.CONNECTEDITEM, line.UID, lines) Then
2887
                        branchLines.Add(line)
2888
                    End If
2889
                End If
2890
            Next
2891
        Next
2892

    
2893
        Return branchLines
2894
    End Function
2895

    
2896
    Private Function IsBranchLine(ByVal connectedUID As String, ByVal UID As String, ByVal lines As List(Of Line)) As Boolean
2897
        Dim connLine = FindLineByUID(lines, connectedUID)
2898
        If connLine IsNot Nothing Then
2899
            If connLine.CONNECTORS(0).CONNECTEDITEM <> UID And connLine.CONNECTORS(1).CONNECTEDITEM <> UID Then
2900
                Return True
2901
            End If
2902
        End If
2903

    
2904
        Return False
2905
    End Function
2906

    
2907
    Private Function FindLineByUID(ByVal lines As List(Of Line), ByVal uid As String) As Line
2908
        For Each line As Line In lines
2909
            If line.UID = uid Then
2910
                Return line
2911
            End If
2912
        Next
2913

    
2914
        Return Nothing
2915
    End Function
2916

    
2917

    
2918
    Private Function FindSymbolByUID(ByVal symbols As List(Of Symbol), ByVal uid As String) As Symbol
2919
        For Each symbol As Symbol In symbols
2920
            If symbol.UID = uid Then
2921
                Return symbol
2922
            End If
2923
        Next
2924

    
2925
        Return Nothing
2926
    End Function
2927

    
2928
    Private Function IsHorizontal(ByVal line As Line)
2929
        If line.END_X - line.START_X = 0 Then
2930
            Return False
2931
        Else
2932
            Dim angle = Math.Atan(Math.Abs(line.END_Y - line.START_Y) / Math.Abs(line.END_X - line.START_X)) * 180 / Math.PI
2933
            If angle < 10 Then
2934
                Return True
2935
            Else
2936
                Return False
2937
            End If
2938
        End If
2939
    End Function
2940

    
2941
    Private Function IsHorizontal(ByVal point1 As Pointd, ByVal point2 As Pointd)
2942
        If point1.X - point2.X = 0 Then
2943
            Return False
2944
        Else
2945
            Dim angle = Math.Atan(Math.Abs(point2.Y - point1.Y) / Math.Abs(point2.X - point1.X)) * 180 / Math.PI
2946
            If angle < 10 Then
2947
                Return True
2948
            Else
2949
                Return False
2950
            End If
2951
        End If
2952
    End Function
2953

    
2954
    Private Sub FindConnectPrimaryLine(ByVal drawing As Drawing, ByVal primaryLines As List(Of Line), ByVal shape As Object, ByRef groupLine As List(Of Line))
2955

    
2956
        If TypeOf (shape) Is Line Then
2957
            Dim _line As Line = shape
2958

    
2959
            For Each conn As Connector In _line.CONNECTORS
2960
                Dim symbol As Symbol = FindSymbolByUID(drawing.SYMBOLS, conn.CONNECTEDITEM)
2961
                Dim line As Line = FindLineByUID(primaryLines, conn.CONNECTEDITEM)
2962

    
2963
                If line IsNot Nothing Then
2964
                    If IsBranchLine(line.UID, _line.UID, primaryLines) = False And line.ENABLE And line.TYPE = "Primary" Then
2965
                        line.ENABLE = False
2966
                        groupLine.Add(line)
2967
                        FindConnectPrimaryLine(drawing, primaryLines, line, groupLine)
2968
                    End If
2969
                ElseIf symbol IsNot Nothing Then
2970
                    If symbol.ENABLE Then
2971
                        symbol.ENABLE = False
2972
                        FindConnectPrimaryLine(drawing, primaryLines, symbol, groupLine)
2973
                    End If
2974
                End If
2975
            Next
2976

    
2977
        ElseIf TypeOf (shape) Is Symbol Then
2978
            Dim _symbol As Symbol = shape
2979

    
2980
            For Each conn As Connector In _symbol.CONNECTORS
2981
                Dim symbol As Symbol = FindSymbolByUID(drawing.SYMBOLS, conn.CONNECTEDITEM)
2982
                Dim line As Line = FindLineByUID(primaryLines, conn.CONNECTEDITEM)
2983

    
2984
                If line IsNot Nothing Then
2985
                    If line.ENABLE And line.TYPE = "Primary" Then
2986
                        line.ENABLE = False
2987
                        groupLine.Add(line)
2988
                        FindConnectPrimaryLine(drawing, primaryLines, line, groupLine)
2989
                        Exit For
2990
                    End If
2991
                ElseIf symbol IsNot Nothing Then
2992
                    If symbol.ENABLE Then
2993
                        symbol.ENABLE = False
2994
                        FindConnectPrimaryLine(drawing, primaryLines, symbol, groupLine)
2995
                    End If
2996
                End If
2997
            Next
2998

    
2999
        End If
3000

    
3001
    End Sub
3002

    
3003
    Private Function GetPrimaryGroup(ByVal drawing As Drawing, ByVal primaryLines As List(Of Line)) As List(Of List(Of Line))
3004
        Dim result As List(Of List(Of Line)) = New List(Of List(Of Line))
3005

    
3006
        For Each line As Line In primaryLines
3007
            If line.ENABLE And line.TYPE = "Primary" Then
3008
                Dim forwardGroupLine As List(Of Line) = New List(Of Line)
3009
                Dim reverseGroupLine As List(Of Line) = New List(Of Line)
3010
                line.ENABLE = False
3011

    
3012
                Dim _symbol As Symbol = FindSymbolByUID(drawing.SYMBOLS, line.CONNECTORS(0).CONNECTEDITEM)
3013
                Dim _line As Line = FindLineByUID(primaryLines, line.CONNECTORS(0).CONNECTEDITEM)
3014

    
3015
                If _line IsNot Nothing Then
3016
                    If IsBranchLine(line.CONNECTORS(0).CONNECTEDITEM, line.UID, primaryLines) = False Then
3017
                        _line.ENABLE = False
3018
                        forwardGroupLine.Add(_line)
3019
                        FindConnectPrimaryLine(drawing, primaryLines, _line, forwardGroupLine)
3020
                    End If
3021
                ElseIf _symbol IsNot Nothing Then
3022
                    _symbol.ENABLE = False
3023
                    FindConnectPrimaryLine(drawing, primaryLines, _symbol, forwardGroupLine)
3024
                End If
3025

    
3026
                _symbol = FindSymbolByUID(drawing.SYMBOLS, line.CONNECTORS(1).CONNECTEDITEM)
3027
                _line = FindLineByUID(primaryLines, line.CONNECTORS(1).CONNECTEDITEM)
3028
                If _line IsNot Nothing Then
3029
                    If IsBranchLine(line.CONNECTORS(1).CONNECTEDITEM, line.UID, primaryLines) = False Then
3030
                        _line.ENABLE = False
3031
                        reverseGroupLine.Add(_line)
3032
                        FindConnectPrimaryLine(drawing, primaryLines, _line, reverseGroupLine)
3033
                    End If
3034
                ElseIf _symbol IsNot Nothing Then
3035
                    _symbol.ENABLE = False
3036
                    FindConnectPrimaryLine(drawing, primaryLines, _symbol, reverseGroupLine)
3037
                End If
3038

    
3039
                reverseGroupLine.Reverse()
3040
                reverseGroupLine.Add(line)
3041
                reverseGroupLine.AddRange(forwardGroupLine)
3042

    
3043
                result.Add(reverseGroupLine)
3044

    
3045
            End If
3046
        Next
3047

    
3048
        Return result
3049
    End Function
3050

    
3051

    
3052

    
3053
    Private Function GetTargetLMConnector(ByVal ModelId As String, ByVal point As Pointd) As Tuple(Of LMConnector, Integer)
3054
        Dim lmConnector As LMConnector = Nothing
3055
        Dim ConnPoint1 As PointdInfo = Nothing
3056
        Dim ConnPoint2 As PointdInfo = Nothing
3057
        Dim insertIndex As Integer = 0
3058

    
3059
        Dim min As Double = 0
3060
        Dim max As Double = 0
3061
        Dim _tempDistance As Double = 0
3062
        Dim distance As Double = Double.MaxValue
3063

    
3064
        Try
3065
            Dim pointdInfos As List(Of PointdInfo) = PipeRunPoint(ModelId)
3066

    
3067
            For index = 0 To pointdInfos.Count - 2
3068
                Dim point1 As Pointd = pointdInfos(index).Pointd
3069
                Dim point2 As Pointd = pointdInfos(index + 1).Pointd
3070

    
3071
                If IsHorizontal(point1, point2) Then
3072
                    min = Math.Min(point1.X, point2.X)
3073
                    max = Math.Max(point1.X, point2.X)
3074
                    _tempDistance = Math.Abs((point1.Y + point2.Y) / 2 - point.Y)
3075

    
3076
                    If min <= point.X And max >= point.X And _tempDistance < distance Then
3077
                        ConnPoint1 = pointdInfos(index)
3078
                        ConnPoint2 = pointdInfos(index + 1)
3079
                        insertIndex = index + 1
3080
                        distance = _tempDistance
3081
                    End If
3082

    
3083
                Else
3084
                    min = Math.Min(point1.Y, point2.Y)
3085
                    max = Math.Max(point1.Y, point2.Y)
3086
                    _tempDistance = Math.Abs((point1.X + point2.X) / 2 - point.X)
3087

    
3088
                    If min <= point.Y And max >= point.Y And _tempDistance < distance Then
3089
                        ConnPoint1 = pointdInfos(index)
3090
                        ConnPoint2 = pointdInfos(index + 1)
3091
                        insertIndex = index + 1
3092
                        distance = _tempDistance
3093
                    End If
3094
                End If
3095
            Next
3096

    
3097
            If ConnPoint1 IsNot Nothing And ConnPoint2 IsNot Nothing Then
3098
                If ConnPoint1.Type = "RUN" Then
3099
                    lmConnector = GetLMConnectorByPoint(ModelId, ConnPoint1.Pointd)
3100
                ElseIf ConnPoint2.Type = "RUN" Then
3101
                    lmConnector = GetLMConnectorByPoint(ModelId, ConnPoint2.Pointd)
3102
                ElseIf ConnPoint1.Type = "BRANCH" And ConnPoint2.Type = "BRANCH" Then
3103
                    lmConnector = GetLMConnectorBySP_ID(ModelId, ConnPoint1.SP_ID, ConnPoint2.SP_ID)
3104
                Else
3105
                    Debug.WriteLine("Error At GetTargetLMConnector")
3106
                End If
3107
            End If
3108

    
3109
            If lmConnector Is Nothing Then
3110
                Throw New Exception("")
3111
            End If
3112

    
3113
            Return New Tuple(Of LMConnector, Integer)(lmConnector, insertIndex)
3114
        Catch ex As Exception
3115
            Debug.WriteLine("Error At GetTargetLMConnector")
3116
            Return Nothing
3117
        End Try
3118
    End Function
3119

    
3120
    Private Function GetLMConnectorByPoint(ByVal ModelId As String, ByVal point As Pointd) As LMConnector
3121
        Dim objPlacement As Placement = New Placement
3122
        Dim objConnector As LMConnector = Nothing
3123

    
3124
        Dim distance As Double = Double.MaxValue
3125
        Dim lmPipeRun As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ModelId)
3126
        For Each oRep As LMRepresentation In lmPipeRun.Representations
3127
            If oRep.Attributes("RepresentationType").Value = "Connector" And oRep.Attributes("ItemStatus").Value = "Active" Then
3128
                Dim _conn As LMConnector = objPlacement.PIDDataSource.GetConnector(oRep.Id)
3129
                For Each vertex As LMConnectorVertex In _conn.ConnectorVertices
3130
                    Dim _distance As Double = CalcPointToPointdDistance(point, New Pointd(vertex.XCoordinate, vertex.YCoordinate))
3131

    
3132
                    If _distance < distance Then
3133
                        distance = _distance
3134
                        objConnector = _conn
3135
                    End If
3136
                Next
3137
            End If
3138
        Next
3139

    
3140
        Return objConnector
3141
    End Function
3142

    
3143
    Private Function GetLMConnectorBySP_ID(ByVal ModelId As String, ByVal SP_ID1 As String, ByVal SP_ID2 As String) As LMConnector
3144
        Dim objPlacement As Placement = New Placement
3145
        Dim objConnector As LMConnector = Nothing
3146

    
3147
        Dim distance As Double = Double.MaxValue
3148
        Dim lmPipeRun As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ModelId)
3149
        For Each oRep As LMRepresentation In lmPipeRun.Representations
3150
            If oRep.Attributes("RepresentationType").Value = "Connector" And oRep.Attributes("ItemStatus").Value = "Active" Then
3151
                Dim _conn As LMConnector = objPlacement.PIDDataSource.GetConnector(oRep.Id)
3152

    
3153
                Dim find1 As Boolean = False
3154
                Dim find2 As Boolean = False
3155

    
3156
                If _conn.ConnectItem1SymbolID IsNot Nothing Then
3157
                    If _conn.ConnectItem1SymbolID.ToString = SP_ID1 Or _conn.ConnectItem1SymbolID.ToString = SP_ID2 Then
3158
                        find1 = True
3159
                    End If
3160
                End If
3161

    
3162
                If _conn.ConnectItem2SymbolID IsNot Nothing Then
3163
                    If _conn.ConnectItem2SymbolID.ToString = SP_ID1 Or _conn.ConnectItem2SymbolID.ToString = SP_ID2 Then
3164
                        find2 = True
3165
                    End If
3166
                End If
3167

    
3168
                If find1 And find2 Then
3169
                    Return _conn
3170
                End If
3171
            End If
3172
        Next
3173

    
3174
        If objConnector Is Nothing Then
3175
            Debug.WriteLine("Error At GetLMConnectorBySP_ID")
3176
        End If
3177

    
3178
        Return objConnector
3179
    End Function
3180

    
3181

    
3182

    
3183
    Private Function DrawPrimaryGroupLine(ByVal points As List(Of Pointd), ByVal ConnectLine1 As Line, ByVal ConnectLine2 As Line) As LMConnector
3184
        Try
3185
            Dim objPlacement As Placement = New Placement
3186
            Dim objItem As LMAItem
3187
            Dim objConnector As LMConnector
3188

    
3189
            Dim targetConnector1 As Tuple(Of LMConnector, Integer) = Nothing
3190
            Dim branch1_SP_ID_List As List(Of String) = New List(Of String)
3191
            Dim targetConnector2 As Tuple(Of LMConnector, Integer) = Nothing
3192
            Dim branch2_SP_ID_List As List(Of String) = New List(Of String)
3193

    
3194

    
3195
            If ConnectLine1 IsNot Nothing Then
3196
                targetConnector1 = GetTargetLMConnector(ConnectLine1.LMCONNECTOR_MODELID, points(0))
3197

    
3198
                Dim run As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ConnectLine1.LMCONNECTOR_MODELID)
3199
                For Each oRep As LMRepresentation In run.Representations
3200
                    If oRep.Attributes("RepresentationType").Value = "Branch" And oRep.Attributes("ItemStatus").Value = "Active" Then
3201
                        branch1_SP_ID_List.Add(oRep.Id)
3202
                    End If
3203
                Next
3204
            End If
3205

    
3206
            If ConnectLine2 IsNot Nothing Then
3207
                targetConnector2 = GetTargetLMConnector(ConnectLine2.LMCONNECTOR_MODELID, points(points.Count - 1))
3208

    
3209
                Dim run As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ConnectLine2.LMCONNECTOR_MODELID)
3210
                For Each oRep As LMRepresentation In run.Representations
3211
                    If oRep.Attributes("RepresentationType").Value = "Branch" And oRep.Attributes("ItemStatus").Value = "Active" Then
3212
                        branch2_SP_ID_List.Add(oRep.Id)
3213
                    End If
3214
                Next
3215
            End If
3216

    
3217
            Dim objInputs As PlaceRunInputs = New PlaceRunInputs
3218
            objItem = objPlacement.PIDCreateItem(GetPipeType("Primary"))
3219

    
3220
            For index = 0 To points.Count - 1
3221
                If index = 0 And targetConnector1 IsNot Nothing Then
3222
                    objInputs.AddConnectorTarget(targetConnector1.Item1, points(index).X, points(index).Y)
3223
                ElseIf index = points.Count - 1 And targetConnector2 IsNot Nothing Then
3224
                    objInputs.AddConnectorTarget(targetConnector2.Item1, points(index).X, points(index).Y)
3225
                Else
3226
                    objInputs.AddPoint(points(index).X, points(index).Y)
3227
                End If
3228
            Next
3229
            objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
3230

    
3231

    
3232
            '' 기존 Points에 Insert해야함
3233
            If ConnectLine1 IsNot Nothing Then
3234
                Dim run As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ConnectLine1.LMCONNECTOR_MODELID)
3235
                For Each oRep As LMRepresentation In run.Representations
3236
                    If oRep.Attributes("RepresentationType").Value = "Branch" And oRep.Attributes("ItemStatus").Value = "Active" Then
3237
                        If branch1_SP_ID_List.Contains(oRep.Id) = False Then
3238
                            PipeRunPoint(ConnectLine1.LMCONNECTOR_MODELID).Insert(targetConnector1.Item2, New PointdInfo(points(0), "BRANCH", oRep.Id))
3239
                            Exit For
3240
                        End If
3241
                    End If
3242
                Next
3243
            End If
3244

    
3245
            If ConnectLine2 IsNot Nothing Then
3246
                Dim run As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ConnectLine2.LMCONNECTOR_MODELID)
3247
                For Each oRep As LMRepresentation In run.Representations
3248
                    If oRep.Attributes("RepresentationType").Value = "Branch" And oRep.Attributes("ItemStatus").Value = "Active" Then
3249
                        If branch2_SP_ID_List.Contains(oRep.Id) = False Then
3250
                            PipeRunPoint(ConnectLine2.LMCONNECTOR_MODELID).Insert(targetConnector2.Item2, New PointdInfo(points(points.Count - 1), "BRANCH", oRep.Id))
3251
                            Exit For
3252
                        End If
3253
                    End If
3254
                Next
3255
            End If
3256

    
3257
            Return objConnector
3258
        Catch ex As Exception
3259
            Debug.WriteLine("Error At DrawPrimaryGroupLine")
3260
            Return Nothing
3261
        End Try
3262

    
3263
    End Function
3264

    
3265
    Private Function CalcLineToPointdDistance(ByVal point1 As Pointd, ByVal point2 As Pointd, ByVal targetPointd As Pointd) As Double
3266
        If point1.X = point2.X Then
3267
            Return Math.Abs(targetPointd.X - point1.X)
3268
        ElseIf point1.Y = point2.Y Then
3269
            Return Math.Abs(targetPointd.Y - point1.Y)
3270
        Else
3271
            ' y = ax + c
3272
            Dim a As Double = (point2.Y - point1.Y) / (point2.X - point1.X)
3273
            Dim c As Double = point2.Y - a * point2.X
3274

    
3275
            ' ax + by + c = 0
3276
            Dim b As Double = -1
3277
            Return Math.Abs(a * targetPointd.X + b * targetPointd.Y + c) / Math.Pow(a * a + b * b, 0.5)
3278
        End If
3279
    End Function
3280

    
3281
    Private Function CalcPointToPointdDistance(ByVal point1 As Pointd, ByVal point2 As Pointd) As Double
3282

    
3283
        Return Math.Pow(Math.Pow(point1.X - point2.X, 2) + Math.Pow(point1.Y - point2.Y, 2), 0.5)
3284

    
3285
    End Function
3286

    
3287
    Private Function GetConnectorTarget(ByVal Connector_ModelID As String, ByVal targetPoint As Pointd) As LMConnector
3288
        Dim objPlacement As Placement = New Placement
3289

    
3290
        Dim lmPipeRun As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(Connector_ModelID)
3291

    
3292
        Dim connList As List(Of LMConnector) = New List(Of LMConnector)
3293
        Dim oConnector As LMConnector = Nothing
3294

    
3295
        For Each oRep As LMRepresentation In lmPipeRun.Representations
3296
            If oRep.Attributes("RepresentationType").Value = "Connector" And oRep.Attributes("ItemStatus").Value = "Active" Then
3297
                connList.Add(objPlacement.PIDDataSource.GetConnector(oRep.Id))
3298
            End If
3299
        Next
3300

    
3301
        '' 자기 자신의 Line 찾기
3302
        Dim distance As Double = Double.MaxValue
3303
        For Each lmLine As LMConnector In connList
3304
            '' Connector의 포인트 정리
3305

    
3306
            '' 임시
3307
            oConnector = lmLine
3308
            '_Placement.PIDDataSource.GetPipingPoint()
3309

    
3310
            Dim pointList As List(Of Pointd) = New List(Of Pointd)
3311

    
3312
            For index = 1 To Integer.MaxValue
3313
                Dim point As LMConnectorVertex = lmLine.ConnectorVertices.Nth(index)
3314
                If point IsNot Nothing Then
3315
                    Dim _pointd As Pointd = New Pointd()
3316
                    _pointd.X = point.XCoordinate
3317
                    _pointd.Y = point.YCoordinate
3318
                    pointList.Add(_pointd)
3319
                Else
3320
                    Exit For
3321
                End If
3322
            Next
3323

    
3324
            For index = 0 To pointList.Count - 1
3325
                If pointList.Count > index + 1 Then
3326
                    Dim _tempDistance As Double = CalcLineToPointdDistance(pointList(index), pointList(index + 1), targetPoint)
3327
                    If _tempDistance < distance Then
3328
                        oConnector = lmLine
3329
                        distance = _tempDistance
3330
                    End If
3331
                End If
3332
            Next
3333
        Next
3334

    
3335
        Return oConnector
3336
    End Function
3337

    
3338
    Private Function DrawBranchLine(ByVal branchLine As Line, ByVal connLine1 As Line, ByVal connLine2 As Line) As LMConnector
3339
        Try
3340
            Dim objPlacement As Placement = New Placement
3341
            Dim objItem As LMAItem
3342
            Dim objConnector As LMConnector
3343
            Dim objInputs As PlaceRunInputs = New PlaceRunInputs
3344
            objItem = objPlacement.PIDCreateItem(GetPipeType("Primary"))
3345

    
3346
            If connLine1 IsNot Nothing Then
3347
                If String.IsNullOrEmpty(connLine1.LMCONNECTOR_MODELID) Then
3348
                    Return Nothing
3349
                Else
3350

    
3351
                    '' Branch Point
3352
                    Dim branchPoint As Pointd = New Pointd()
3353
                    If branchLine.CONNECTORS(0).CONNECTPOINT = branchLine.STARTPOINT Then
3354
                        branchPoint.X = branchLine.START_X
3355
                        branchPoint.Y = branchLine.START_Y
3356
                    ElseIf branchLine.CONNECTORS(0).CONNECTPOINT = branchLine.ENDPOINT Then
3357
                        branchPoint.X = branchLine.END_X
3358
                        branchPoint.Y = branchLine.END_Y
3359
                    Else
3360
                        Return Nothing
3361
                    End If
3362

    
3363
                    Dim oConnector As LMConnector = GetConnectorTarget(connLine1.LMCONNECTOR_MODELID, branchPoint)
3364

    
3365
                    If oConnector Is Nothing Then
3366
                        Return Nothing
3367
                    End If
3368

    
3369
                    objInputs.AddConnectorTarget(oConnector, branchPoint.X, branchPoint.Y)
3370
                End If
3371
            Else
3372
                If branchLine.CONNECTORS(0).CONNECTPOINT = branchLine.STARTPOINT Then
3373
                    objInputs.AddPoint(branchLine.START_X, branchLine.START_Y)
3374
                Else
3375
                    objInputs.AddPoint(branchLine.END_X, branchLine.END_Y)
3376
                End If
3377
            End If
3378

    
3379
            If connLine2 IsNot Nothing Then
3380
                If String.IsNullOrEmpty(connLine2.LMCONNECTOR_MODELID) Then
3381
                    Return Nothing
3382
                Else
3383
                    '' Branch Point
3384
                    Dim branchPoint As Pointd = New Pointd()
3385
                    If branchLine.CONNECTORS(1).CONNECTPOINT = branchLine.STARTPOINT Then
3386
                        branchPoint.X = branchLine.START_X
3387
                        branchPoint.Y = branchLine.START_Y
3388
                    Else
3389
                        branchPoint.X = branchLine.END_X
3390
                        branchPoint.Y = branchLine.END_Y
3391
                    End If
3392

    
3393
                    Dim oConnector As LMConnector = GetConnectorTarget(connLine2.LMCONNECTOR_MODELID, branchPoint)
3394

    
3395
                    If oConnector Is Nothing Then
3396
                        Return Nothing
3397
                    End If
3398

    
3399
                    objInputs.AddConnectorTarget(oConnector, branchPoint.X, branchPoint.Y)
3400
                End If
3401
            Else
3402
                If branchLine.CONNECTORS(1).CONNECTPOINT = branchLine.STARTPOINT Then
3403
                    objInputs.AddPoint(branchLine.START_X, branchLine.START_Y)
3404
                Else
3405
                    objInputs.AddPoint(branchLine.END_X, branchLine.END_Y)
3406
                End If
3407
            End If
3408

    
3409
            objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
3410

    
3411
            Dim _lmPipeRun As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(objConnector.ModelItemID)
3412
            _lmPipeRun.StreamNo = branchLine.UID
3413

    
3414
            Return objConnector
3415
        Catch ex As Exception
3416
            SetListBoxItems(ListBox_Result, ex.Message)
3417
            Return Nothing
3418
        End Try
3419

    
3420
    End Function
3421

    
3422

    
3423
    Private Function FindFirstLine(ByVal primaryLineList As List(Of Line), ByVal symbols As List(Of Symbol), ByVal symbol As Symbol, ByVal UID As String) As Line
3424

    
3425
        For Each conn As Connector In symbol.CONNECTORS
3426
            '' 자기 자신일 경우 제외
3427
            If conn.CONNECTEDITEM = UID Then
3428
                Continue For
3429
            End If
3430

    
3431
            Dim _symbol As Symbol = FindSymbolByUID(symbols, conn.CONNECTEDITEM)
3432
            Dim _line As Line = FindLineByUID(primaryLineList, conn.CONNECTEDITEM)
3433

    
3434
            If _line IsNot Nothing Then
3435
                If _line.ENABLE = False Then
3436
                    Return _line
3437
                End If
3438
            ElseIf _symbol IsNot Nothing Then
3439
                Return FindFirstLine(primaryLineList, symbols, _symbol, symbol.UID)
3440
            End If
3441
        Next
3442

    
3443
        Return Nothing
3444

    
3445
    End Function
3446

    
3447

    
3448

    
3449
    Private Sub DrawPrimaryLineGroup(ByVal primaryGroup As List(Of List(Of Line)), ByVal primaryLines As List(Of Line))
3450

    
3451
        Dim loopGroup As List(Of Line) = Nothing
3452

    
3453
        While primaryGroup.Count > 0
3454
            For Each group As List(Of Line) In primaryGroup
3455
                Dim firstLine As Line = group(0)
3456
                Dim lastLine As Line = group(group.Count - 1)
3457

    
3458
                Dim line1 As Line = Nothing
3459
                Dim line2 As Line = Nothing
3460

    
3461
                If group.Count = 1 Then
3462
                    line1 = FindLineByUID(primaryLines, firstLine.CONNECTORS(0).CONNECTEDITEM)
3463
                    line2 = FindLineByUID(primaryLines, firstLine.CONNECTORS(1).CONNECTEDITEM)
3464

    
3465
                Else
3466
                    '' 붙은 Branch 라인이 있는지 확인함
3467
                    Dim _temp1 As Line = FindLineByUID(primaryLines, firstLine.CONNECTORS(0).CONNECTEDITEM)
3468
                    Dim _temp2 As Line = FindLineByUID(primaryLines, firstLine.CONNECTORS(1).CONNECTEDITEM)
3469

    
3470
                    If _temp1 IsNot Nothing Then
3471
                        If group.Contains(_temp1) = False Then
3472
                            line1 = _temp1
3473
                        End If
3474
                    End If
3475

    
3476
                    If line1 Is Nothing And _temp2 IsNot Nothing Then
3477
                        If group.Contains(_temp2) = False Then
3478
                            line1 = _temp2
3479
                        End If
3480
                    End If
3481

    
3482
                    _temp1 = FindLineByUID(primaryLines, lastLine.CONNECTORS(0).CONNECTEDITEM)
3483
                    _temp2 = FindLineByUID(primaryLines, lastLine.CONNECTORS(1).CONNECTEDITEM)
3484

    
3485
                    If _temp1 IsNot Nothing Then
3486
                        If group.Contains(_temp1) = False Then
3487
                            line2 = _temp1
3488
                        End If
3489
                    End If
3490

    
3491
                    If line2 Is Nothing And _temp2 IsNot Nothing Then
3492
                        If group.Contains(_temp2) = False Then
3493
                            line2 = _temp2
3494
                        End If
3495
                    End If
3496

    
3497
                End If
3498

    
3499
                '' line1, line2 가 nothing : 연결된게 없다
3500
                '' line1, line2 가 not nothing : 연결된게 있는데 모델링 된지는 확인해야함
3501
                If line1 IsNot Nothing Then
3502
                    If String.IsNullOrEmpty(line1.LMCONNECTOR_MODELID) Then
3503
                        If loopGroup IsNot Nothing Then
3504
                            If loopGroup.Equals(group) Then
3505
                                SetListBoxItems(ListBox_Result, "Fail to create primary group line [loop]")
3506
                                loopGroup = Nothing
3507
                                primaryGroup.Remove(group)
3508
                            End If
3509
                        Else
3510
                            loopGroup = group
3511
                        End If
3512
                        Continue For
3513
                    End If
3514
                End If
3515

    
3516
                If line2 IsNot Nothing Then
3517
                    If String.IsNullOrEmpty(line2.LMCONNECTOR_MODELID) Then
3518
                        If loopGroup IsNot Nothing Then
3519
                            If loopGroup.Equals(group) Then
3520
                                SetListBoxItems(ListBox_Result, "Fail to create primary group line [loop]")
3521
                                loopGroup = Nothing
3522
                                primaryGroup.Remove(group)
3523
                            End If
3524
                        Else
3525
                            loopGroup = group
3526
                        End If
3527
                        Continue For
3528
                    End If
3529
                End If
3530

    
3531

    
3532
                '' 만약 2개가 같은 라인바라보면 수정 필요
3533
                If line1 IsNot Nothing And line2 IsNot Nothing Then
3534
                    If line1.LMCONNECTOR_MODELID = line2.LMCONNECTOR_MODELID Then
3535
                        line2 = Nothing
3536
                    End If
3537
                End If
3538

    
3539
                '' 그림
3540
                Dim points As List(Of Pointd) = GetGroupPoint(group)
3541
                Dim lmConnector As LMConnector = DrawPrimaryGroupLine(points, line1, line2)
3542
                If lmConnector Is Nothing Then
3543
                    SetListBoxItems(ListBox_Result, "Fail to create primary group line")
3544
                    primaryGroup.Remove(group)
3545
                    Continue For
3546
                End If
3547
                For Each line As Line In group
3548
                    line.LMCONNECTOR_MODELID = lmConnector.ModelItemID
3549
                Next
3550

    
3551

    
3552
                Dim poinInfotList As List(Of PointdInfo) = New List(Of PointdInfo)
3553
                For index = 0 To points.Count - 1
3554
                    If index = 0 And line1 IsNot Nothing Then
3555
                        poinInfotList.Add(New PointdInfo(points(index), "BRANCH", GetBranch_SP_ID(lmConnector, line1.LMCONNECTOR_MODELID)))
3556
                    ElseIf index = points.Count - 1 And line2 IsNot Nothing Then
3557
                        poinInfotList.Add(New PointdInfo(points(index), "BRANCH", GetBranch_SP_ID(lmConnector, line2.LMCONNECTOR_MODELID)))
3558
                    Else
3559
                        poinInfotList.Add(New PointdInfo(points(index), "RUN"))
3560
                    End If
3561
                Next
3562

    
3563
                PipeRunPoint.Add(lmConnector.ModelItemID, poinInfotList)
3564

    
3565
                loopGroup = Nothing
3566
                primaryGroup.Remove(group)
3567
                Exit For
3568
            Next
3569

    
3570
        End While
3571
    End Sub
3572

    
3573
    Private Function GetBranch_SP_ID(ByVal lmConnector As LMConnector, ByVal ModelId As String) As String
3574
        Dim objPlacement As Placement = New Placement
3575

    
3576
        Dim run As LMPipeRun = objPlacement.PIDDataSource.GetPipeRun(ModelId)
3577

    
3578
        For Each oRep As LMRepresentation In run.Representations
3579
            If oRep.Attributes("RepresentationType").Value = "Branch" And oRep.Attributes("ItemStatus").Value = "Active" Then
3580
                If lmConnector.ConnectItem1SymbolID IsNot Nothing Then
3581
                    If oRep.Id = lmConnector.ConnectItem1SymbolID.ToString Then
3582
                        Return oRep.Id
3583
                    End If
3584
                End If
3585
                If lmConnector.ConnectItem2SymbolID IsNot Nothing Then
3586
                    If oRep.Id = lmConnector.ConnectItem2SymbolID.ToString Then
3587
                        Return oRep.Id
3588
                    End If
3589
                End If
3590

    
3591

    
3592
            End If
3593
        Next
3594

    
3595
        Throw New Exception("why")
3596
    End Function
3597

    
3598
    Private Sub PrimaryPipeModeling()
3599
        Try
3600
            For Each oDrwing As TreeNode In Tree_Result.Nodes
3601
                For Each oDwgNode As TreeNode In oDrwing.Nodes
3602
                    Dim sDwgName As String = Path.GetFileNameWithoutExtension(oDwgNode.Text)
3603
                    Dim CDrawing As Drawing = GetDrawing(sDwgName)
3604

    
3605
                    '' Primary Line만 가져옴
3606
                    Dim primaryLineList As List(Of Line) = New List(Of Line)
3607
                    GetPrimaryLineInNode(primaryLineList, oDwgNode)
3608

    
3609
                    '' Branch Line 가져옴
3610
                    Dim branchLines As List(Of Line) = FindBranchLine(primaryLineList)
3611

    
3612
                    '' Draw Primary Line Group
3613
                    Dim primaryGroup As List(Of List(Of Line)) = GetPrimaryGroup(CDrawing, primaryLineList)
3614
                    DrawPrimaryLineGroup(primaryGroup, primaryLineList)
3615
                Next
3616
            Next
3617
        Catch ex As Exception
3618

    
3619
        End Try
3620

    
3621
    End Sub
3622

    
3623
    Structure Pointd
3624
        Public Sub New(ByVal X As Double, ByVal Y As Double)
3625
            Me.X = X
3626
            Me.Y = Y
3627
        End Sub
3628
        Public X As Double
3629
        Public Y As Double
3630
    End Structure
3631

    
3632
    Class PointdInfo
3633
        Public Sub New(ByVal Pointd As Pointd, ByVal Type As String)
3634
            Me.Pointd = Pointd
3635
            Me.Type = Type
3636
        End Sub
3637

    
3638
        Public Sub New(ByVal Pointd As Pointd, ByVal Type As String, ByVal SP_ID As String)
3639
            Me.Pointd = Pointd
3640
            Me.Type = Type
3641
            Me.SP_ID = SP_ID
3642
        End Sub
3643

    
3644
        Public Pointd As Pointd
3645
        Public Type As String
3646
        Public SP_ID As String
3647
    End Class
3648

    
3649
    Private Function GetGroupPoint(ByVal group As List(Of Line)) As List(Of Pointd)
3650

    
3651
        Dim resultLine As List(Of Tuple(Of Line, Boolean)) = New List(Of Tuple(Of Line, Boolean))
3652
        Dim _lines As List(Of Tuple(Of Line, Boolean)) = New List(Of Tuple(Of Line, Boolean))
3653
        For Each line As Line In group
3654
            Dim tuple As Tuple(Of Line, Boolean) = New Tuple(Of Line, Boolean)(line, IsHorizontal(line))
3655
            _lines.Add(tuple)
3656
        Next
3657

    
3658

    
3659
        For Each tuple As Tuple(Of Line, Boolean) In _lines
3660
            If resultLine.Count = 0 Then
3661
                resultLine.Add(tuple)
3662
            Else
3663
                Dim prevTuple As Tuple(Of Line, Boolean) = resultLine(resultLine.Count - 1)
3664

    
3665
                If prevTuple.Item2 = tuple.Item2 Then
3666
                    resultLine.Remove(prevTuple)
3667
                    resultLine.Add(mergeLine(tuple.Item1, prevTuple.Item1, tuple.Item2))
3668
                Else
3669
                    resultLine.Add(tuple)
3670
                End If
3671
            End If
3672
        Next
3673

    
3674
        Dim pointList As List(Of Pointd) = New List(Of Pointd)
3675
        For Each tuple As Tuple(Of Line, Boolean) In resultLine
3676
            If pointList.Count = 0 Then
3677
                Dim line As Line = tuple.Item1
3678

    
3679
                Dim point1 As Pointd
3680
                point1.X = line.START_X
3681
                point1.Y = line.START_Y
3682

    
3683
                Dim point2 As Pointd
3684
                point2.X = line.END_X
3685
                point2.Y = line.END_Y
3686

    
3687
                pointList.Add(point1)
3688
                pointList.Add(point2)
3689
            Else
3690
                Dim line As Line = tuple.Item1
3691
                Dim isHorizontal As Boolean = tuple.Item2
3692

    
3693

    
3694
                Dim prevPoint1 As Pointd = pointList(pointList.Count - 2)
3695
                Dim prevPoint2 As Pointd = pointList(pointList.Count - 1)
3696
                Dim currPoint1 As Pointd = New Pointd()
3697
                currPoint1.X = line.START_X
3698
                currPoint1.Y = line.START_Y
3699
                Dim currPoint2 As Pointd = New Pointd()
3700
                currPoint2.X = line.END_X
3701
                currPoint2.Y = line.END_Y
3702

    
3703
                ''제일 작은 조합의 반대편 prevPoint를 넣어야함
3704
                Dim distance = CalcDistance(prevPoint1, currPoint1)
3705
                Dim prev = True
3706
                Dim curr = True
3707

    
3708
                If distance > CalcDistance(prevPoint1, currPoint2) Then
3709
                    distance = CalcDistance(prevPoint1, currPoint2)
3710
                    curr = False
3711
                End If
3712

    
3713
                If distance > CalcDistance(prevPoint2, currPoint1) Then
3714
                    distance = CalcDistance(prevPoint2, currPoint1)
3715
                    prev = False
3716
                    curr = True
3717
                End If
3718

    
3719
                If distance > CalcDistance(prevPoint2, currPoint2) Then
3720
                    distance = CalcDistance(prevPoint2, currPoint2)
3721
                    prev = False
3722
                    curr = False
3723
                End If
3724

    
3725
                pointList.RemoveAt(pointList.Count - 2)
3726
                pointList.RemoveAt(pointList.Count - 1)
3727

    
3728
                ' 지금은 수평 / 이전 수직
3729
                If isHorizontal Then
3730
                    If prev Then
3731
                        pointList.Add(prevPoint2)
3732

    
3733
                        If curr Then
3734
                            Dim newPoint As Pointd = New Pointd()
3735
                            newPoint.X = prevPoint2.X
3736
                            newPoint.Y = currPoint2.Y
3737
                            pointList.Add(newPoint)
3738

    
3739
                            pointList.Add(currPoint2)
3740
                        Else
3741
                            Dim newPoint As Pointd = New Pointd()
3742
                            newPoint.X = prevPoint2.X
3743
                            newPoint.Y = currPoint1.Y
3744
                            pointList.Add(newPoint)
3745

    
3746
                            pointList.Add(currPoint1)
3747
                        End If
3748
                    Else
3749
                        pointList.Add(prevPoint1)
3750

    
3751
                        If curr Then
3752
                            Dim newPoint As Pointd = New Pointd()
3753
                            newPoint.X = prevPoint1.X
3754
                            newPoint.Y = currPoint2.Y
3755
                            pointList.Add(newPoint)
3756

    
3757
                            pointList.Add(currPoint2)
3758
                        Else
3759
                            Dim newPoint As Pointd = New Pointd()
3760
                            newPoint.X = prevPoint1.X
3761
                            newPoint.Y = currPoint1.Y
3762
                            pointList.Add(newPoint)
3763

    
3764
                            pointList.Add(currPoint1)
3765
                        End If
3766
                    End If
3767
                    '지금은 수직 / 이전 수평
3768
                Else
3769
                    If prev Then
3770
                        pointList.Add(prevPoint2)
3771

    
3772
                        If curr Then
3773
                            Dim newPoint As Pointd = New Pointd()
3774
                            newPoint.X = currPoint2.X
3775
                            newPoint.Y = prevPoint2.Y
3776
                            pointList.Add(newPoint)
3777

    
3778
                            pointList.Add(currPoint2)
3779
                        Else
3780
                            Dim newPoint As Pointd = New Pointd()
3781
                            newPoint.X = currPoint1.X
3782
                            newPoint.Y = prevPoint2.Y
3783
                            pointList.Add(newPoint)
3784

    
3785
                            pointList.Add(currPoint1)
3786
                        End If
3787
                    Else
3788
                        pointList.Add(prevPoint1)
3789

    
3790
                        If curr Then
3791
                            Dim newPoint As Pointd = New Pointd()
3792
                            newPoint.X = currPoint2.X
3793
                            newPoint.Y = prevPoint1.Y
3794
                            pointList.Add(newPoint)
3795

    
3796
                            pointList.Add(currPoint2)
3797
                        Else
3798
                            Dim newPoint As Pointd = New Pointd()
3799
                            newPoint.X = currPoint1.X
3800
                            newPoint.Y = prevPoint1.Y
3801
                            pointList.Add(newPoint)
3802

    
3803
                            pointList.Add(currPoint1)
3804
                        End If
3805
                    End If
3806
                End If
3807
            End If
3808
        Next
3809

    
3810
        Return pointList
3811
    End Function
3812

    
3813
    Private Function CalcDistance(ByVal point1 As Pointd, ByVal point2 As Pointd) As Double
3814
        Return Math.Pow(Math.Sqrt(Math.Abs(point1.X - point2.X)) + Math.Sqrt(Math.Abs(point1.Y - point2.Y)), 0.5)
3815
    End Function
3816

    
3817
    Private Function mergeLine(line1 As Line, line2 As Line, isHorizontal As Boolean) As Tuple(Of Line, Boolean)
3818
        If isHorizontal Then
3819
            Dim min As Double = Math.Min(line1.START_X, Math.Min(line1.END_X, Math.Min(line2.START_X, line2.END_X)))
3820
            Dim max As Double = Math.Max(line1.START_X, Math.Max(line1.END_X, Math.Max(line2.START_X, line2.END_X)))
3821

    
3822
            Dim nLine As Line = New Line()
3823
            nLine.START_X = min
3824
            nLine.START_Y = line1.START_Y
3825
            nLine.END_X = max
3826
            nLine.END_Y = line1.START_Y
3827

    
3828
            Dim tuple As Tuple(Of Line, Boolean) = New Tuple(Of Line, Boolean)(nLine, isHorizontal)
3829
            Return tuple
3830
        Else
3831
            Dim min As Double = Math.Min(line1.START_Y, Math.Min(line1.END_Y, Math.Min(line2.START_Y, line2.END_Y)))
3832
            Dim max As Double = Math.Max(line1.START_Y, Math.Max(line1.END_Y, Math.Max(line2.START_Y, line2.END_Y)))
3833

    
3834
            Dim nLine As Line = New Line()
3835
            nLine.START_X = line1.START_X
3836
            nLine.START_Y = min
3837
            nLine.END_X = line1.START_X
3838
            nLine.END_Y = max
3839

    
3840
            Dim tuple As Tuple(Of Line, Boolean) = New Tuple(Of Line, Boolean)(nLine, isHorizontal)
3841
            Return tuple
3842
        End If
3843

    
3844
    End Function
3845

    
3846
    Private Sub FindNearPoint(ByVal oOPCSymbol As LMSymbol, ByRef dNear_x As Double, ByRef dNear_y As Double)
3847
        Dim oConnectionPoints_x(4) As Double
3848
        Dim oConnectionPoints_y(4) As Double
3849

    
3850
        Try
3851
            _Placement.PIDConnectPointLocation(oOPCSymbol, 1, oConnectionPoints_x(0), oConnectionPoints_y(0))
3852
            _Placement.PIDConnectPointLocation(oOPCSymbol, 2, oConnectionPoints_x(1), oConnectionPoints_y(1))
3853
            _Placement.PIDConnectPointLocation(oOPCSymbol, 3, oConnectionPoints_x(2), oConnectionPoints_y(2))
3854
            _Placement.PIDConnectPointLocation(oOPCSymbol, 4, oConnectionPoints_x(3), oConnectionPoints_y(3))
3855
            Dim iNearPoint As Integer = 0
3856
            Dim dGap As Double = 0
3857
            For i = 0 To 3
3858
                If dGap = 0 Then
3859
                    iNearPoint = i
3860
                    dGap = Math.Abs(oConnectionPoints_x(i) - dNear_x) + Math.Abs(oConnectionPoints_y(i) - dNear_y)
3861
                Else
3862
                    If dGap >= Math.Abs(oConnectionPoints_x(i) - dNear_x) + Math.Abs(oConnectionPoints_y(i) - dNear_y) Then
3863
                        iNearPoint = i
3864
                        dGap = Math.Abs(oConnectionPoints_x(i) - dNear_x) + Math.Abs(oConnectionPoints_y(i) - dNear_y)
3865
                    End If
3866
                End If
3867
            Next
3868
            dNear_x = oConnectionPoints_x(iNearPoint)
3869
            dNear_y = oConnectionPoints_y(iNearPoint)
3870
        Catch ex As Exception
3871

    
3872
        End Try
3873

    
3874
    End Sub
3875

    
3876
    Private Function GetPipeColor(ByVal sType As String) As Color
3877
        If sType.ToUpper() = "ELECTRIC" Then
3878
            Return Color.DarkOrange
3879
        ElseIf sType.ToUpper() = "CONNECT TO PROCESS" Then
3880
            Return Color.Green
3881
        ElseIf sType.ToUpper() = "SOFTWARE" Then
3882
            Return Color.Blue
3883
        ElseIf sType.ToUpper() = "PNEUMATIC" Then
3884
            Return Color.Gray
3885
        Else
3886
            Return Color.Black
3887
        End If
3888
    End Function
3889

    
3890
    Private Function GetPipeType(ByVal sType As String) As String
3891
        Dim sSystempath As String = "\Piping\Routing\Process Lines\Primary Piping.sym" ' oPipeRow(0)(_XML_LINE_SYSTEMPATH).ToString()
3892
        If sType.ToUpper() = "ELECTRIC" Then
3893
            sSystempath = "\Instrumentation\Signal Line\Electric.sym"
3894
        ElseIf sType.ToUpper() = "CONNECT TO PROCESS" Then
3895
            sSystempath = "\Instrumentation\Signal Line\Connect to Process.sym"
3896
        ElseIf sType.ToUpper() = "SOFTWARE" Then
3897
            sSystempath = "\Instrumentation\Signal Line\Software Link.sym"
3898
        ElseIf sType.ToUpper() = "PNEUMATIC" Then
3899
            sSystempath = "\Instrumentation\Signal Line\Pneumatic.sym"
3900
        Else
3901
        End If
3902
        Return sSystempath
3903
    End Function
3904

    
3905
    Private Sub InitAutoRouting()
3906
        For Each oDrwing As TreeNode In Tree_Result.Nodes
3907
            For Each oDwgNode As TreeNode In oDrwing.Nodes
3908
                Dim sDwgName As String = Path.GetFileNameWithoutExtension(oDwgNode.Text)
3909
                Dim CDrawing As Drawing = GetDrawing(sDwgName)
3910
                If CDrawing IsNot Nothing Then
3911
                    Dim iAllLineNoCount As Integer = Tree_Result.Nodes.Count ' GetCheckNodeCount(oLinenoNode)
3912
                    Dim iPipingOPC_count As Integer = 0 ' GetCheckNodeCount(oLinenoNode)
3913
                    SetListBoxItems(ListBox_Result, "Place " & CDrawing.DwgName & "....")
3914

    
3915
                    For Each oNode As TreeNode In oDwgNode.Nodes
3916
                        Dim iItemcnt As Integer = 0
3917
                        Dim sNodeUid As String = oNode.Name
3918
                        Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
3919
                        Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
3920
                        If CLineNo IsNot Nothing Then
3921
                            Dim oLine_Dt As DataTable = CLineNo.Dt_Line
3922
                            Dim oSymbol_Dt As DataTable = CLineNo.Dt_Symbol
3923

    
3924
                            For Each oLineRow In oLine_Dt.Rows
3925
                                ' oLineRow(_XML_LINE_UID) = ""
3926
                                oLineRow(_XML_LINE_SPID) = ""
3927
                                oLineRow(_XML_LINE_LMCONNECTOR) = Nothing
3928
                                oLineRow(_XML_LINE_LMCONNECTOR_1) = Nothing
3929
                                oLineRow(_XML_LINE_LMCONNECTOR_2) = Nothing
3930
                                oLineRow(_XML_LINE_DRAWING_TF) = "FALSE"
3931
                                oLineRow(_XML_LINE_Check) = "FALSE"
3932
                            Next
3933
                            For Each oSymbolRow In oSymbol_Dt.Rows
3934
                                '   oSymbolRow(_XML_SYMBOL_UID) = ""
3935
                                oSymbolRow(_XML_SYMBOL_SPID) = ""
3936
                                oSymbolRow(_XML_SYMBOL_LMSYMBOL) = Nothing
3937
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_1) = Nothing
3938
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_2) = Nothing
3939
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_3) = Nothing
3940
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_4) = Nothing
3941
                                oSymbolRow(_XML_SYMBOL_Check) = "FALSE"
3942
                                oSymbolRow(_XML_SYMBOL_DRAWING_TF) = "FALSE"
3943

    
3944
                            Next
3945

    
3946
                        End If
3947

    
3948
                        Dim CTRIMLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
3949
                        If CTRIMLineNo IsNot Nothing Then
3950
                            Dim oLine_Dt As DataTable = CTRIMLineNo.Dt_Line
3951
                            Dim oSymbol_Dt As DataTable = CTRIMLineNo.Dt_Symbol
3952

    
3953
                            For Each oLineRow In oLine_Dt.Rows
3954
                                ' oLineRow(_XML_LINE_UID) = ""
3955
                                oLineRow(_XML_LINE_SPID) = ""
3956
                                oLineRow(_XML_LINE_LMCONNECTOR) = Nothing
3957
                                oLineRow(_XML_LINE_LMCONNECTOR_1) = Nothing
3958
                                oLineRow(_XML_LINE_LMCONNECTOR_2) = Nothing
3959
                                oLineRow(_XML_LINE_DRAWING_TF) = "FALSE"
3960
                                oLineRow(_XML_LINE_Check) = "FALSE"
3961
                            Next
3962
                            For Each oSymbolRow In oSymbol_Dt.Rows
3963
                                '   oSymbolRow(_XML_SYMBOL_UID) = ""
3964
                                oSymbolRow(_XML_SYMBOL_SPID) = ""
3965
                                oSymbolRow(_XML_SYMBOL_LMSYMBOL) = Nothing
3966
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_1) = Nothing
3967
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_2) = Nothing
3968
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_3) = Nothing
3969
                                oSymbolRow(_XML_SYMBOL_LMCONNECTOR_4) = Nothing
3970
                                oSymbolRow(_XML_SYMBOL_Check) = "FALSE"
3971
                                oSymbolRow(_XML_SYMBOL_DRAWING_TF) = "FALSE"
3972

    
3973
                            Next
3974

    
3975
                        End If
3976
                    Next
3977
                End If
3978
            Next
3979
        Next
3980
    End Sub
3981

    
3982

    
3983

    
3984

    
3985

    
3986

    
3987
    Private Function CheckBranchLine(ByVal dStartX As Double, ByVal dStartY As Double,
3988
                                ByRef dEndX As Double, ByRef dEndY As Double, ByRef sBranchType As String, ByRef oLMConnector As LMConnector) As Boolean
3989

    
3990
        Try
3991

    
3992
            For Each oModelrow In _ModelingLine_Dt.Rows
3993
                'Dim sStartPoint As String = oModelrow(_XML_LINE_STARTPOINT)
3994
                'Dim sEndPoint As String = oModelrow(_XML_LINE_ENDPOINT)
3995
                Dim dModelStartX As Double
3996
                Dim dModelStartY As Double
3997
                Dim dModelEndX As Double
3998
                Dim dModelEndY As Double
3999
                dModelStartX = oModelrow(_XML_LINE_DWG_STARTPOINT_X)
4000
                dModelStartY = oModelrow(_XML_LINE_DWG_STARTPOINT_Y)
4001
                dModelEndX = oModelrow(_XML_LINE_DWG_ENDPOINT_X)
4002
                dModelEndY = oModelrow(_XML_LINE_DWG_ENDPOINT_Y)
4003
                'ConvertPointBystring(sStartPoint, dModelStartX, dModelStartY)
4004
                'ConvertPointBystring(sEndPoint, dModelEndX, dModelEndY)
4005
                'ConvertPointByImage(dModelStartX, dModelStartY, _IMG_X, _IMG_Y)
4006
                'ConvertPointByImage(dModelEndX, dModelEndY, _IMG_X, _IMG_Y)
4007
                Dim dGap As Double = 0.0002
4008
                Dim d기준x As Double = (dModelStartX + dModelEndX) / 2
4009
                Dim d기준y As Double = (dModelStartY + dModelEndY) / 2
4010
                Try
4011
                    oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4012
                Catch ex As Exception
4013

    
4014
                End Try
4015
                Dim oRun As LMPipeRun = Nothing
4016
                Try
4017

    
4018
                    oRun = _Placement.PIDDataSource.GetPipeRun(oLMConnector.ModelItemID)
4019
                    Dim dResultCalc As Double = -1
4020
                    For Each objRep In oRun.Representations
4021
                        If objRep.Attributes("RepresentationType").Value = "Connector" And objRep.Attributes("ItemStatus").Value = "Active" Then
4022
                            Dim objConnector As LMConnector = _Placement.PIDDataSource.GetConnector(objRep.ID)
4023
                            For Each objConnectorVertex In objConnector.ConnectorVertices
4024
                                Dim dConn_X As Double = objConnectorVertex.Attributes("XCoordinate").Value
4025
                                Dim dConn_Y As Double = objConnectorVertex.Attributes("YCoordinate").Value
4026
                                Dim dStartCalc As Double = Math.Abs(dStartX - dConn_X) + Math.Abs(dStartY - dConn_Y)
4027

    
4028
                                If dResultCalc > dStartCalc Or dResultCalc = -1 Then
4029
                                    dResultCalc = dStartCalc
4030
                                    oLMConnector = objConnector
4031
                                    d기준x = dConn_X
4032
                                    d기준y = dConn_Y
4033
                                End If
4034
                                Dim dEndCalc As Double = Math.Abs(dEndX - dConn_X) + Math.Abs(dEndY - dConn_Y)
4035
                                If dResultCalc > dEndCalc Then
4036
                                    dResultCalc = dEndCalc
4037
                                    oLMConnector = objConnector
4038
                                    d기준x = dConn_X
4039
                                    d기준y = dConn_Y
4040
                                End If
4041
                            Next
4042
                        End If
4043
                    Next
4044
                    '        _Placement.PIDConnectPointLocation(oRun, 1, dModelStartX, dModelEndX)
4045
                    '       _Placement.PIDConnectPointLocation(oRun, 2, dModelEndX, dModelEndY)
4046
                Catch ex As Exception
4047
                End Try
4048

    
4049

    
4050
                'Dim sSPID As String = oModelrow(_XML_LINE_SPID).ToString()
4051
                'Dim oPipeRun As LMPipeRun = _Placement.PIDDataSource.Get PipeRun(sSPID)
4052
                'If dModelStartX + dGap > dStartX And dModelStartX - dGap < dStartX And
4053
                '        dModelStartY + dGap > dStartY And dModelStartY - dGap < dStartY Then
4054
                '    dStartX = dModelStartX
4055
                '    dStartY = dModelStartY
4056
                'ElseIf dModelEndX + dGap > dStartX And dModelEndX - dGap < dStartX And
4057
                '        dModelEndY + dGap > dStartY And dModelEndY - dGap < dStartY Then
4058
                '    dStartX = dModelEndX
4059
                '    dStartY = dModelEndY
4060
                'End If
4061

    
4062
                'Vetical
4063
                If Math.Abs(dModelStartX - dModelEndX) <= Math.Abs(dModelStartY - dModelEndY) Then
4064
                    If Math.Abs(dStartX - dEndX) >= Math.Abs(dStartY - dEndY) Then
4065
                        'Horizontal 
4066
                        ' dGap = 0.0002 'Math.Abs(dStartX - dEndX) / 20
4067
                        '기준선의 Y범위안에 가로선이 포함되어야됨
4068
                        If (dModelStartY + dGap >= dStartY And dModelEndY - dGap <= dStartY) Or
4069
                            (dModelStartY - dGap <= dStartY And dModelEndY + dGap >= dStartY) And
4070
                            (dModelStartY + dGap >= dEndY And dModelEndY - dGap <= dEndY) Or
4071
                            (dModelStartY - dGap <= dEndY And dModelEndY + dGap >= dEndY) Then
4072
                            '기준선보다 왼쪽에 가로선이 있을때
4073
                            If d기준x >= dStartX And d기준x >= dEndX Then
4074
                                If dStartX >= dEndX Then
4075
                                    'dStartX 좌표를 기준으로 Gap만큼 더했을때 기준선보다 큰지 확인
4076
                                    If dStartX + dGap >= d기준x Then
4077
                                        dStartX = d기준x
4078
                                        sBranchType = "1"
4079
                                        Return True
4080
                                    End If
4081
                                Else
4082
                                    'dEndX 좌표를 기준으로 Gap만큼 더했을때 기준선보다 큰지 확인
4083
                                    If dEndX + dGap >= d기준x Then
4084
                                        dEndX = d기준x
4085
                                        sBranchType = "2"
4086
                                        Return True
4087
                                    End If
4088
                                End If
4089
                                '기준선보다 오른쪽에 가로선이 있을때
4090
                            ElseIf d기준x <= dStartX And d기준x <= dEndX Then
4091
                                If dStartX >= dEndX Then
4092
                                    'dEndX 좌표를 기준으로 Gap만큼 뺐을때 기준선보다 작은지 확인
4093
                                    If dEndX - dGap <= d기준x Then
4094
                                        dEndX = d기준x
4095
                                        sBranchType = "2"
4096
                                        Return True
4097
                                    End If
4098
                                Else
4099
                                    'dStartX 좌표를 기준으로 Gap만큼 뺐을때 기준선보다 작은지 확인
4100
                                    If dStartX - dGap <= d기준x Then
4101
                                        dStartX = d기준x
4102
                                        sBranchType = "1"
4103
                                        Return True
4104
                                    End If
4105
                                End If
4106
                            Else
4107
                                '기준선과 세로선이 겹칠때
4108
                                If (d기준x >= dStartX And d기준x <= dEndX) Or
4109
                                        (d기준x <= dStartX And d기준x >= dEndX) Then
4110
                                    If (dModelStartY <= dStartY And dModelEndY >= dEndY) Or
4111
                                        (dModelStartY >= dStartY And dModelEndY <= dEndY) Then
4112
                                        '기준선이 dStartX와 dEndX중 어느쪽에 가까운지 확인
4113
                                        '가로선의 왼쪽점과 기준선이 가까울때는 gap만큼 뺐을때 기준선보다 작은지확인
4114
                                        '가로선의 오른쪽점과 기준선이 가까울때는 gap만큼 더했을때 기준선보다 큰지확인
4115
                                        If Math.Abs(d기준x - dStartX) >= Math.Abs(d기준x - dEndX) Then
4116
                                            'EndX점이 기준선과 더 가까이 있음
4117
                                            If dStartX >= dEndX Then
4118
                                                '가로선의 왼쪽점과 기준선이 가까우므로 gap만큼 뺐을때 기준선보다 작은지확인
4119
                                                If dEndX - dGap <= d기준x Then
4120
                                                    dEndX = d기준x
4121
                                                    sBranchType = "4"
4122
                                                    Return True
4123
                                                End If
4124
                                            Else
4125
                                                '가로선의 오른쪽점과 기준선이 가까우므로 gap만큼 더했을때 기준선보다 큰지확인
4126
                                                If dEndX + dGap >= d기준x Then
4127
                                                    dEndX = d기준x
4128
                                                    sBranchType = "4"
4129
                                                    Return True
4130
                                                End If
4131

    
4132
                                            End If
4133
                                        Else
4134
                                            'dStartX점이 기준선과 더 가까이 있음
4135
                                            If dStartX >= dEndX Then
4136
                                                '가로선의 오른쪽점과 기준선이 가까우므로 gap만큼 더했을때 기준선보다 큰지확인
4137
                                                If dStartX + dGap >= d기준x Then
4138
                                                    dStartX = d기준x
4139
                                                    sBranchType = "3"
4140
                                                    Return True
4141
                                                End If
4142

    
4143
                                            Else
4144
                                                '가로선의 왼쪽점과 기준선이 가까우므로 gap만큼 뺐을때 기준선보다 작은지확인
4145
                                                If dStartX - dGap <= d기준x Then
4146
                                                    dStartX = d기준x
4147
                                                    sBranchType = "3"
4148
                                                    Return True
4149
                                                End If
4150
                                            End If
4151
                                        End If
4152
                                    End If
4153

    
4154
                                End If
4155
                            End If
4156
                        End If
4157

    
4158
                    End If
4159
                Else
4160
                    'Horizontal
4161
                    If Math.Abs(dModelStartX - dModelEndX) >= Math.Abs(dModelStartY - dModelEndY) Then
4162
                        'Vertical
4163
                        If Math.Abs(dStartX - dEndX) <= Math.Abs(dStartY - dEndY) Then
4164
                            '  dGap = 0.0015 'Math.Abs(dStartY - dEndY) / 80
4165

    
4166
                            '기준선의 X범위안에 세로선이 포함되어야됨
4167
                            If ((dModelStartX + dGap >= dStartX And dModelEndX - dGap <= dStartX) Or
4168
                            (dModelStartX - dGap <= dStartX And dModelEndX + dGap >= dStartX)) And
4169
                            ((dModelStartX + dGap >= dEndX And dModelEndX - dGap <= dEndX) Or
4170
                            (dModelStartX - dGap <= dEndX And dModelEndX + dGap >= dEndX)) Then
4171

    
4172
                                '가로선보다 아래에 세로선이 있을때
4173
                                If d기준y >= dStartY And d기준y >= dEndY Then
4174
                                    If dStartY >= dEndY Then
4175
                                        'dStartY 좌표를 기준으로 Gap만큼 더했을때 기준선보다 큰지 확인
4176
                                        If dStartY + dGap >= d기준y Then
4177
                                            dStartY = d기준y
4178
                                            sBranchType = "3"
4179
                                            Return True
4180
                                        End If
4181
                                    Else
4182
                                        'dEndY 좌표를 기준으로 Gap만큼 더했을때 기준선보다 큰지 확인
4183
                                        If dEndY + dGap >= d기준y Then
4184
                                            dEndY = d기준y
4185

    
4186
                                            If Math.Abs(dEndX - dModelStartX) > Math.Abs(dEndX - dModelEndX) Then
4187
                                                dEndX = dModelEndX
4188
                                            Else
4189
                                                dEndX = dModelStartX
4190
                                            End If
4191

    
4192
                                            sBranchType = "4"
4193
                                            Return True
4194
                                        End If
4195
                                    End If
4196
                                    '기준선보다 위에 세로선이 있을때
4197
                                ElseIf d기준y <= dStartY And d기준y <= dEndY Then
4198
                                    If dStartY >= dEndY Then
4199
                                        'dEndY 좌표를 기준으로 Gap만큼 뺐을때 기준선보다 작은지 확인
4200
                                        If dEndY - dGap <= d기준y Then
4201
                                            dEndY = d기준y
4202
                                            sBranchType = "4"
4203
                                            Return True
4204
                                        End If
4205
                                    Else
4206
                                        'dStartY 좌표를 기준으로 Gap만큼 뺐을때 기준선보다 작은지 확인
4207
                                        If dStartY - dGap <= d기준y Then
4208
                                            dStartY = d기준y
4209
                                            sBranchType = "3"
4210
                                            Return True
4211
                                        End If
4212
                                    End If
4213
                                Else
4214
                                    '기준선과 세로선이 겹칠때
4215
                                    If (d기준y >= dStartY And d기준y <= dEndY) Or
4216
                                            (d기준y <= dStartY And d기준y >= dEndY) Then
4217
                                        '기준선이 dStartY와 dEndY중 어느쪽에 가까운지 확인
4218
                                        '세로선의 윗점과 기준선이 가까울때는 gap만큼 뺐을때 기준선보다 작은지확인
4219
                                        '세로선의 아래점과 기준선이 가까울때는 gap만큼 더했을때 기준선보다 큰지확인
4220
                                        If (dModelStartX <= dStartX And dModelEndX >= dEndX) Or
4221
                                            (dModelStartX >= dStartX And dModelEndX <= dEndX) Then
4222
                                            If Math.Abs(d기준y - dStartY) >= Math.Abs(d기준y - dEndY) Then
4223
                                                'Endy점이 기준선과 더 가까이 있음
4224
                                                If dStartY >= dEndY Then
4225
                                                    '세로선의 아래점과 기준선이 가까우므로 gap만큼 더했을때 기준선보다 큰지확인
4226
                                                    If dEndY + dGap >= d기준y Then
4227
                                                        dEndY = d기준y
4228
                                                        sBranchType = "4"
4229
                                                        Return True
4230
                                                    End If
4231
                                                Else
4232
                                                    '세로선의 윗점과 기준선이 가까우므로 gap만큼 뺐을때 기준선보다 작은지확인
4233
                                                    If dEndY - dGap <= d기준y Then
4234
                                                        dEndY = d기준y
4235
                                                        sBranchType = "4"
4236
                                                        Return True
4237
                                                    End If
4238
                                                End If
4239
                                            Else
4240
                                                'dStartY점이 기준선과 더 가까이 있음
4241
                                                If dStartY >= dEndY Then
4242
                                                    '세로선의 윗점과 기준선이 가까우므로 gap만큼 뺐을때 기준선보다 작은지확인
4243
                                                    If dStartY - dGap <= d기준y Then
4244
                                                        dStartY = d기준y
4245
                                                        sBranchType = "3"
4246
                                                        Return True
4247
                                                    End If
4248
                                                Else
4249
                                                    '세로선의 아래점과 기준선이 가까우므로 gap만큼 더했을때 기준선보다 큰지확인
4250
                                                    If dStartY + dGap >= d기준y Then
4251
                                                        dStartY = d기준y
4252
                                                        sBranchType = "3"
4253
                                                        Return True
4254
                                                    End If
4255
                                                End If
4256
                                            End If
4257
                                        End If
4258

    
4259
                                    End If
4260
                                End If
4261
                            End If
4262
                        End If
4263
                    End If
4264
                End If
4265
            Next
4266
        Catch ex As Exception
4267

    
4268
        End Try
4269
        oLMConnector = Nothing
4270
        Return False
4271
    End Function
4272

    
4273
    Private Function CheckConnectionSymbolToSymbol(ByVal oModelingLineRows() As DataRow, ByRef dX As Double, ByRef dY As Double,
4274
                                  ByRef oLMConnector As LMConnector) As Boolean
4275
        Dim bConnectionFlag As Boolean = False
4276
        Try
4277
            For Each oModelrow In oModelingLineRows
4278
                Dim d기준x As Double = dX
4279
                Dim d기준y As Double = dY
4280
                Dim dGap As Double = 0.0002
4281
                Dim oRun As LMPipeRun = Nothing
4282
                Try
4283
                    Dim oLMSymbol As LMSymbol = oModelrow(_XML_SYMBOL_LMSYMBOL)
4284
                    Dim dX1 As Double = 0.0
4285
                    Dim dY1 As Double = 0.0
4286
                    Dim dX2 As Double = 0.0
4287
                    Dim dY2 As Double = 0.0
4288
                    For Each oConnector In oLMSymbol.Connect1Connectors
4289
                        oLMConnector = oConnector
4290
                    Next
4291
                    '  oRun = _Placement.PIDDataSource.GetPipeRun(oLMSymbol.Connect1Connectors.Nth(1).ModelItemID)
4292
                    _Placement.PIDConnectPointLocation(oLMSymbol, 1, dX1, dY1)
4293
                    _Placement.PIDConnectPointLocation(oLMSymbol, 2, dX2, dY2)
4294
                    If Math.Abs(dX - dX1) < dGap And Math.Abs(dY - dY1) < dGap Then
4295
                        dX = dX1
4296
                        dY = dY1
4297
                        bConnectionFlag = True
4298
                        Exit For
4299
                    End If
4300
                    If Math.Abs(dX - dX2) < dGap And Math.Abs(dY - dY2) < dGap Then
4301
                        dX = dX2
4302
                        dY = dY2
4303
                        bConnectionFlag = True
4304
                        Exit For
4305
                    End If
4306

    
4307
                    'For Each oConnector In oLMSymbol.Connect1Connectors
4308
                    '    For Each objConnectorVertex In oConnector.ConnectorVertices
4309
                    '        Dim dConn_X As Double = objConnectorVertex.Attributes("XCoordinate").Value
4310
                    '        Dim dConn_Y As Double = objConnectorVertex.Attributes("YCoordinate").Value
4311
                    '        If Math.Abs(dX - dConn_X) < dGap And Math.Abs(dY - dConn_Y) < dGap Then
4312
                    '            oLMConnector = oConnector
4313
                    '            dX = dConn_X
4314
                    '            dY = dConn_Y
4315
                    '            bConnectionFlag = True
4316
                    '            Exit For
4317
                    '        End If
4318
                    '    Next
4319
                    'Next
4320

    
4321
                    'For Each oConnector In oLMSymbol.Connect2Connectors
4322
                    '    For Each objConnectorVertex In oConnector.ConnectorVertices
4323
                    '        Dim dConn_X As Double = objConnectorVertex.Attributes("XCoordinate").Value
4324
                    '        Dim dConn_Y As Double = objConnectorVertex.Attributes("YCoordinate").Value
4325
                    '        If Math.Abs(dX - dConn_X) < dGap And Math.Abs(dY - dConn_Y) < dGap Then
4326
                    '            oLMConnector = oConnector
4327
                    '            dX = dConn_X
4328
                    '            dY = dConn_Y
4329
                    '            bConnectionFlag = True
4330
                    '            Exit For
4331
                    '        End If
4332
                    '    Next
4333
                    'Next
4334

    
4335

    
4336
                    'If oRun IsNot Nothing Then
4337
                    '    Dim dResultCalc As Double = -1
4338
                    '    For Each objRep In oRun.Representations
4339
                    '        Dim sRepresentationType As String = objRep.Attributes("RepresentationType").Value
4340
                    '        If objRep.Attributes("RepresentationType").Value = "Connector" Or
4341
                    '            objRep.Attributes("RepresentationType").Value = "Symbol" And
4342
                    '             objRep.Attributes("ItemStatus").Value = "Active" Then
4343
                    '            Dim objConnector As LMConnector = _Placement.PIDDataSource.GetConnector(objRep.ID)
4344
                    '            For Each objConnectorVertex In objConnector.ConnectorVertices
4345
                    '                Dim dConn_X As Double = objConnectorVertex.Attributes("XCoordinate").Value
4346
                    '                Dim dConn_Y As Double = objConnectorVertex.Attributes("YCoordinate").Value
4347
                    '                If Math.Abs(dX - dConn_X) < dGap And Math.Abs(dY - dConn_Y) < dGap Then
4348
                    '                    oLMConnector = objConnector
4349
                    '                    d기준x = dConn_X
4350
                    '                    d기준y = dConn_Y
4351
                    '                    bConnectionFlag = True
4352
                    '                    Exit For
4353
                    '                End If
4354
                    '            Next
4355
                    '        End If
4356
                    '    Next
4357
                    'End If
4358

    
4359
                Catch ex As Exception
4360
                End Try
4361
            Next
4362

    
4363
        Catch ex As Exception
4364

    
4365
        End Try
4366
        Return bConnectionFlag
4367
    End Function
4368

    
4369
    Private Function CheckConnectionSymbolToLine(ByVal oModelingLineRows() As DataRow, ByRef dX As Double, ByRef dY As Double,
4370
ByVal dCenterX As Double, ByVal dCenterY As Double, ByRef oLMConnector As LMConnector) As LMSymbol
4371
        Dim bConnectionFlag As Boolean = False
4372
        Dim oLMSymbol As LMSymbol = Nothing
4373
        Try
4374

    
4375
            For Each oModelrow In _ModelingSymbol_Dt.Rows
4376
                Dim dMinx As Double = oModelrow(_XML_SYMBOL_MIN_X)
4377
                Dim dMaxx As Double = oModelrow(_XML_SYMBOL_MAX_X)
4378
                Dim dMiny As Double = oModelrow(_XML_SYMBOL_MIN_Y)
4379
                Dim dMaxy As Double = oModelrow(_XML_SYMBOL_MAX_Y)
4380
                Dim dGap As Double = 0.001
4381
                If dMinx <= dX And dMaxx >= dX And dMiny <= dY And dMaxy >= dY Then
4382
                    oLMSymbol = oModelrow(_XML_SYMBOL_LMSYMBOL)
4383
                    Dim dX1 As Double = 0.0
4384
                    Dim dY1 As Double = 0.0
4385
                    Dim dX2 As Double = 0.0
4386
                    Dim dY2 As Double = 0.0
4387
                    Dim dX3 As Double = 0.0
4388
                    Dim dY3 As Double = 0.0
4389
                    Dim dX4 As Double = 0.0
4390
                    Dim dY4 As Double = 0.0
4391
                    Dim dX5 As Double = 0.0
4392
                    Dim dY5 As Double = 0.0
4393
                    Dim dX6 As Double = 0.0
4394
                    Dim dY6 As Double = 0.0
4395
                    Dim dX7 As Double = 0.0
4396
                    Dim dY7 As Double = 0.0
4397
                    Dim dX8 As Double = 0.0
4398
                    Dim dY8 As Double = 0.0
4399
                    _Placement.PIDConnectPointLocation(oLMSymbol, 1, dX1, dY1)
4400
                    _Placement.PIDConnectPointLocation(oLMSymbol, 2, dX2, dY2)
4401
                    _Placement.PIDConnectPointLocation(oLMSymbol, 3, dX3, dY3)
4402
                    _Placement.PIDConnectPointLocation(oLMSymbol, 4, dX4, dY4)
4403
                    _Placement.PIDConnectPointLocation(oLMSymbol, 5, dX5, dY5)
4404
                    _Placement.PIDConnectPointLocation(oLMSymbol, 6, dX6, dY6)
4405
                    _Placement.PIDConnectPointLocation(oLMSymbol, 7, dX7, dY7)
4406
                    _Placement.PIDConnectPointLocation(oLMSymbol, 8, dX8, dY8)
4407

    
4408
                    If Math.Abs(dX - dX1) <= dGap And Math.Abs(dY - dY1) <= dGap Then
4409
                        dX = dX1
4410
                        dY = dY1
4411
                    ElseIf Math.Abs(dX - dX2) <= dGap And Math.Abs(dY - dY2) <= dGap Then
4412
                        dX = dX2
4413
                        dY = dY2
4414
                    ElseIf Math.Abs(dX - dX3) <= dGap And Math.Abs(dY - dY3) <= dGap Then
4415
                        dX = dX3
4416
                        dY = dY3
4417
                    ElseIf Math.Abs(dX - dX4) <= dGap And Math.Abs(dY - dY4) <= dGap Then
4418
                        dX = dX4
4419
                        dY = dY4
4420
                    ElseIf Math.Abs(dX - dX5) <= dGap And Math.Abs(dY - dY5) <= dGap Then
4421
                        dX = dX5
4422
                        dY = dY5
4423
                    ElseIf Math.Abs(dX - dX6) <= dGap And Math.Abs(dY - dY6) <= dGap Then
4424
                        dX = dX6
4425
                        dY = dY6
4426
                    ElseIf Math.Abs(dX - dX7) <= dGap And Math.Abs(dY - dY7) <= dGap Then
4427
                        dX = dX7
4428
                        dY = dY7
4429
                    ElseIf Math.Abs(dX - dX8) <= dGap And Math.Abs(dY - dY8) <= dGap Then
4430
                        dX = dX8
4431
                        dY = dY8
4432
                    End If
4433
                End If
4434
            Next
4435

    
4436

    
4437

    
4438
            'For Each oModelrow In oModelingLineRows
4439
            '    Dim d기준x As Double = dCenterX
4440
            '    Dim d기준y As Double = dCenterY
4441
            '    Dim dGap As Double = 0.001
4442
            '    Dim oRun As LMPipeRun = Nothing
4443
            '    Dim dCheckGap As Double = 0
4444
            '    Try
4445

    
4446
            '        Dim dX1 As Double = 0.0
4447
            '        Dim dY1 As Double = 0.0
4448
            '        Dim dX2 As Double = 0.0
4449
            '        Dim dY2 As Double = 0.0
4450
            '        '  oRun = _Placement.PIDDataSource.GetPipeRun(oLMSymbol.Connect1Connectors.Nth(1).ModelItemID)
4451
            '        oLMSymbol = oModelrow(_XML_SYMBOL_LMSYMBOL)
4452
            '        For Each oConnector In oLMSymbol.Connect1Connectors
4453
            '            oLMConnector = oConnector
4454
            '        Next
4455
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 1, dX1, dY1)
4456
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 2, dX2, dY2)
4457
            '        '  If Math.Abs(dX - dX1) < dGap And Math.Abs(dY - dY1) < dGap And
4458
            '        If Math.Abs(d기준x - dX1) < dCheckGap And Math.Abs(d기준y - dY1) < dCheckGap Or dCheckGap = 0 Then
4459
            '            dX = dX1
4460
            '            dY = dY1
4461
            '            bConnectionFlag = True
4462
            '            dCheckGap = Math.Abs(d기준x - dX1) + Math.Abs(d기준y - dY1)
4463
            '        End If
4464
            '        'If Math.Abs(dX - dX2) < dGap And Math.Abs(dY - dY2) < dGap And
4465
            '        '  Math.Abs(d기준x - dX2) < dCheckGap And Math.Abs(d기준y - dY2 < dCheckGap) Or dCheckGap = 0 Then
4466
            '        If Math.Abs(d기준x - dX2) < dCheckGap And Math.Abs(d기준y - dY2) < dCheckGap Or dCheckGap = 0 Then
4467
            '            dX = dX2
4468
            '            dY = dY2
4469
            '            bConnectionFlag = True
4470
            '        End If
4471

    
4472
            '    Catch ex As Exception
4473
            '    End Try
4474
            '    If bConnectionFlag Then
4475
            '        oLMSymbol = oModelrow(_XML_SYMBOL_LMSYMBOL)
4476
            '    Else
4477
            '        oLMSymbol = Nothing
4478
            '    End If
4479
            'Next
4480

    
4481
        Catch ex As Exception
4482

    
4483
        End Try
4484

    
4485
        Return oLMSymbol
4486
    End Function
4487

    
4488
    ''' <summary>
4489
    ''' 라인과 라인이 만나는점이 브런치점인지 확인, 오차범위내 라인보정
4490
    ''' </summary>
4491
    ''' <param name="oModelingLineRows"></param>
4492
    ''' <param name="dStartX"></param>
4493
    ''' <param name="dStartY"></param>
4494
    ''' <param name="dEndX"></param>
4495
    ''' <param name="dEndY"></param>
4496
    ''' <param name="oLMConnector"></param>
4497
    ''' <returns></returns>
4498
    Private Function CheckBranchLine(ByVal oModelingLineRows As DataRowCollection, ByRef dStartX As Double, ByRef dStartY As Double,
4499
                                     ByRef dEndX As Double, ByRef dEndY As Double, ByRef oLMConnector As LMConnector) As String
4500
        Dim bConnectionFlag As Boolean = False
4501
        Dim sBranchDirection As String = ""
4502
        Try
4503
            For Each oModelrow In oModelingLineRows
4504
                Dim dModelStartX As Double
4505
                Dim dModelStartY As Double
4506
                Dim dModelEndX As Double
4507
                Dim dModelEndY As Double
4508
                Dim dGap As Double = 0.002
4509
                dModelStartX = oModelrow(_XML_LINE_DWG_STARTPOINT_X)
4510
                dModelStartY = oModelrow(_XML_LINE_DWG_STARTPOINT_Y)
4511
                dModelEndX = oModelrow(_XML_LINE_DWG_ENDPOINT_X)
4512
                dModelEndY = oModelrow(_XML_LINE_DWG_ENDPOINT_Y)
4513

    
4514
                '기존라인이 X축방향이라면 현재선은 Y축방향이 되어야됨
4515
                If Math.Abs(dModelStartX - dModelEndX) > Math.Abs(dModelStartY - dModelEndY) And
4516
                    Math.Abs(dStartX - dEndX) < Math.Abs(dStartY - dEndY) Then
4517

    
4518
                    '기본라인의 X축영역안에 현재선이 있어야됨
4519
                    '      If dModelEndY > dModelStartY Then
4520
                    If (dStartX < dModelEndX And dStartX > dModelStartX) Or
4521
                            (dStartX > dModelEndX And dStartX < dModelStartX) Then
4522
                        '[오차범위 수정]
4523
                        '현재선의 Y축방향이 기존라인의 X축방향을 통과하는지 확인
4524
                        If dStartY < dEndY Then
4525
                            If dEndY > dModelStartY And dModelStartY > dStartY Then
4526
                                If dEndY - dModelStartY > dModelStartY - dStartY Then
4527
                                    '위쪽으로 라인이 나와있을때
4528
                                    '현재선 중 작은 Y좌표를 오차범위만큼 더했을때 기존라인의 Y축보다 큰지확인 
4529
                                    'Y축보다 클경우 작은 Y좌표를 기존라인의 Y축에 맞추고 더한 길이만큼 큰 Y좌표에 더한다.
4530
                                    If Math.Abs(dStartY - dModelStartY) <= dGap Then
4531
                                        Dim dAddPoint As Double = dModelStartY - dStartY
4532
                                        dEndY = dEndY + dAddPoint
4533
                                        dStartY = dModelStartY
4534
                                        sBranchDirection = "START"
4535
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4536
                                        Exit For
4537
                                    End If
4538
                                Else
4539
                                    '아래쪽으로 라인이 나와있을때
4540
                                    '현재선 중 큰 Y좌표를 오차범위만큼 뺐을때 기존라인의 Y축보다 작은지확인 
4541
                                    'Y축보다 작을경우 큰 Y좌표를 기존라인의 Y축에 맞추고 더한 길이만큼 작은 Y좌표에 뺀다.
4542
                                    If Math.Abs(dEndY - dModelStartY) <= dGap Then
4543
                                        Dim dAddPoint As Double = dEndY - dModelStartY
4544
                                        dStartY = dStartY - dAddPoint
4545
                                        dEndY = dModelStartY
4546
                                        sBranchDirection = "END"
4547
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4548
                                        Exit For
4549
                                    End If
4550
                                End If
4551
                            Else
4552
                                '현재선의 Y축방향이 기존라인의 X축방향에 못미치는지 확인
4553
                                If dStartY > dModelStartY Then
4554
                                    '기존라인보다 위쪽에 현재선이 있을때
4555
                                    If Math.Abs(dStartY - dModelStartY) <= dGap Then
4556
                                        '오차범위만큼 작은 y좌표를 뺐을때 기존라인보다 아래쪽에 있을경우 오차보정
4557
                                        Dim dAddPoint As Double = dStartY - dModelStartY
4558
                                        dEndY = dEndY - dAddPoint
4559
                                        dStartY = dModelStartY
4560
                                        sBranchDirection = "START"
4561
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4562
                                        Exit For
4563
                                    End If
4564
                                Else
4565
                                    '기존라인보다 아래쪽에 현재선이 있을때
4566
                                    If Math.Abs(dEndY - dModelStartY) <= dGap Then
4567
                                        '오차범위만큼 큰 y좌표를 더했을때 기존라인보다 위쪽에 있을경우 오차보정
4568
                                        Dim dAddPoint As Double = dModelStartY - dEndY
4569
                                        dEndY = dModelStartY
4570
                                        dStartY = dStartY + dAddPoint
4571
                                        sBranchDirection = "END"
4572
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4573
                                        Exit For
4574
                                    End If
4575
                                End If
4576
                            End If
4577
                        Else
4578
                            If dEndY < dModelStartY And dModelStartY < dStartY Then
4579
                                If dModelStartY - dEndY < dStartY - dModelStartY Then
4580
                                    '위쪽으로 라인이 나와있을때
4581
                                    '현재선 중 작은 Y좌표를 오차범위만큼 더했을때 기존라인의 Y축보다 큰지확인 
4582
                                    'Y축보다 클경우 작은 Y좌표를 기존라인의 Y축에 맞추고 더한 길이만큼 큰 Y좌표에 더한다.
4583
                                    If Math.Abs(dEndY - dModelStartY) <= dGap Then
4584
                                        Dim dAddPoint As Double = dModelStartY - dEndY
4585
                                        dStartY = dStartY + dAddPoint
4586
                                        dEndY = dModelStartY
4587
                                        sBranchDirection = "END"
4588
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4589
                                        Exit For
4590
                                    End If
4591
                                Else
4592
                                    '아래쪽으로 라인이 나와있을때
4593
                                    '현재선 중 큰 Y좌표를 오차범위만큼 뺐을때 기존라인의 Y축보다 작은지확인 
4594
                                    'Y축보다 작을경우 큰 Y좌표를 기존라인의 Y축에 맞추고 더한 길이만큼 작은 Y좌표에 뺀다.
4595
                                    If Math.Abs(dStartY - dModelStartY) <= dGap Then
4596
                                        Dim dAddPoint As Double = dStartY - dModelStartY
4597
                                        dEndY = dEndY - dAddPoint
4598
                                        dStartY = dModelStartY
4599
                                        sBranchDirection = "START"
4600
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4601
                                        Exit For
4602
                                    End If
4603
                                End If
4604
                            Else
4605
                                If dEndY > dModelStartY Then
4606
                                    '기존라인보다 우측에 현재선이 있을때
4607
                                    If Math.Abs(dEndY - dModelStartY) <= dGap Then
4608
                                        '오차범위만큼 작은 x좌표를 뺐을때 기존라인보다 좌측에 있을경우 오차보정
4609
                                        Dim dAddPoint As Double = dEndY - dModelStartY
4610
                                        dStartY = dStartY - dAddPoint
4611
                                        dEndY = dModelStartY
4612
                                        sBranchDirection = "END"
4613
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4614
                                        Exit For
4615
                                    End If
4616
                                Else
4617
                                    '기존라인보다 좌측에 현재선이 있을때
4618
                                    If Math.Abs(dStartY - dModelStartY) <= dGap Then
4619
                                        '오차범위만큼 큰 x좌표를 더했을때 기존라인보다 우측에 있을경우 오차보정
4620
                                        Dim dAddPoint As Double = dModelStartY - dStartY
4621
                                        dStartY = dModelStartY
4622
                                        dEndY = dEndY + dAddPoint
4623
                                        sBranchDirection = "START"
4624
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4625
                                        Exit For
4626
                                    End If
4627
                                End If
4628
                            End If
4629
                        End If
4630
                    End If
4631
                    '기존라인이 Y축방향이라면 현재선은 X축방향이 되어야됨
4632
                ElseIf Math.Abs(dModelStartX - dModelEndX) < Math.Abs(dModelStartY - dModelEndY) And
4633
                Math.Abs(dStartX - dEndX) > Math.Abs(dStartY - dEndY) Then
4634

    
4635
                    '기본라인의 Y축영역안에 현재선이 있어야됨
4636
                    '      If dModelEndY > dModelStartY Then
4637
                    If (dStartY < dModelEndY And dStartY > dModelStartY) Or
4638
                            (dStartY > dModelEndY And dStartY < dModelStartY) Then
4639
                        '[오차범위 수정]
4640
                        '현재선의 X축방향이 기존라인의 Y축방향을 통과하는지 확인
4641
                        If dStartX < dEndX Then
4642
                            If dEndX > dModelStartX And dModelStartX > dStartX Then
4643
                                If dEndX - dModelStartX > dModelStartX - dStartX Then
4644
                                    '우측으로 라인이 나와있을때
4645
                                    '현재선 중 작은 X좌표를 오차범위만큼 더했을때 기존라인의 X축보다 큰지확인 
4646
                                    'X축보다 클경우 작은 X좌표를 기존라인의 X축에 맞추고 더한 길이만큼 큰 X좌표에 더한다.
4647
                                    If Math.Abs(dStartX - dModelStartX) <= dGap Then
4648
                                        Dim dAddPoint As Double = dModelStartX - dStartX
4649
                                        dEndX = dEndX + dAddPoint
4650
                                        dStartX = dModelStartX
4651
                                        sBranchDirection = "START"
4652
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4653
                                        Exit For
4654
                                    End If
4655
                                Else
4656
                                    '좌측으로 라인이 나와있을때
4657
                                    '현재선 중 큰 X좌표를 오차범위만큼 뺐을때 기존라인의 X축보다 작은지확인 
4658
                                    'X축보다 작을경우 큰 X좌표를 기존라인의 X축에 맞추고 뺀 길이만큼 작은 X좌표에 뺀다.
4659
                                    If Math.Abs(dEndX - dModelStartX) <= dGap Then
4660
                                        Dim dAddPoint As Double = dEndX - dModelStartX
4661
                                        dStartX = dStartX - dAddPoint
4662
                                        dEndX = dModelStartX
4663
                                        sBranchDirection = "END"
4664
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4665
                                        Exit For
4666
                                    End If
4667
                                End If
4668
                            Else
4669
                                '현재선의 X축방향이 기존라인의 Y축방향에 못미치는지 확인
4670
                                If dStartX > dModelStartX Then
4671
                                    '기존라인보다 우측에 현재선이 있을때
4672
                                    If Math.Abs(dStartX - dModelStartX) <= dGap Then
4673
                                        '오차범위만큼 작은 x좌표를 뺐을때 기존라인보다 좌측에 있을경우 오차보정
4674
                                        Dim dAddPoint As Double = dStartX - dModelStartX
4675
                                        dEndX = dEndX - dAddPoint
4676
                                        dStartX = dModelStartX
4677
                                        sBranchDirection = "START"
4678
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4679
                                        Exit For
4680
                                    End If
4681
                                Else
4682
                                    '기존라인보다 좌측에 현재선이 있을때
4683
                                    If Math.Abs(dEndX - dModelStartX) <= dGap Then
4684
                                        '오차범위만큼 큰 x좌표를 더했을때 기존라인보다 우측에 있을경우 오차보정
4685
                                        Dim dAddPoint As Double = dModelStartX - dEndX
4686
                                        dEndX = dModelStartX
4687
                                        dStartX = dStartX + dAddPoint
4688
                                        sBranchDirection = "END"
4689
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4690
                                        Exit For
4691
                                    End If
4692
                                End If
4693
                            End If
4694
                        Else
4695
                            If dEndX < dModelStartX And dModelStartX < dStartX Then
4696
                                If dModelStartX - dEndX < dStartX - dModelStartX Then
4697
                                    '우측으로 라인이 나와있을때
4698
                                    '현재선 중 작은 X좌표를 오차범위만큼 더했을때 기존라인의 X축보다 큰지확인 
4699
                                    'X축보다 클경우 작은 X좌표를 기존라인의 X축에 맞추고 더한 길이만큼 큰 X좌에 더한다.
4700
                                    If Math.Abs(dModelStartX - dEndX) <= dGap Then
4701
                                        Dim dAddPoint As Double = dModelStartX - dEndX
4702
                                        dStartX = dStartX + dAddPoint
4703
                                        dEndX = dModelStartX
4704
                                        sBranchDirection = "END"
4705
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4706
                                        Exit For
4707
                                    End If
4708
                                Else
4709
                                    '좌측으로 라인이 나와있을때
4710
                                    '현재선 중 큰 X좌표를 오차범위만큼 뺐을때 기존라인의 X축보다 작은지확인 
4711
                                    'X축보다 작을경우 큰 X좌표를 기존라인의 X축에 맞추고 뺀 길이만큼 작은 X좌표에 뺀다.
4712
                                    If Math.Abs(dStartX - dModelStartX) <= dGap Then
4713
                                        Dim dAddPoint As Double = dStartX - dModelStartX
4714
                                        dEndX = dEndX - dAddPoint
4715
                                        dStartX = dModelStartX
4716
                                        sBranchDirection = "START"
4717
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4718
                                        Exit For
4719
                                    End If
4720

    
4721
                                End If
4722
                            Else
4723
                                If dEndX > dModelStartX Then
4724
                                    '기존라인보다 우측에 현재선이 있을때
4725
                                    If Math.Abs(dEndX - dModelStartX) <= dGap Then
4726
                                        '오차범위만큼 작은 x좌표를 뺐을때 기존라인보다 좌측에 있을경우 오차보정
4727
                                        Dim dAddPoint As Double = dEndX - dModelStartX
4728
                                        dStartX = dStartX - dAddPoint
4729
                                        dEndX = dModelStartX
4730
                                        sBranchDirection = "END"
4731
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4732
                                        Exit For
4733
                                    End If
4734
                                Else
4735
                                    '기존라인보다 좌측에 현재선이 있을때
4736
                                    If Math.Abs(dStartX - dModelStartX) <= dGap Then
4737
                                        '오차범위만큼 큰 x좌표를 더했을때 기존라인보다 우측에 있을경우 오차보정
4738
                                        Dim dAddPoint As Double = dModelStartX - dStartX
4739
                                        dStartX = dModelStartX
4740
                                        dEndX = dEndX + dAddPoint
4741
                                        sBranchDirection = "START"
4742
                                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4743
                                        Exit For
4744
                                    End If
4745
                                End If
4746
                            End If
4747
                        End If
4748
                    End If
4749
                End If
4750
            Next
4751
        Catch ex As Exception
4752
            bConnectionFlag = False
4753
            oLMConnector = Nothing
4754
        End Try
4755
        Return sBranchDirection
4756

    
4757
    End Function
4758

    
4759
    Private Function UpdateCheckBranchLine(ByRef dX As Double, ByRef dY As Double,
4760
                                  ByRef oLMConnector As LMConnector, ByRef sUid As String) As Boolean
4761
        Dim oDataSource As LMADataSource = _Placement.PIDDataSource
4762
        Dim bCheckBranchItem As Boolean = False
4763
        Dim iGapCheck As Integer = 0
4764
        Try
4765
            For Each oModelrow In _ModelingLine_Dt.Rows
4766
                Dim d기준x As Double = dX
4767
                Dim d기준y As Double = dY
4768
                Dim dGap As Double = 0.001
4769
                Dim oRun As LMPipeRun = Nothing
4770
                Dim dModelStartX As Double
4771
                Dim dModelStartY As Double
4772
                Dim dModelEndX As Double
4773
                Dim dModelEndY As Double
4774
                dModelStartX = oModelrow(_XML_LINE_DWG_STARTPOINT_X)
4775
                dModelStartY = oModelrow(_XML_LINE_DWG_STARTPOINT_Y)
4776
                dModelEndX = oModelrow(_XML_LINE_DWG_ENDPOINT_X)
4777
                dModelEndY = oModelrow(_XML_LINE_DWG_ENDPOINT_Y)
4778
                d기준x = (dModelStartX + dModelEndX) / 2
4779
                d기준y = (dModelStartY + dModelEndY) / 2
4780

    
4781
                Dim dMax_X As Double = 0.0
4782
                Dim dMax_Y As Double = 0.0
4783
                Dim dMin_X As Double = 0.0
4784
                Dim dMin_Y As Double = 0.0
4785
                If dModelEndX > dModelStartX Then
4786
                    dMax_X = dModelEndX
4787
                    dMin_X = dModelStartX
4788
                Else
4789
                    dMax_X = dModelStartX
4790
                    dMin_X = dModelEndX
4791
                End If
4792

    
4793
                If dModelEndY > dModelStartY Then
4794
                    dMax_Y = dModelEndY
4795
                    dMin_Y = dModelStartY
4796
                Else
4797
                    dMax_Y = dModelStartY
4798
                    dMin_Y = dModelEndY
4799
                End If
4800

    
4801
                If dX <= dMax_X + dGap And dX >= dMin_X - dGap And
4802
                  dY <= dMax_Y + dGap And dY >= dMin_Y - dGap Then
4803
                    If Math.Abs(dMax_X - dMin_X) > Math.Abs(dMax_Y - dMin_Y) Then
4804
                        dY = dMax_Y
4805
                    Else
4806
                        dX = dMax_X
4807
                    End If
4808

    
4809
                    Try
4810
                        Dim sModelItemID As String = oModelrow(_XML_LINE_SPID).ToString()
4811
                        sUid = oModelrow(_XML_LINE_UID).ToString()
4812
                        oRun = oDataSource.GetPipeRun(sModelItemID)
4813
                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4814
                    Catch ex As Exception
4815
                    End Try
4816
                    Try
4817
                        If oRun IsNot Nothing Then
4818
                            Dim dResultCalc As Double = -1
4819
                            Dim bBranchFlag As Boolean = False
4820
                            Dim dBranchX As Double = 0
4821
                            Dim dBranchY As Double = 0
4822
                            For Each objRep In oRun.Representations
4823
                                '  Dim sAttriName As String
4824
                                'For Each objAttr In objRep.Attributes
4825
                                '    sAttriName = objAttr.name
4826
                                'Next
4827
                                'MsgBox(objRep.RepresentationType)
4828
                                If objRep.RepresentationType = "Connector" Then
4829
                                    Dim objConnector As LMConnector = oDataSource.GetConnector(objRep.ID)
4830
                                    '     Dim sItemStatus As String = objConnector.Attributes("ItemStatus").Value
4831
                                    '   Dim sModelTypeName As String = objConnector.ModelItemObject.Attributes("ItemTypeName").Value
4832

    
4833
                                    'Dim dConn_SX As Double = 0
4834
                                    'Dim dConn_SY As Double = 0
4835
                                    'Dim dConn_EX As Double = 0
4836
                                    'Dim dConn_EY As Double = 0
4837
                                    Dim dConn_X As Double = 0
4838
                                    Dim dConn_Y As Double = 0
4839
                                    For Each objConnectorVertex In objConnector.ConnectorVertices
4840
                                        dConn_X = objConnectorVertex.Attributes("XCoordinate").Value
4841
                                        dConn_Y = objConnectorVertex.Attributes("YCoordinate").Value
4842
                                        'If dConn_SX = 0 Then
4843
                                        '    dConn_SX = objConnectorVertex.Attributes("XCoordinate").Value
4844
                                        '    dConn_SY = objConnectorVertex.Attributes("YCoordinate").Value
4845
                                        'Else
4846
                                        '    dConn_EX = objConnectorVertex.Attributes("XCoordinate").Value
4847
                                        '    dConn_EY = objConnectorVertex.Attributes("YCoordinate").Value
4848
                                        'End If
4849
                                        Dim dCalc As Double = Math.Abs(dConn_X - dX) + Math.Abs(dConn_Y - dY)
4850
                                        If bBranchFlag = False Then
4851
                                            If dResultCalc = -1 Or dResultCalc > dCalc Then
4852
                                                dResultCalc = dCalc
4853
                                                oLMConnector = objConnector
4854
                                                bCheckBranchItem = True
4855
                                            End If
4856
                                        Else
4857
                                            If (dConn_X >= dX And dBranchX <= dX And dConn_Y >= dY And dBranchY <= dY) Or
4858
                                               (dConn_X <= dX And dBranchX >= dX And dConn_Y <= dY And dBranchY >= dY) Then
4859
                                                If dResultCalc = -1 Or dResultCalc > dCalc Then
4860
                                                    dResultCalc = dCalc
4861
                                                    oLMConnector = objConnector
4862
                                                    bCheckBranchItem = True
4863
                                                End If
4864
                                            End If
4865
                                        End If
4866

    
4867

    
4868
                                        'If dConn_EX <> 0 And dConn_EY <> 0 Then
4869
                                        '    If dConn_SX >= dX And dConn_EX <= dX And dConn_SY >= dY And dConn_EY <= dY Then
4870
                                        '        oLMConnector = objConnector
4871
                                        '        Exit For
4872
                                        '    ElseIf dConn_SX <= dX And dConn_EX >= dX And dConn_SY <= dY And dConn_EY >= dY Then
4873
                                        '        oLMConnector = objConnector
4874
                                        '        Exit For
4875
                                        '    Else
4876
                                        '        If dConn_EX > 0 Then
4877
                                        '            dConn_SX = dConn_EX
4878
                                        '            dConn_SY = dConn_EY
4879
                                        '        End If
4880
                                        '    End If
4881
                                        'End If
4882

    
4883
                                    Next
4884
                                    'If oLMConnector IsNot Nothing Then
4885
                                    '    Exit For
4886
                                    'End If
4887
                                ElseIf objRep.RepresentationType = "Branch" Then
4888
                                    Dim objConnector As LMSymbol = oDataSource.GetSymbol(objRep.ID)
4889
                                    dBranchX = objConnector.Attributes("XCoordinate").Value
4890
                                    dBranchY = objConnector.Attributes("YCoordinate").Value
4891
                                    bBranchFlag = True
4892
                                End If
4893
                                'If objRep.Attributes("RepresentationType").Value = "Connector" And objRep.Attributes("ItemStatus").Value = "Active" Then
4894
                                '    Dim objConnector As LMConnector = _Placement.PIDDataSource.GetConnector(objRep.ID)
4895
                                '    For Each objConnectorVertex In objConnector.ConnectorVertices
4896
                                '        Dim dConn_X As Double = objConnectorVertex.Attributes("XCoordinate").Value
4897
                                '        Dim dConn_Y As Double = objConnectorVertex.Attributes("YCoordinate").Value
4898
                                '        If Math.Abs(dX - dConn_X) < dGap And Math.Abs(dY - dConn_Y) < dGap Then
4899
                                '            oLMConnector = objConnector
4900
                                '            dX = dConn_X
4901
                                '            dY = dConn_Y
4902
                                '            bConnectionFlag = True
4903
                                '        End If
4904
                                '    Next
4905
                                'End If
4906
                            Next
4907
                        End If
4908
                    Catch ex As Exception
4909
                    End Try
4910
                    '    oUid = oModelrow(_XML_LINE_UID).ToString()
4911
                    ' Dim oID As String = oModelrow(_XML_LINE_SPID)
4912
                    '    oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4913
                    '    oID = oLMConnector.ModelItemID
4914
                    '  oLMConnector = _Placement.PIDDataSource.GetConnector(oID)
4915
                    'If oLMConnector IsNot Nothing Then
4916
                    '    Exit For
4917
                    'End If
4918
                End If
4919

    
4920

    
4921
            Next
4922
        Catch ex As Exception
4923
            bCheckBranchItem = False
4924
            oLMConnector = Nothing
4925
        End Try
4926
        Return bCheckBranchItem
4927
    End Function
4928

    
4929
    ''' <summary>
4930
    ''' 라인과 특정 포인트에 커넥션을 확인하는 메서드
4931
    ''' </summary>
4932
    ''' <param name="oModelingLineRows"></param>
4933
    ''' <param name="dX"></param>
4934
    ''' <param name="dY"></param>
4935
    ''' <param name="oLMConnector"></param>
4936
    ''' <param name="dPreConnX"></param>
4937
    ''' <param name="dPreConnY"></param>
4938
    ''' <returns></returns>
4939

    
4940
    Private Function CheckConnectionLine(ByRef dX As Double, ByRef dY As Double,
4941
                                  ByRef oLMConnector As LMConnector, ByRef sUid As String) As Boolean
4942
        Dim bConnectionFlag As Boolean = False
4943
        Dim iGapCheck As Integer = 0
4944
        Try
4945
            For Each oModelrow In _ModelingLine_Dt.Rows
4946
                Dim d기준x As Double = dX
4947
                Dim d기준y As Double = dY
4948
                Dim dGap As Double = 0.001
4949
                Dim oRun As LMPipeRun = Nothing
4950
                Dim dModelStartX As Double
4951
                Dim dModelStartY As Double
4952
                Dim dModelEndX As Double
4953
                Dim dModelEndY As Double
4954
                dModelStartX = oModelrow(_XML_LINE_DWG_STARTPOINT_X)
4955
                dModelStartY = oModelrow(_XML_LINE_DWG_STARTPOINT_Y)
4956
                dModelEndX = oModelrow(_XML_LINE_DWG_ENDPOINT_X)
4957
                dModelEndY = oModelrow(_XML_LINE_DWG_ENDPOINT_Y)
4958
                d기준x = (dModelStartX + dModelEndX) / 2
4959
                d기준y = (dModelStartY + dModelEndY) / 2
4960

    
4961
                Dim bCheckEqual As Boolean = False
4962
                If dX <= dModelStartX + dGap And dX >= dModelStartX - dGap And
4963
                        dY <= dModelStartY + dGap And dY >= dModelStartY - dGap Then
4964
                    bCheckEqual = True
4965
                ElseIf dX <= dModelEndX + dGap And dX >= dModelEndX - dGap And
4966
                        dY <= dModelEndY + dGap And dY >= dModelEndY - dGap Then
4967
                    bCheckEqual = True
4968
                End If
4969
                If bCheckEqual Then
4970
                    Try
4971
                        oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
4972
                        sUid = oModelrow(_XML_LINE_UID)
4973
                        oRun = _Placement.PIDDataSource.GetPipeRun(oLMConnector.ModelItemID)
4974
                    Catch ex As Exception
4975
                    End Try
4976
                    Try
4977
                        If oRun IsNot Nothing Then
4978
                            Dim dResultCalc As Double = -1
4979
                            For Each objRep In oRun.Representations
4980
                                If objRep.Attributes("RepresentationType").Value = "Connector" And objRep.Attributes("ItemStatus").Value = "Active" Then
4981
                                    Dim objConnector As LMConnector = _Placement.PIDDataSource.GetConnector(objRep.ID)
4982
                                    For Each objConnectorVertex In objConnector.ConnectorVertices
4983
                                        Dim dConn_X As Double = objConnectorVertex.Attributes("XCoordinate").Value
4984
                                        Dim dConn_Y As Double = objConnectorVertex.Attributes("YCoordinate").Value
4985
                                        If Math.Abs(dX - dConn_X) < dGap And Math.Abs(dY - dConn_Y) < dGap Then
4986
                                            oLMConnector = objConnector
4987
                                            dX = dConn_X
4988
                                            dY = dConn_Y
4989
                                            bConnectionFlag = True
4990
                                        End If
4991
                                    Next
4992
                                End If
4993
                            Next
4994
                        End If
4995
                    Catch ex As Exception
4996
                    End Try
4997
                Else
4998
                End If
4999
            Next
5000
        Catch ex As Exception
5001
            bConnectionFlag = False
5002
            oLMConnector = Nothing
5003
        End Try
5004
        Return bConnectionFlag
5005
    End Function
5006

    
5007
    Private Function CheckAlreadyBranchLine(ByVal sSystemPath As String, ByVal dStartX As Double, ByVal dStartY As Double, ByVal dEndX As Double, ByVal dEndY As Double) As Boolean
5008
        '현재선의 방향을 보고 상대라인이 직교되는 방향인지 체크
5009
        '오차범위를 줘서 현재선을 통과하는지 체크
5010
        '통과하는 상대라인 갯수를 먼저 구한다음 라인 갯수만큼 라인을 그린다.
5011
        Dim bCheckBranchLine As Boolean = False
5012
        Dim sCurrentDirection As String = ""
5013

    
5014
        Dim oModel_Dt As New DataTable()
5015
        oModel_Dt.Columns.Add("X")
5016
        oModel_Dt.Columns.Add("Y")
5017
        oModel_Dt.Columns.Add("Type")
5018
        oModel_Dt.Columns.Add("SPID")
5019
        Dim dGap = 0.001
5020
        If Math.Abs(dStartX - dEndX) > Math.Abs(dStartY - dEndY) Then
5021
            sCurrentDirection = "X"
5022
            If dStartX > dEndX Then
5023
                Dim dTempX As Double = dEndX
5024
                dEndX = dStartX
5025
                dStartX = dTempX
5026
                Dim dTempY As Double = dEndY
5027
                dEndY = dStartY
5028
                dStartY = dTempY
5029
            End If
5030
            '현재선이 X축방향
5031
            Try
5032
                For Each oModelrow In _ModelingLine_Dt.Rows
5033
                    Dim dModelStart_X As Double = oModelrow(_XML_LINE_DWG_STARTPOINT_X)
5034
                    Dim dModelStart_Y As Double = oModelrow(_XML_LINE_DWG_STARTPOINT_Y)
5035
                    Dim dModelEnd_X As Double = oModelrow(_XML_LINE_DWG_ENDPOINT_X)
5036
                    Dim dModelEnd_Y As Double = oModelrow(_XML_LINE_DWG_ENDPOINT_Y)
5037
                    Dim sSPID As String = oModelrow(_XML_LINE_SPID)
5038
                    If dStartX < dModelStart_X And dStartX < dModelEnd_X And
5039
                       dEndX > dModelStart_X And dEndX > dModelEnd_X Then
5040
                        Dim dAddX As Double = dStartX
5041
                        Dim dAddY As Double = dStartY
5042
                        Dim sType As String = ""
5043
                        Dim dAddLineX As Double = 0
5044
                        Dim dAddLineY As Double = 0
5045
                        If dStartY = dModelStart_Y Then
5046
                            dAddX = 0
5047
                            '    dAddX = dModelStart_X
5048
                        ElseIf dStartY = dModelEnd_Y Then
5049
                            dAddX = 0
5050
                            '      dAddX = dModelEnd_X
5051
                        ElseIf dStartY <= dModelStart_Y + dGap And dStartY >= dModelStart_Y - dGap Then
5052
                            dAddX = dModelStart_X
5053
                            If dStartY <= dModelStart_Y Then
5054
                                sType = "AddLine"
5055
                                dAddLineX = dModelStart_X
5056
                                dAddLineY = dModelStart_Y
5057
                            End If
5058
                        ElseIf dStartY <= dModelEnd_Y + dGap And dStartY >= dModelEnd_Y - dGap Then
5059
                            dAddX = dModelEnd_X
5060
                            If dStartY <= dModelEnd_Y Then
5061
                                sType = "AddLine"
5062
                                dAddLineX = dModelEnd_X
5063
                                dAddLineY = dModelEnd_Y
5064
                            End If
5065
                        End If
5066
                        If sType = "AddLine" Then
5067
                            Dim objInputs As PlaceRunInputs
5068
                            objInputs = New PlaceRunInputs
5069
                            Dim oLMConnector As LMConnector = Nothing
5070
                            CheckConnectionLine(dAddLineX, dAddLineY, oLMConnector, "")
5071
                            objInputs.AddPoint(dAddLineX, dAddY)
5072
                            objInputs.AddConnectorTarget(oLMConnector, dAddLineX, dAddLineY)
5073
                            Dim AddLMConnector As LMConnector = LineModeling(objInputs, sSystemPath)
5074
                            JoinPipeRun(oLMConnector.ModelItemID, AddLMConnector.ModelItemID)
5075
                            dStartY = dAddY
5076
                        End If
5077

    
5078
                        If dAddX <> 0 Then
5079
                            Dim oDatarow As DataRow = oModel_Dt.NewRow()
5080
                            oDatarow("X") = dAddX
5081
                            oDatarow("Y") = dAddY
5082
                            oDatarow("Type") = sType
5083
                            oDatarow("SPID") = sSPID
5084
                            oModel_Dt.Rows.Add(oDatarow)
5085
                        End If
5086
                    End If
5087
                Next
5088
            Catch ex As Exception
5089
            End Try
5090
        Else
5091
            '현재선이 y축방향
5092
            sCurrentDirection = "Y"
5093
            Try
5094
                For Each oModelrow In _ModelingLine_Dt.Rows
5095
                    Dim dModelStart_X As Double = oModelrow(_XML_LINE_DWG_STARTPOINT_X)
5096
                    Dim dModelStart_Y As Double = oModelrow(_XML_LINE_DWG_STARTPOINT_Y)
5097
                    Dim dModelEnd_X As Double = oModelrow(_XML_LINE_DWG_ENDPOINT_X)
5098
                    Dim dModelEnd_Y As Double = oModelrow(_XML_LINE_DWG_ENDPOINT_Y)
5099
                    Dim sSPID As String = oModelrow(_XML_LINE_SPID)
5100
                    If dStartY < dModelStart_Y And dStartY < dModelEnd_Y And
5101
                       dEndY > dModelStart_Y And dEndY > dModelEnd_Y Then
5102
                        Dim dAddX As Double = dStartX
5103
                        Dim dAddY As Double = dStartY
5104
                        Dim sType As String = ""
5105
                        Dim dAddLineX As Double = 0
5106
                        Dim dAddLineY As Double = 0
5107
                        If dStartX = dModelStart_X Then
5108
                            dAddY = 0
5109
                            '       dAddY = dModelStart_Y
5110
                        ElseIf dStartX = dModelEnd_X Then
5111
                            dAddY = 0
5112
                            '        dAddY = dModelEnd_Y
5113
                        ElseIf dStartX <= dModelStart_X + dGap And dStartX >= dModelStart_X - dGap Then
5114
                            '         dAddY = dModelStart_Y
5115
                            If dStartX <= dModelStart_X Then
5116
                                dAddLineX = dModelStart_X
5117
                                dAddLineY = dModelStart_Y
5118
                                sType = "AddLine"
5119
                            End If
5120
                        ElseIf dStartX <= dModelEnd_X + dGap And dStartX >= dModelEnd_X - dGap Then
5121
                            '        dAddY = dModelEnd_Y
5122
                            If dStartX <= dModelEnd_X Then
5123
                                dAddLineX = dModelEnd_X
5124
                                dAddLineY = dModelEnd_Y
5125
                                sType = "AddLine"
5126
                            End If
5127
                        End If
5128
                        If sType = "AddLine" Then
5129
                            Dim objInputs As PlaceRunInputs
5130
                            objInputs = New PlaceRunInputs
5131
                            Dim oLMConnector As LMConnector = Nothing
5132
                            CheckConnectionLine(dAddLineX, dAddLineY, oLMConnector, "")
5133
                            objInputs.AddPoint(dAddX, dAddLineY)
5134
                            objInputs.AddConnectorTarget(oLMConnector, dAddLineX, dAddLineY)
5135
                            Dim AddLMConnector As LMConnector = LineModeling(objInputs, sSystemPath)
5136
                            JoinPipeRun(oLMConnector.ModelItemID, AddLMConnector.ModelItemID)
5137
                            dStartX = dAddX
5138
                        End If
5139

    
5140
                        If dAddY <> 0 Then
5141
                            Dim oDatarow As DataRow = oModel_Dt.NewRow()
5142
                            oDatarow("X") = dAddX
5143
                            oDatarow("Y") = dAddY
5144
                            oDatarow("Type") = sType
5145
                            oDatarow("SPID") = sSPID
5146
                            oModel_Dt.Rows.Add(oDatarow)
5147
                        End If
5148
                    End If
5149
                Next
5150
            Catch ex As Exception
5151
            End Try
5152
        End If
5153

    
5154
        '//못미치는 라인은 라인길이를 더한후 나머지 모델링(2018.09.27)
5155

    
5156
        If oModel_Dt.Rows.Count > 0 Then
5157
            If sCurrentDirection = "X" Then
5158
                'X좌표 정렬
5159
                oModel_Dt.DefaultView.Sort = "X desc"
5160
                oModel_Dt = oModel_Dt.DefaultView.ToTable(True)
5161
            Else
5162
                'Y좌표 정렬
5163
                oModel_Dt.DefaultView.Sort = "Y desc"
5164
                oModel_Dt = oModel_Dt.DefaultView.ToTable(True)
5165
            End If
5166
            Dim oLMConnector As LMConnector = Nothing
5167
            Dim oPreLMConnector As LMConnector = Nothing
5168
            Dim dStartFlag As Boolean = True
5169
            For Each oModelRow In oModel_Dt.Rows
5170
                Dim objInputs As PlaceRunInputs
5171
                objInputs = New PlaceRunInputs
5172
                Dim dX As Double = oModelRow("X")
5173
                Dim dY As Double = oModelRow("Y")
5174
                Dim sType As String = oModelRow("Type")
5175
                Dim sUid As String = ""
5176

    
5177

    
5178
                CheckConnectionLine(dX, dY, oLMConnector, sUid)
5179
                If oLMConnector IsNot Nothing Then
5180
                    If dStartFlag Then
5181
                        objInputs.AddPoint(dStartX, dStartY)
5182
                        objInputs.AddConnectorTarget(oLMConnector, dX, dY)
5183
                    Else
5184
                        objInputs.AddConnectorTarget(oPreLMConnector, dStartX, dStartY)
5185
                        objInputs.AddConnectorTarget(oLMConnector, dX, dY)
5186
                    End If
5187
                    oPreLMConnector = LineModeling(objInputs, sSystemPath)
5188
                    '모델링후 StartX를 현재 X로 변경
5189
                    dStartX = dX
5190
                    dStartY = dY
5191
                End If
5192
            Next
5193
            If oPreLMConnector IsNot Nothing Then
5194
                Dim objInputs As PlaceRunInputs
5195
                objInputs = New PlaceRunInputs
5196
                objInputs.AddConnectorTarget(oPreLMConnector, dStartX, dStartY)
5197
                objInputs.AddPoint(dEndX, dEndY)
5198
                LineModeling(objInputs, sSystemPath)
5199
            End If
5200
        End If
5201
        Return bCheckBranchLine
5202
    End Function
5203

    
5204

    
5205
    Private Function CheckLineBranch(ByVal oLine_Dt As DataTable, ByRef dX As Double, ByRef dY As Double,
5206
                                     ByVal sDirection As String, ByRef oLMConnector As LMConnector) As Boolean
5207

    
5208
        Dim oModelingLineRows() As DataRow = oLine_Dt.Select(" Then[" & _XML_LINE_DRAWING_TF & "] = 'TRUE' And " &
5209
                                                                "[" & _XML_LINE_SPID & "] <> ''")
5210

    
5211
        Dim bConnectionFlag As Boolean = False
5212
        Try
5213
            For Each oModelrow In oModelingLineRows
5214
                Dim sStartPoint As String = oModelrow(_XML_LINE_STARTPOINT)
5215
                Dim sEndPoint As String = oModelrow(_XML_LINE_ENDPOINT)
5216
                Dim dModelStartX As Double
5217
                Dim dModelStartY As Double
5218
                Dim dModelEndX As Double
5219
                Dim dModelEndY As Double
5220
                ConvertPointBystring(sStartPoint, dModelStartX, dModelStartY)
5221
                ConvertPointBystring(sEndPoint, dModelEndX, dModelEndY)
5222
                ConvertPointByImage(dModelStartX, dModelStartY, _IMG_X, _IMG_Y)
5223
                ConvertPointByImage(dModelEndX, dModelEndY, _IMG_X, _IMG_Y)
5224
                Dim dGap As Double = 0.0002
5225

    
5226
                If Math.Abs(dModelStartX - dModelEndX) <= Math.Abs(dModelStartY - dModelEndY) Then
5227
                    'Vertical
5228
                    If sDirection = "X" Then
5229
                        'x Direction Line
5230
                        If (dModelStartY + dGap >= dY And dModelEndY - dGap <= dY) Or
5231
                        (dModelStartY - dGap <= dY And dModelEndY + dGap >= dY) Then
5232
                            If (dX > dModelStartX And dX < dModelEndX) Or (dX > dModelEndX And dX < dModelStartX) Then
5233
                                If Math.Abs(dX - dModelStartX) > Math.Abs(dX - dModelEndX) Then
5234
                                    dX = dModelEndX
5235
                                Else
5236
                                    dX = dModelStartX
5237
                                End If
5238
                                Try
5239
                                    oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
5240
                                Catch ex As Exception
5241

    
5242
                                End Try
5243
                                bConnectionFlag = True
5244
                            End If
5245
                        End If
5246
                    End If
5247
                Else
5248
                    'Horizontal 
5249
                    If sDirection = "Y" Then
5250
                        If (dModelStartX + dGap >= dX And dModelEndX - dGap <= dX) Or
5251
                       (dModelStartX - dGap <= dX And dModelEndX + dGap >= dX) Then
5252
                            If (dY > dModelStartY And dY < dModelEndY) Or (dY > dModelEndY And dY < dModelStartY) Then
5253
                                If Math.Abs(dY - dModelStartY) > Math.Abs(dY - dModelEndY) Then
5254
                                    dY = dModelEndY
5255
                                Else
5256
                                    dY = dModelStartY
5257
                                End If
5258
                                Try
5259
                                    oLMConnector = oModelrow(_XML_LINE_LMCONNECTOR)
5260
                                Catch ex As Exception
5261
                                End Try
5262
                                bConnectionFlag = True
5263
                            End If
5264
                        End If
5265
                    End If
5266
                End If
5267
            Next
5268
        Catch ex As Exception
5269
        End Try
5270
        Return bConnectionFlag
5271
    End Function
5272
    Private Function LineModeling(ByVal oLine_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal sStartLineUid As String, ByVal sEndLineUid As String, ByVal dStart_x As Double, ByVal dStart_y As Double, ByVal dEnd_x As Double, ByVal dEnd_y As Double,
5273
                              ByVal sLineNoUid As String, ByVal sLineUid As String, ByVal sSystemPath As String, ByRef oLMConnector As LMConnector) As Boolean
5274
        'Try
5275
        '    Dim oDatasource As Object = _Placement.PIDDataSource
5276
        '    Dim oPipeRun As LMPipeRun = Nothing
5277
        '    Dim objInputs As PlaceRunInputs
5278
        '    objInputs = New PlaceRunInputs
5279
        '    Dim objItem As LMAItem
5280
        '    '       Dim objConnector As LMConnector
5281

    
5282
        '    Dim oStartLineRow() As DataRow = oLine_Dt.Select("[" & _XML_LINE_Conn1_Uid & "] = '" & sStartLineUid & "' And " &
5283
        '                                                            "[" & _XML_LINE_DRAWING_TF & "] = 'TRUE' And" &
5284
        '                                                                  "[" & _XML_LINE_SPID & "] <> ''")
5285
        '    If oStartLineRow.Length = 0 Then
5286
        '        oStartLineRow = oLine_Dt.Select("[" & _XML_LINE_Conn2_Uid & "] = '" & sStartLineUid & "' And " &
5287
        '                                                            "[" & _XML_LINE_DRAWING_TF & "] = 'TRUE' And" &
5288
        '                                                                  "[" & _XML_LINE_SPID & "] <> ''")
5289
        '    End If
5290
        '    Dim oEndLineRow() As DataRow = oLine_Dt.Select("[" & _XML_LINE_Conn1_Uid & "] = '" & sEndLineUid & "' And " &
5291
        '                                                            "[" & _XML_LINE_DRAWING_TF & "] = 'TRUE' And" &
5292
        '                                                                  "[" & _XML_LINE_SPID & "] <> ''")
5293

    
5294
        '    oEndLineRow = oLine_Dt.Select("[" & _XML_LINE_Conn2_Uid & "] = '" & sEndLineUid & "' And " &
5295
        '                                                            "[" & _XML_LINE_DRAWING_TF & "] = 'TRUE' And" &
5296
        '                                                                  "[" & _XML_LINE_SPID & "] <> ''")
5297
        '    Dim sStartConnectionType As String = ""
5298
        '    Dim sEndConnectionType As String = ""
5299

    
5300
        '    Dim oStartLMConnector As LMConnector = Nothing
5301
        '    Dim oEndLMConnector As LMConnector = Nothing
5302
        '    Dim oDirectionLine As String = ""
5303

    
5304
        '    If Math.Abs(dStart_x - dEnd_x) > Math.Abs(dStart_y - dEnd_y) Then
5305
        '        oDirectionLine = "X"
5306
        '    Else
5307
        '        oDirectionLine = "Y"
5308
        '    End If
5309

    
5310
        '    Dim bCheckFlag As Boolean = False
5311

    
5312
        '    Dim bStartCheckFlag As Boolean = CheckConnectionLine(oStartLineRow, dStart_x, dStart_y, oStartLMConnector)
5313
        '    If bStartCheckFlag = False Then
5314
        '        bStartCheckFlag = CheckConnectionLine(oStartLineRow, dEnd_x, dEnd_y, oStartLMConnector)
5315
        '        bCheckFlag = True
5316
        '    End If
5317
        '    Dim bEndCheckFlag As Boolean = CheckConnectionLine(oEndLineRow, dEnd_x, dEnd_y, oEndLMConnector)
5318

    
5319
        '    If bEndCheckFlag = False Then
5320

    
5321
        '        bEndCheckFlag = CheckConnectionLine(oEndLineRow, dStart_x, dStart_y, oEndLMConnector)
5322
        '        bCheckFlag = True
5323
        '    End If
5324

    
5325
        '    If bStartCheckFlag = True And bEndCheckFlag = False Then
5326
        '        If bCheckFlag Then
5327
        '            objInputs.AddConnectorTarget(oStartLMConnector, dEnd_x, dEnd_y)
5328
        '            objInputs.AddPoint(dStart_x, dStart_y)
5329
        '        Else
5330
        '            objInputs.AddConnectorTarget(oStartLMConnector, dStart_x, dStart_y)
5331
        '            objInputs.AddPoint(dEnd_x, dEnd_y)
5332
        '        End If
5333

    
5334
        '    ElseIf bStartCheckFlag = False And bEndCheckFlag = True Then
5335
        '        If bCheckFlag Then
5336

    
5337
        '            objInputs.AddConnectorTarget(oStartLMConnector, dStart_x, dStart_y)
5338
        '            objInputs.AddPoint(dEnd_x, dEnd_y)
5339
        '        Else
5340
        '            objInputs.AddPoint(dStart_x, dStart_y)
5341
        '            objInputs.AddConnectorTarget(oStartLMConnector, dEnd_x, dEnd_y)
5342
        '        End If
5343

    
5344
        '    ElseIf bStartCheckFlag = True And bEndCheckFlag = True Then
5345
        '        objInputs.AddConnectorTarget(oStartLMConnector, dStart_x, dStart_y)
5346
        '        objInputs.AddConnectorTarget(oEndLMConnector, dEnd_x, dEnd_y)
5347
        '    Else
5348
        '        objInputs.AddPoint(dStart_x, dStart_y)
5349
        '        objInputs.AddPoint(dEnd_x, dEnd_y)
5350
        '    End If
5351
        '    SetListBoxItems(ListBox_Result, "Place Pipe..(" & dStart_x & "," & dStart_y & ") - (" & dEnd_x & "," & dEnd_y & ")..." & _iPipecnt & " count ")
5352
        '    _iPipecnt = _iPipecnt + 1
5353
        '    objItem = _Placement.PIDCreateItem(sSystemPath)
5354
        '    oLMConnector = _Placement.PIDPlaceRun(objItem, objInputs)
5355

    
5356
        '    Dim oUpdateRow As DataRow() = oLine_Dt.Select(_XML_LINE_UID & " = '" + sLineUid + "'")
5357
        '    If oUpdateRow.Length = 1 Then
5358
        '        oUpdateRow(0)(_XML_LINE_SPID) = oLMConnector.ModelItemID
5359
        '        oUpdateRow(0)(_XML_LINE_LMCONNECTOR) = oLMConnector
5360

    
5361
        '        oUpdateRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5362
        '    End If
5363

    
5364
        '    oPipeRun = oDatasource.GetPipeRun(oLMConnector.ModelItemID)
5365

    
5366
        '    Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
5367
        '    If oAttributeRow.Length > 0 Then
5368
        '        For Each oAttribute In oAttributeRow
5369
        '            Try
5370
        '                Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
5371
        '                Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
5372
        '                If sPIDValue.Contains("'") Then
5373
        '                    sPIDValue = sPIDValue.Replace("'", """")
5374
        '                End If
5375
        '                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
5376
        '                oPipeRun.Attributes(sSPPIDAttribute).Value = sPIDValue
5377
        '            Catch ex As Exception
5378
        '            End Try
5379
        '        Next
5380
        '        oPipeRun.Commit()
5381
        '    End If
5382
        '    Dim sID_1 As String = ""
5383
        '    Dim sID_2 As String = ""
5384
        '    If oStartLMConnector IsNot Nothing Then
5385
        '        sID_1 = oStartLMConnector.ModelItemID
5386
        '        sID_2 = oLMConnector.ModelItemID
5387
        '    ElseIf oEndLMConnector IsNot Nothing Then
5388
        '        sID_1 = oEndLMConnector.ModelItemID
5389
        '        sID_2 = oLMConnector.ModelItemID
5390
        '    End If
5391
        '    If sID_1 <> "" And sID_2 <> "" Then
5392
        '        Dim objSurvivorItem As LMAItem = Nothing
5393
        '        Dim oPipeRun1 As LMPipeRun = oDatasource.GetPipeRun(sID_1)
5394
        '        Dim oPipeRun2 As LMPipeRun = oDatasource.GetPipeRun(sID_2)
5395
        '        _Placement.PIDJoinRuns(oPipeRun1, oPipeRun2)
5396
        '    End If
5397
        '    Return True
5398
        'Catch ex As Exception
5399
        '    Return False
5400
        'End Try
5401

    
5402
    End Function
5403

    
5404
    Private Function LineToLineModeling(ByVal sLineNoUid As String, ByVal oLine_Dt As DataTable,
5405
                                        ByVal oAttribute_Dt As DataTable, ByVal sConnLineUid As String, ByVal sType As String,
5406
                                        ByRef oLMConnector As LMConnector) As String
5407
        Dim sReturnUid As String = ""
5408
        Try
5409
            Dim sLineUid As String = ""
5410

    
5411
            Dim iConnType As Integer = 0
5412

    
5413
            Dim sStartpoint As String = ""
5414
            Dim sEndpoint As String = ""
5415
            Dim dOriginalStart_x As Double = 0.0
5416
            Dim dOriginalStart_y As Double = 0.0
5417
            Dim dOriginalEnd_x As Double = 0.0
5418
            Dim dOriginalEnd_y As Double = 0.0
5419

    
5420
            Dim dStart_x As Double = 0
5421
            Dim dStart_y As Double = 0
5422
            Dim dEnd_x As Double = 0
5423
            Dim dEnd_y As Double = 0
5424
            Dim sStartLineUid As String = sConnLineUid
5425
            Dim sEndLineUid As String = ""
5426
            Dim sDirection As String = ""
5427
            Dim sSystemPath As String = GetPipeType(sType)
5428

    
5429
            Dim oPipeRow() As DataRow = oLine_Dt.Select(_XML_LINE_UID & " = '" & sConnLineUid & "' And " &
5430
                                                                    "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And" &
5431
                                                                     "[" & _XML_SYMBOL_Check & "] = 'TRUE' And " &
5432
                                                                     "[" & _XML_SYMBOL_TYPE & "] = '" & sType & "'")
5433
            If oPipeRow.Length > 0 Then
5434
                sStartpoint = oPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
5435
                sEndpoint = oPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
5436
                ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
5437
                ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
5438
                ConvertPointByImage(dOriginalStart_x, dOriginalStart_y, _IMG_X, _IMG_Y)
5439
                ConvertPointByImage(dOriginalEnd_x, dOriginalEnd_y, _IMG_X, _IMG_Y)
5440
                If dStart_x = 0 And dStart_y = 0 Then
5441
                    dStart_x = dOriginalStart_x
5442
                    dStart_y = dOriginalStart_y
5443
                    dEnd_x = dOriginalEnd_x
5444
                    dEnd_y = dOriginalEnd_y
5445
                    If Math.Abs(dOriginalStart_x - dOriginalEnd_x) > Math.Abs(dOriginalStart_y - dOriginalEnd_y) Then
5446
                        sDirection = "X"
5447
                    Else
5448
                        sDirection = "Y"
5449
                    End If
5450
                    oPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5451
                    sLineUid = sConnLineUid
5452
                End If
5453
            End If
5454

    
5455
            While True
5456
                sLineUid = ""
5457
                oPipeRow = oLine_Dt.Select(_XML_LINE_Conn1_Uid & " = '" + sConnLineUid + "' And " &
5458
                                            "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And" &
5459
                                            "[" & _XML_SYMBOL_Check & "] = 'TRUE' And " &
5460
                                            "[" & _XML_SYMBOL_TYPE & "] = '" & sType & "'")
5461

    
5462
                If oPipeRow.Length = 0 Then
5463
                    oPipeRow = oLine_Dt.Select(_XML_LINE_Conn2_Uid & " = '" + sConnLineUid + "' And " &
5464
                                            "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And" &
5465
                                            "[" & _XML_SYMBOL_Check & "] = 'TRUE' And " &
5466
                                            "[" & _XML_SYMBOL_TYPE & "] = '" & sType & "'")
5467
                Else
5468
                    'sLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5469
                    'sConnLineUid = sLineUid
5470
                    sLineUid = sConnLineUid
5471
                    sConnLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5472
                    iConnType = 1
5473
                End If
5474

    
5475
                If oPipeRow.Length > 0 Then
5476
                    If sLineUid = "" Then
5477
                        'sLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5478
                        'sConnLineUid = sLineUid
5479
                        sLineUid = sConnLineUid
5480
                        sConnLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5481
                        iConnType = 2
5482
                    End If
5483
                    If iConnType = 1 Then
5484

    
5485
                    ElseIf iConnType = 2 Then
5486

    
5487
                    End If
5488
                    sStartpoint = oPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
5489
                    sEndpoint = oPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
5490
                    ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
5491
                    ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
5492
                    ConvertPointByImage(dOriginalStart_x, dOriginalStart_y, _IMG_X, _IMG_Y)
5493
                    ConvertPointByImage(dOriginalEnd_x, dOriginalEnd_y, _IMG_X, _IMG_Y)
5494

    
5495
                    If dStart_x = 0 And dStart_y = 0 Then
5496
                        dStart_x = dOriginalStart_x
5497
                        dStart_y = dOriginalStart_y
5498
                        dEnd_x = dOriginalEnd_x
5499
                        dEnd_y = dOriginalEnd_y
5500
                        If Math.Abs(dOriginalStart_x - dOriginalEnd_x) > Math.Abs(dOriginalStart_y - dOriginalEnd_y) Then
5501
                            sDirection = "X"
5502
                        Else
5503
                            sDirection = "Y"
5504
                        End If
5505
                        sType = oPipeRow(0)(_XML_LINE_TYPE).ToString()
5506
                        sSystemPath = GetPipeType(sType)
5507
                    Else
5508
                        If Math.Abs(dOriginalStart_x - dOriginalEnd_x) > Math.Abs(dOriginalStart_y - dOriginalEnd_y) Then
5509
                            If sDirection = "Y" Then
5510
                                '방향이 바꼈음 Y - > X
5511
                                LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5512
                                sLineNoUid, sLineUid, sSystemPath, oLMConnector)
5513
                                dStart_x = dOriginalStart_x
5514
                                dStart_y = dOriginalStart_y
5515
                                dEnd_x = dOriginalEnd_x
5516
                                dEnd_y = dOriginalEnd_y
5517
                                sStartLineUid = sConnLineUid
5518
                            Else
5519
                                dEnd_x = dOriginalEnd_x
5520
                                dEnd_y = dOriginalEnd_y
5521
                            End If
5522
                            sDirection = "X"
5523
                        Else
5524
                            If sDirection = "X" Then
5525
                                '방향이 바꼈음 X - > Y
5526
                                LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5527
                                sLineNoUid, sLineUid, sSystemPath, oLMConnector)
5528
                                dStart_x = dOriginalStart_x
5529
                                dStart_y = dOriginalStart_y
5530
                                dEnd_x = dOriginalEnd_x
5531
                                dEnd_y = dOriginalEnd_y
5532
                                sStartLineUid = sConnLineUid
5533
                            Else
5534

    
5535
                                dEnd_x = dOriginalEnd_x
5536
                                dEnd_y = dOriginalEnd_y
5537
                            End If
5538
                            sDirection = "Y"
5539
                        End If
5540
                    End If
5541
                    '            oPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5542
                Else
5543
                    If dStart_x <> 0 And dStart_y <> 0 And dEnd_x <> 0 And dEnd_y <> 0 Then
5544
                        LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5545
                         sLineNoUid, sLineUid, sSystemPath, oLMConnector)
5546
                    End If
5547
                    sReturnUid = sConnLineUid
5548
                    Exit While
5549
                End If
5550
            End While
5551

    
5552
            If sStartLineUid <> "" And sEndLineUid <> "" Then
5553
                LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5554
                             sLineNoUid, sLineUid, sSystemPath, oLMConnector)
5555
                dStart_x = 0
5556
                dStart_y = 0
5557
                dEnd_x = 0
5558
                dEnd_y = 0
5559
            End If
5560
        Catch ex As Exception
5561

    
5562
        End Try
5563

    
5564
        Return sReturnUid
5565
    End Function
5566

    
5567

    
5568
    'Private Function LineToLineModeling(ByVal sLineNoUid As String, ByVal oLine_Dt As DataTable,
5569
    '                                    ByVal oAttribute_Dt As DataTable, ByVal sConnLineUid As String, ByVal sType As String) As String
5570
    '    Dim sReturnUid As String = ""
5571
    '    Try
5572
    '        Dim sLineUid As String = ""
5573

    
5574
    '        Dim iConnType As Integer = 0
5575

    
5576
    '        Dim sStartpoint As String = ""
5577
    '        Dim sEndpoint As String = ""
5578
    '        Dim dOriginalStart_x As Double = 0.0
5579
    '        Dim dOriginalStart_y As Double = 0.0
5580
    '        Dim dOriginalEnd_x As Double = 0.0
5581
    '        Dim dOriginalEnd_y As Double = 0.0
5582

    
5583
    '        Dim dStart_x As Double = 0
5584
    '        Dim dStart_y As Double = 0
5585
    '        Dim dEnd_x As Double = 0
5586
    '        Dim dEnd_y As Double = 0
5587
    '        Dim sStartLineUid As String = sConnLineUid
5588
    '        Dim sEndLineUid As String = ""
5589
    '        Dim sDirection As String = ""
5590
    '        Dim sSystemPath As String = GetPipeType(sType)
5591

    
5592
    '        Dim oPipeRow() As DataRow = oLine_Dt.Select(_XML_LINE_UID & " = '" & sConnLineUid & "' And " &
5593
    '                                                                "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And" &
5594
    '                                                                 "[" & _XML_SYMBOL_Check & "] = 'TRUE' And " &
5595
    '                                                                 "[" & _XML_SYMBOL_TYPE & "] = '" & sType & "'")
5596
    '        If oPipeRow.Length > 0 Then
5597
    '            sStartpoint = oPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
5598
    '            sEndpoint = oPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
5599
    '            ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
5600
    '            ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
5601
    '            ConvertPointByImage(dOriginalStart_x, dOriginalStart_y, _IMG_X, _IMG_Y)
5602
    '            ConvertPointByImage(dOriginalEnd_x, dOriginalEnd_y, _IMG_X, _IMG_Y)
5603
    '            If dStart_x = 0 And dStart_y = 0 Then
5604
    '                dStart_x = dOriginalStart_x
5605
    '                dStart_y = dOriginalStart_y
5606
    '                dEnd_x = dOriginalEnd_x
5607
    '                dEnd_y = dOriginalEnd_y
5608
    '                If Math.Abs(dOriginalStart_x - dOriginalEnd_x) > Math.Abs(dOriginalStart_y - dOriginalEnd_y) Then
5609
    '                    sDirection = "X"
5610
    '                Else
5611
    '                    sDirection = "Y"
5612
    '                End If
5613
    '                oPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5614
    '                sLineUid = sConnLineUid
5615
    '            End If
5616
    '        End If
5617

    
5618
    '        While True
5619
    '            sLineUid = ""
5620
    '            oPipeRow = oLine_Dt.Select(_XML_LINE_Conn1_Uid & " = '" + sConnLineUid + "' And " &
5621
    '                                                                "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And" &
5622
    '                                                                         "[" & _XML_SYMBOL_Check & "] = 'TRUE' And " &
5623
    '                                                                         "[" & _XML_SYMBOL_TYPE & "] = '" & sType & "'")
5624

    
5625
    '            If oPipeRow.Length = 0 Then
5626
    '                oPipeRow = oLine_Dt.Select(_XML_LINE_Conn2_Uid & " = '" + sConnLineUid + "' And " &
5627
    '                                         "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And" &
5628
    '                                       "[" & _XML_SYMBOL_Check & "] = 'TRUE' And " &
5629
    '                                      "[" & _XML_SYMBOL_TYPE & "] = '" & sType & "'")
5630
    '            Else
5631
    '                'sLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5632
    '                'sConnLineUid = sLineUid
5633
    '                sLineUid = sConnLineUid
5634
    '                sConnLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5635
    '                iConnType = 1
5636
    '            End If
5637

    
5638
    '            If oPipeRow.Length > 0 Then
5639
    '                If sLineUid = "" Then
5640
    '                    'sLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5641
    '                    'sConnLineUid = sLineUid
5642
    '                    sLineUid = sConnLineUid
5643
    '                    sConnLineUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5644
    '                    iConnType = 2
5645
    '                End If
5646
    '                If iConnType = 1 Then
5647

    
5648
    '                ElseIf iConnType = 2 Then
5649

    
5650
    '                End If
5651
    '                sStartpoint = oPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
5652
    '                sEndpoint = oPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
5653
    '                ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
5654
    '                ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
5655
    '                ConvertPointByImage(dOriginalStart_x, dOriginalStart_y, _IMG_X, _IMG_Y)
5656
    '                ConvertPointByImage(dOriginalEnd_x, dOriginalEnd_y, _IMG_X, _IMG_Y)
5657

    
5658

    
5659

    
5660
    '                If dStart_x = 0 And dStart_y = 0 Then
5661
    '                    dStart_x = dOriginalStart_x
5662
    '                    dStart_y = dOriginalStart_y
5663
    '                    dEnd_x = dOriginalEnd_x
5664
    '                    dEnd_y = dOriginalEnd_y
5665
    '                    If Math.Abs(dOriginalStart_x - dOriginalEnd_x) > Math.Abs(dOriginalStart_y - dOriginalEnd_y) Then
5666
    '                        sDirection = "X"
5667
    '                    Else
5668
    '                        sDirection = "Y"
5669
    '                    End If
5670
    '                    sType = oPipeRow(0)(_XML_LINE_TYPE).ToString()
5671
    '                    sSystemPath = GetPipeType(sType)
5672
    '                Else
5673
    '                    If Math.Abs(dOriginalStart_x - dOriginalEnd_x) > Math.Abs(dOriginalStart_y - dOriginalEnd_y) Then
5674
    '                        If sDirection = "Y" Then
5675
    '                            '방향이 바꼈음 Y - > X
5676
    '                            LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5677
    '                            sLineNoUid, sLineUid, sSystemPath)
5678
    '                            dStart_x = dOriginalStart_x
5679
    '                            dStart_y = dOriginalStart_y
5680
    '                            dEnd_x = dOriginalEnd_x
5681
    '                            dEnd_y = dOriginalEnd_y
5682
    '                            sStartLineUid = sConnLineUid
5683
    '                        Else
5684
    '                            dEnd_x = dOriginalEnd_x
5685
    '                            dEnd_y = dOriginalEnd_y
5686
    '                        End If
5687
    '                        sDirection = "X"
5688
    '                    Else
5689
    '                        If sDirection = "X" Then
5690
    '                            '방향이 바꼈음 X - > Y
5691
    '                            LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5692
    '                            sLineNoUid, sLineUid, sSystemPath)
5693
    '                            dStart_x = dOriginalStart_x
5694
    '                            dStart_y = dOriginalStart_y
5695
    '                            dEnd_x = dOriginalEnd_x
5696
    '                            dEnd_y = dOriginalEnd_y
5697
    '                            sStartLineUid = sConnLineUid
5698
    '                        Else
5699

    
5700
    '                            dEnd_x = dOriginalEnd_x
5701
    '                            dEnd_y = dOriginalEnd_y
5702
    '                        End If
5703
    '                        sDirection = "Y"
5704
    '                    End If
5705
    '                End If
5706
    '                '            oPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5707
    '            Else
5708
    '                If dStart_x <> 0 And dStart_y <> 0 And dEnd_x <> 0 And dEnd_y <> 0 Then
5709
    '                    LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5710
    '                     sLineNoUid, sLineUid, sSystemPath)
5711
    '                End If
5712

    
5713

    
5714
    '                sReturnUid = sConnLineUid
5715
    '                Exit While
5716
    '            End If
5717
    '        End While
5718

    
5719
    '        If sStartLineUid <> "" And sEndLineUid <> "" Then
5720
    '            LineModeling(oLine_Dt, oAttribute_Dt, sStartLineUid, sEndLineUid, dStart_x, dStart_y, dEnd_x, dEnd_y,
5721
    '                         sLineNoUid, sLineUid, sSystemPath)
5722
    '            dStart_x = 0
5723
    '            dStart_y = 0
5724
    '            dEnd_x = 0
5725
    '            dEnd_y = 0
5726
    '        End If
5727
    '    Catch ex As Exception
5728

    
5729
    '    End Try
5730

    
5731
    '    Return sReturnUid
5732
    'End Function
5733

    
5734

    
5735
    Private Function SymbolToLine_Modeling(ByVal oLine_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal sLineNoUid As String,
5736
                                       ByVal sSymbolUid As String, ByVal oLMSymbol As LMSymbol) As String
5737

    
5738

    
5739
        Dim oDatasource As Object = _Placement.PIDDataSource
5740
        Dim oPipeRun As LMPipeRun = Nothing
5741
        Dim objItem As LMAItem
5742
        Dim objConnector As LMConnector
5743
        Dim objInputs As PlaceRunInputs
5744
        objInputs = New PlaceRunInputs
5745

    
5746

    
5747
        Dim sPipeUid As String = ""
5748
        Dim iConnType As Integer = 0
5749
        Dim sStartpoint As String = ""
5750
        Dim sEndpoint As String = ""
5751
        Dim dOriginalStart_x As Double = 0.0
5752
        Dim dOriginalStart_y As Double = 0.0
5753
        Dim dOriginalEnd_x As Double = 0.0
5754
        Dim dOriginalEnd_y As Double = 0.0
5755
        Dim dStart_x As Double = 0.0
5756
        Dim dStart_y As Double = 0.0
5757
        Dim dEnd_x As Double = 0.0
5758
        Dim dEnd_y As Double = 0.0
5759

    
5760
        Dim sReturnUid As String = ""
5761
        Dim oPipeRow() As DataRow = oLine_Dt.Select(_XML_LINE_Conn1_Uid & " = '" + sSymbolUid + "' And " &
5762
                                                                        "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' " &
5763
                                                                                  _XML_SYMBOL_Check & "] = 'TRUE'")
5764
        If oPipeRow.Length = 0 Then
5765
            oPipeRow = oLine_Dt.Select(_XML_LINE_Conn2_Uid & " = '" + sSymbolUid + "' And " &
5766
                                     "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' " &
5767
                                    _XML_SYMBOL_Check & "] = 'TRUE'")
5768
        Else
5769
            sPipeUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5770
            iConnType = 1
5771
        End If
5772

    
5773
        If oPipeRow.Length = 1 Then
5774
            If sPipeUid = "" Then
5775
                sPipeUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5776
                iConnType = 2
5777
            End If
5778
            sReturnUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5779
            sStartpoint = oPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
5780
            sEndpoint = oPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
5781
            ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
5782
            dStart_x = dOriginalStart_x
5783
            dStart_y = dOriginalStart_y
5784
            ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
5785
            dEnd_x = dOriginalEnd_x
5786
            dEnd_y = dOriginalEnd_y
5787
            ConvertPointByImage(dStart_x, dStart_y, _IMG_X, _IMG_Y)
5788
            ConvertPointByImage(dEnd_x, dEnd_y, _IMG_X, _IMG_Y)
5789
            'OPC Connection Point가져와서 연결(2018-07-12)
5790
            If iConnType = 1 Then
5791
                FindNearPoint(oLMSymbol, dStart_x, dStart_y)
5792
                objInputs.AddSymbolTarget(oLMSymbol, dStart_x, dStart_y)
5793
                objInputs.AddPoint(dEnd_x, dEnd_y)
5794
            Else
5795
                FindNearPoint(oLMSymbol, dEnd_x, dEnd_y)
5796
                objInputs.AddSymbolTarget(oLMSymbol, dEnd_x, dEnd_y)
5797
                objInputs.AddPoint(dStart_x, dStart_y)
5798
            End If
5799
            oPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5800

    
5801
            Dim sType As String = oPipeRow(0)(_XML_LINE_TYPE).ToString()
5802
            Dim sSystemPath As String = GetPipeType(sType)
5803

    
5804

    
5805

    
5806

    
5807
            objItem = _Placement.PIDCreateItem(sSystemPath)
5808
            objConnector = _Placement.PIDPlaceRun(objItem, objInputs)
5809
            oPipeRun = oDatasource.GetPipeRun(objConnector.ModelItemID)
5810
            Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
5811
            If oAttributeRow.Length > 0 Then
5812
                For Each oAttribute In oAttributeRow
5813
                    Try
5814
                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
5815
                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
5816
                        If sPIDValue.Contains("'") Then
5817
                            sPIDValue = sPIDValue.Replace("'", """")
5818
                        End If
5819
                        Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
5820
                        oPipeRun.Attributes(sSPPIDAttribute).Value = sPIDValue
5821
                    Catch ex As Exception
5822
                    End Try
5823
                Next
5824
                oPipeRun.Commit()
5825
            End If
5826
        End If
5827
        Return sReturnUid
5828
    End Function
5829

    
5830
    Private Function LineToSymbol_Modeling(ByVal oSymbol_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal sLineNoUid As String,
5831
                                       ByVal sLineUid As String, ByVal oLMConnector As LMConnector, ByRef oLMSymbol As LMSymbol) As String
5832

    
5833

    
5834
        Dim oDatasource As Object = _Placement.PIDDataSource
5835
        Dim objItem As LMAItem
5836
        Dim objConnector As LMConnector
5837
        Dim objInputs As PlaceRunInputs
5838
        objInputs = New PlaceRunInputs
5839

    
5840

    
5841
        Dim sSymbolUid As String = ""
5842
        Dim iConnType As Integer = 0
5843
        Dim dOriginalPoint_x As Double = 0.0
5844
        Dim dORiginalPoint_y As Double = 0.0
5845
        Dim dX As Double = 0.0
5846
        Dim dY As Double = 0.0
5847
        Dim sReturnUid As String = ""
5848
        Dim oSymbolRow() As DataRow = oSymbol_Dt.Select(_XML_SYMBOL_Conn1_Uid & " = '" + sLineUid + "' And " &
5849
                                                                        "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' " &
5850
                                                                                  _XML_SYMBOL_Check & "] = 'TRUE'")
5851
        If oSymbolRow.Length = 0 Then
5852
            oSymbolRow = oSymbol_Dt.Select(_XML_SYMBOL_Conn2_Uid & " = '" + sLineUid + "' And " &
5853
                                                                        "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' " &
5854
                                                                                 _XML_SYMBOL_Check & "] = 'TRUE'")
5855
            If oSymbolRow.Length = 0 Then
5856
                oSymbolRow = oSymbol_Dt.Select(_XML_SYMBOL_Conn2_Uid & " = '" + sLineUid + "' And " &
5857
                                                                 "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' " &
5858
                                                                          _XML_SYMBOL_Check & "] = 'TRUE'")
5859
                If oSymbolRow.Length = 0 Then
5860
                    oSymbolRow = oSymbol_Dt.Select(_XML_SYMBOL_Conn2_Uid & " = '" + sLineUid + "' And " &
5861
                                                   "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' " &
5862
                                                            _XML_SYMBOL_Check & "] = 'TRUE'")
5863
                    If oSymbolRow.Length = 0 Then
5864

    
5865
                    Else
5866
                        sSymbolUid = oSymbolRow(0)(_XML_SYMBOL_UID).ToString()
5867
                        iConnType = 4
5868
                    End If
5869
                Else
5870
                    sSymbolUid = oSymbolRow(0)(_XML_SYMBOL_UID).ToString()
5871
                    iConnType = 3
5872
                End If
5873
            Else
5874
                sSymbolUid = oSymbolRow(0)(_XML_SYMBOL_UID).ToString()
5875
                iConnType = 2
5876
            End If
5877

    
5878
        Else
5879
            sSymbolUid = oSymbolRow(0)(_XML_SYMBOL_UID).ToString()
5880
            iConnType = 1
5881
        End If
5882

    
5883
        If oSymbolRow.Length = 1 Then
5884
            If sSymbolUid = "" Then
5885
                sSymbolUid = oSymbolRow(0)(_XML_SYMBOL_UID).ToString()
5886
                iConnType = 2
5887
            End If
5888
            sReturnUid = oSymbolRow(0)(_XML_SYMBOL_UID).ToString()
5889
            Dim sOriginalPoint As String = oSymbolRow(0)(_XML_SYMBOL_ORIGINALPOINT).ToString()
5890
            ConvertPointBystring(sOriginalPoint, dOriginalPoint_x, dORiginalPoint_y)
5891
            dX = dOriginalPoint_x
5892
            dY = dORiginalPoint_y
5893
            ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
5894
            'OPC Connection Point가져와서 연결(2018-07-12)
5895

    
5896
            oSymbolRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5897

    
5898
            Dim sType As String = oSymbolRow(0)(_XML_LINE_TYPE).ToString()
5899
            Dim sSystemPath As String = GetPipeType(sType)
5900

    
5901
            oLMSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, ExistingItem:=oLMConnector.AsLMAItem,
5902
          TargetItem:=oLMSymbol.AsLMAItem)
5903

    
5904
            Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
5905
            If oAttributeRow.Length > 0 Then
5906
                For Each oAttribute In oAttributeRow
5907
                    Try
5908
                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
5909
                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
5910
                        If sPIDValue.Contains("'") Then
5911
                            sPIDValue = sPIDValue.Replace("'", """")
5912
                        End If
5913
                        Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
5914
                        oLMSymbol.Attributes(sSPPIDAttribute).Value = sPIDValue
5915
                    Catch ex As Exception
5916
                    End Try
5917
                Next
5918
            End If
5919
        End If
5920
        Return sReturnUid
5921
    End Function
5922

    
5923

    
5924
    Private Sub OPCTOLineRouting(ByRef oLine_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal oOPCSymbol As LMSymbol,
5925
                            ByVal sOPCUid As String, ByVal sLineNoUid As String)
5926
        Try
5927
            Dim oDatasource As Object = _Placement.PIDDataSource
5928
            Dim objItem As LMAItem
5929
            Dim objConnector As LMConnector
5930
            Dim objInputs As PlaceRunInputs
5931
            objInputs = New PlaceRunInputs
5932
            Dim dOriginalStart_x As Double = 0.0
5933
            Dim dOriginalStart_y As Double = 0.0
5934
            Dim dOriginalEnd_x As Double = 0.0
5935
            Dim dOriginalEnd_y As Double = 0.0
5936
            Dim dStart_x As Double = 0.0
5937
            Dim dStart_y As Double = 0.0
5938
            Dim dEnd_x As Double = 0.0
5939
            Dim dEnd_y As Double = 0.0
5940

    
5941
            Dim oPipeRun As LMPipeRun = Nothing
5942
            Dim sStartpoint As String = ""
5943
            Dim sEndpoint As String = ""
5944
            Dim iConnType As Integer = 0
5945
            Dim oPipeRow() As DataRow = oLine_Dt.Select(_XML_LINE_Conn1_Uid & " = '" + sOPCUid + "' And [" &
5946
                                                                                       _XML_SYMBOL_Check & "] = 'TRUE'")
5947
            Dim sPipeUid As String = ""
5948
            If oPipeRow.Length = 0 Then
5949
                oPipeRow = oLine_Dt.Select(_XML_LINE_Conn2_Uid & " = '" + sOPCUid + "' And [" &
5950
                        _XML_SYMBOL_Check & "] = 'TRUE'")
5951
            Else
5952
                sPipeUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5953
                iConnType = 1
5954
            End If
5955
            Dim oAddUid_List As New List(Of String)
5956
            If oPipeRow.Length = 1 Then
5957
                If sPipeUid = "" Then
5958
                    sPipeUid = oPipeRow(0)(_XML_LINE_UID).ToString()
5959
                    iConnType = 2
5960
                End If
5961
                oAddUid_List.Add(sPipeUid)
5962
                sStartpoint = oPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
5963
                sEndpoint = oPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
5964
                ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
5965
                dStart_x = dOriginalStart_x
5966
                dStart_y = dOriginalStart_y
5967
                ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
5968
                dEnd_x = dOriginalEnd_x
5969
                dEnd_y = dOriginalEnd_y
5970
                ConvertPointByImage(dStart_x, dStart_y, _IMG_X, _IMG_Y)
5971
                ConvertPointByImage(dEnd_x, dEnd_y, _IMG_X, _IMG_Y)
5972

    
5973
                'OPC Connection Point가져와서 연결(2018-07-12)
5974
                If iConnType = 1 Then
5975
                    FindNearPoint(oOPCSymbol, dStart_x, dStart_y)
5976
                    objInputs.AddSymbolTarget(oOPCSymbol, dStart_x, dStart_y)
5977
                    objInputs.AddPoint(dEnd_x, dEnd_y)
5978
                Else
5979
                    FindNearPoint(oOPCSymbol, dEnd_x, dEnd_y)
5980
                    objInputs.AddSymbolTarget(oOPCSymbol, dEnd_x, dEnd_y)
5981
                    objInputs.AddPoint(dStart_x, dStart_y)
5982
                End If
5983
                oPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
5984

    
5985
                While True
5986
                    '    objInputs.Clear()
5987
                    Dim oAddPipeRow() As DataRow = oLine_Dt.Select("[" & _XML_LINE_Conn1_Uid & "] = '" + sPipeUid + "' and " &
5988
                                                                 "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And [" &
5989
                                                                                       _XML_SYMBOL_Check & "] = 'TRUE'")
5990
                    If oAddPipeRow.Length = 0 Then
5991
                        oAddPipeRow = oLine_Dt.Select("[" & _XML_LINE_Conn2_Uid & "] = '" + sPipeUid + "' and " &
5992
                                                                 "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And [" &
5993
                                                                                       _XML_SYMBOL_Check & "] = 'TRUE'")
5994
                        sPipeUid = ""
5995
                    Else
5996
                        iConnType = 1
5997
                        sPipeUid = oAddPipeRow(0)(_XML_LINE_UID).ToString()
5998
                    End If
5999
                    If oAddPipeRow.Length = 1 Then
6000
                        If sPipeUid = "" Then
6001
                            sPipeUid = oAddPipeRow(0)(_XML_LINE_UID).ToString()
6002
                            iConnType = 2
6003
                        End If
6004
                        oAddUid_List.Add(sPipeUid)
6005
                        sStartpoint = oAddPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
6006
                        sEndpoint = oAddPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
6007
                        ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
6008
                        dStart_x = dOriginalStart_x
6009
                        dStart_y = dOriginalStart_y
6010
                        ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
6011
                        dEnd_x = dOriginalEnd_x
6012
                        dEnd_y = dOriginalEnd_y
6013
                        ConvertPointByImage(dStart_x, dStart_y, _IMG_X, _IMG_Y)
6014
                        ConvertPointByImage(dEnd_x, dEnd_y, _IMG_X, _IMG_Y)
6015
                        If iConnType = 1 Then
6016
                            objInputs.AddPoint(dEnd_x, dEnd_y)
6017
                            ' objInputs.AddPoint(dStart_x, dStart_y)
6018
                        Else
6019
                            'objInputs.AddConnectorTarget(objConnector, dStart_x, dStart_y)
6020
                            '  objInputs.AddPoint(dStart_x, dStart_y)
6021
                            '  objInputs.AddPoint(dEnd_x, dEnd_y)
6022
                            objInputs.AddPoint(dStart_x, dStart_y)
6023
                        End If
6024

    
6025
                        oAddPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
6026
                    Else
6027
                        Exit While
6028
                    End If
6029

    
6030
                End While
6031
                Dim sType As String = oPipeRow(0)(_XML_LINE_TYPE).ToString()
6032
                Dim sSystemPath As String = GetPipeType(sType)
6033

    
6034
                objItem = _Placement.PIDCreateItem(sSystemPath)
6035
                objConnector = _Placement.PIDPlaceRun(objItem, objInputs)
6036
                For i = 0 To oAddUid_List.Count - 1
6037
                    Dim oUpdateRow As DataRow() = oLine_Dt.Select(_XML_LINE_UID & " = '" + oAddUid_List(i) + "'")
6038
                    If oUpdateRow.Length = 1 Then
6039
                        oUpdateRow(0)(_XML_LINE_SPID) = objConnector.ModelItemID
6040
                        oUpdateRow(0)(_XML_LINE_LMCONNECTOR) = objConnector
6041
                    End If
6042
                Next
6043

    
6044

    
6045
                oPipeRun = oDatasource.GetPipeRun(objConnector.ModelItemID)
6046
                Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
6047
                If oAttributeRow.Length > 0 Then
6048
                    For Each oAttribute In oAttributeRow
6049
                        Try
6050
                            Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6051
                            Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6052
                            If sPIDValue.Contains("'") Then
6053
                                sPIDValue = sPIDValue.Replace("'", """")
6054
                            End If
6055
                            Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6056
                            oPipeRun.Attributes(sSPPIDAttribute).Value = sPIDValue
6057
                        Catch ex As Exception
6058
                        End Try
6059
                    Next
6060
                    oPipeRun.Commit()
6061
                End If
6062

    
6063
            End If
6064

    
6065
        Catch ex As Exception
6066
        End Try
6067
    End Sub
6068

    
6069
    Private Function AddUidList중복체크(ByVal sUidList As List(Of String), ByVal sAddUid As String) As Boolean
6070

    
6071
        For Each sUid In sUidList
6072
            If sUid = sAddUid Then
6073
                Return False
6074
            End If
6075
        Next
6076
        Return True
6077
    End Function
6078

    
6079
    Private Sub LineRouting(ByRef oLine_Dt As DataTable, ByVal oAttribute_Dt As DataTable, ByVal sLineNoUid As String, ByVal sLineNoText As String)
6080
        Try
6081
            Dim oDatasource As Object = _Placement.PIDDataSource
6082
            Dim objItem As LMAItem
6083
            Dim objConnector As LMConnector
6084
            Dim objInputs As PlaceRunInputs
6085
            objInputs = New PlaceRunInputs
6086
            Dim dOriginalStart_x As Double = 0.0
6087
            Dim dOriginalStart_y As Double = 0.0
6088
            Dim dOriginalEnd_x As Double = 0.0
6089
            Dim dOriginalEnd_y As Double = 0.0
6090
            Dim dStart_x As Double = 0.0
6091
            Dim dStart_y As Double = 0.0
6092
            Dim dEnd_x As Double = 0.0
6093
            Dim dEnd_y As Double = 0.0
6094
            Dim oPipeRun As LMPipeRun = Nothing
6095
            Dim sStartpoint As String = ""
6096
            Dim sEndpoint As String = ""
6097
            Dim iConnType As Integer = 0
6098
            Dim pLMConnector As LMConnector = Nothing
6099
            For Each oLinerow In oLine_Dt.Rows
6100
                objInputs.Clear()
6101
                Dim sCheck As String = oLinerow(_XML_LINE_DRAWING_TF).ToString()
6102
                If sCheck = "FALSE" Then
6103
                    Dim sUid As String = oLinerow(_XML_LINE_UID).ToString()
6104
                    sStartpoint = oLinerow(_XML_LINE_STARTPOINT).ToString()
6105
                    sEndpoint = oLinerow(_XML_LINE_ENDPOINT).ToString()
6106
                    ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
6107
                    dStart_x = dOriginalStart_x
6108
                    dStart_y = dOriginalStart_y
6109
                    ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
6110
                    dEnd_x = dOriginalEnd_x
6111
                    dEnd_y = dOriginalEnd_y
6112
                    ConvertPointByImage(dStart_x, dStart_y, _IMG_X, _IMG_Y)
6113
                    ConvertPointByImage(dEnd_x, dEnd_y, _IMG_X, _IMG_Y)
6114

    
6115
                    objInputs.AddPoint(dStart_x, dStart_y)
6116
                    objInputs.AddPoint(dEnd_x, dEnd_y)
6117
                    Dim sType As String = oLinerow(_XML_LINE_TYPE).ToString()
6118
                    Dim sSystemPath As String = GetPipeType(sType)
6119
                    objItem = _Placement.PIDCreateItem(sSystemPath)
6120
                    objConnector = _Placement.PIDPlaceRun(objItem, objInputs)
6121
                    SetListBoxItems(ListBox_Result, "Place Pipe.." & sUid & " (" & dOriginalStart_x & "," & dOriginalStart_y & ") - (" & dOriginalEnd_x & "," & dOriginalEnd_y & ")..." & _iPipecnt & " count ")
6122

    
6123
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Pipe : " & sUid)
6124
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "LineNo : " & sLineNoText)
6125
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection1 : " & oLinerow(_XML_SYMBOL_Conn1_Uid).ToString())
6126
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection2 : " & oLinerow(_XML_SYMBOL_Conn2_Uid).ToString())
6127
                    'ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
6128
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "StartPoint : " & dOriginalStart_x & "," & dOriginalStart_y)
6129
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "EndPoint : " & dOriginalEnd_x & "," & dOriginalEnd_y)
6130
                    ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Pipe Count : " & _iPipecnt)
6131

    
6132
                    _iPipecnt = _iPipecnt + 1
6133
                    oLinerow(_XML_LINE_SPID) = objConnector.ModelItemID
6134
                    oLinerow(_XML_LINE_LMCONNECTOR) = objConnector
6135

    
6136
                    oLinerow(_XML_LINE_DRAWING_TF) = "TRUE"
6137
                    oPipeRun = oDatasource.GetPipeRun(objConnector.ModelItemID)
6138

    
6139
                    Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
6140
                    If oAttributeRow.Length > 0 Then
6141
                        For Each oAttribute In oAttributeRow
6142
                            Try
6143
                                Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6144
                                Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6145
                                If sPIDValue.Contains("'") Then
6146
                                    sPIDValue = sPIDValue.Replace("'", """")
6147
                                End If
6148
                                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6149
                                oPipeRun.Attributes(sSPPIDAttribute).Value = sPIDValue
6150
                            Catch ex As Exception
6151
                            End Try
6152
                        Next
6153
                        oPipeRun.Commit()
6154
                    End If
6155
                End If
6156

    
6157

    
6158

    
6159

    
6160

    
6161
                'Dim sPipeUid As String = oLinerow(_XML_LINE_UID).ToString()
6162
                'Dim sCheckModeling As Boolean = False
6163
                'objInputs.Clear()
6164
                'Dim oAddUid_List As New List(Of String)
6165
                'Try
6166
                '    Dim oAddPipeRow() As DataRow = oLine_Dt.Select("[" & _XML_LINE_Conn1_Uid & "] = '" + sPipeUid + "' and " &
6167
                '                                            "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And [" &
6168
                '                                            _XML_SYMBOL_Check & "] = 'TRUE'")
6169
                '    If oAddPipeRow.Length = 0 Then
6170
                '        oAddPipeRow = oLine_Dt.Select("[" & _XML_LINE_Conn2_Uid & "] = '" + sPipeUid + "' and " &
6171
                '                                        "[" & _XML_LINE_DRAWING_TF & "] = 'FALSE' And [" &
6172
                '                                        _XML_SYMBOL_Check & "] = 'TRUE'")
6173
                '        sPipeUid = ""
6174
                '    Else
6175
                '        iConnType = 1
6176
                '        sPipeUid = oAddPipeRow(0)(_XML_LINE_UID).ToString()
6177
                '    End If
6178
                '    If oAddPipeRow.Length = 1 Then
6179
                '        sCheckModeling = True
6180
                '        If sPipeUid = "" Then
6181
                '            sPipeUid = oAddPipeRow(0)(_XML_LINE_UID).ToString()
6182
                '            iConnType = 2
6183
                '        End If
6184
                '        If AddUidList중복체크(oAddUid_List, sPipeUid) Then
6185
                '            oAddUid_List.Add(sPipeUid)
6186
                '        End If
6187
                '        sStartpoint = oAddPipeRow(0)(_XML_LINE_STARTPOINT).ToString()
6188
                '        sEndpoint = oAddPipeRow(0)(_XML_LINE_ENDPOINT).ToString()
6189
                '        ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
6190
                '        dStart_x = dOriginalStart_x
6191
                '        dStart_y = dOriginalStart_y
6192
                '        ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
6193
                '        dEnd_x = dOriginalEnd_x
6194
                '        dEnd_y = dOriginalEnd_y
6195
                '        ConvertPointByImage(dStart_x, dStart_y, _IMG_X, _IMG_Y)
6196
                '        ConvertPointByImage(dEnd_x, dEnd_y, _IMG_X, _IMG_Y)
6197
                '        Dim sBranchType As String = ""
6198
                '        If (CheckBranchLine(oLine_Dt, dStart_x, dStart_y, dEnd_x, dEnd_y, sBranchType, pLMConnector)) Then
6199
                '            Try
6200
                '                If pLMConnector Is Nothing Then
6201
                '                    objInputs.AddPoint(dStart_x, dStart_y)
6202
                '                    objInputs.AddPoint(dEnd_x, dEnd_y)
6203
                '                Else
6204
                '                    If sBranchType = "1" Then
6205
                '                        objInputs.AddConnectorTarget(pLMConnector, dStart_x, dStart_y)
6206
                '                        objInputs.AddPoint(dEnd_x, dEnd_y)
6207
                '                    ElseIf sBranchType = "2" Then
6208
                '                        objInputs.AddConnectorTarget(pLMConnector, dEnd_x, dEnd_y)
6209
                '                        objInputs.AddPoint(dStart_x, dStart_y)
6210
                '                    ElseIf sBranchType = "3" Then
6211
                '                        objInputs.AddConnectorTarget(pLMConnector, dStart_x, dStart_y)
6212
                '                        objInputs.AddPoint(dEnd_x, dEnd_y)
6213
                '                    ElseIf sBranchType = "4" Then
6214
                '                        objInputs.AddConnectorTarget(pLMConnector, dEnd_x, dEnd_y)
6215
                '                        objInputs.AddPoint(dStart_x, dStart_y)
6216
                '                    End If
6217
                '                End If
6218
                '            Catch ex As Exception
6219
                '            End Try
6220
                '        Else
6221
                '            objInputs.AddPoint(dStart_x, dStart_y)
6222
                '            objInputs.AddPoint(dEnd_x, dEnd_y)
6223
                '        End If
6224
                '        oAddPipeRow(0)(_XML_LINE_DRAWING_TF) = "TRUE"
6225
                '    Else
6226
                '        Dim CheckTF As String = oLinerow(_XML_LINE_DRAWING_TF).ToString()
6227
                '        Dim CheckSelect As String = oLinerow(_XML_LINE_Check).ToString()
6228
                '        If CheckTF = "FALSE" And CheckSelect = "TRUE" Then
6229
                '            sPipeUid = oLinerow(_XML_LINE_UID).ToString()
6230
                '            oAddUid_List.Clear()
6231
                '            oAddUid_List.Add(sPipeUid)
6232
                '            sCheckModeling = True
6233
                '            sStartpoint = oLinerow(_XML_LINE_STARTPOINT).ToString()
6234
                '            sEndpoint = oLinerow(_XML_LINE_ENDPOINT).ToString()
6235
                '            ConvertPointBystring(sStartpoint, dOriginalStart_x, dOriginalStart_y)
6236
                '            dStart_x = dOriginalStart_x
6237
                '            dStart_y = dOriginalStart_y
6238
                '            ConvertPointBystring(sEndpoint, dOriginalEnd_x, dOriginalEnd_y)
6239
                '            dEnd_x = dOriginalEnd_x
6240
                '            dEnd_y = dOriginalEnd_y
6241
                '            ConvertPointByImage(dStart_x, dStart_y, _IMG_X, _IMG_Y)
6242
                '            ConvertPointByImage(dEnd_x, dEnd_y, _IMG_X, _IMG_Y)
6243
                '            Dim sBranchType As String = ""
6244
                '            If (CheckBranchLine(oLine_Dt, dStart_x, dStart_y, dEnd_x, dEnd_y, sBranchType, pLMConnector)) Then
6245
                '                Try
6246
                '                    If sBranchType = "1" Then
6247
                '                        objInputs.AddPoint(dEnd_x, dEnd_y)
6248
                '                        objInputs.AddConnectorTarget(pLMConnector, dStart_x, dStart_y)
6249
                '                    ElseIf sBranchType = "2" Then
6250
                '                        objInputs.AddPoint(dStart_x, dStart_y)
6251
                '                        objInputs.AddConnectorTarget(pLMConnector, dEnd_x, dEnd_y)
6252
                '                    ElseIf sBranchType = "3" Then
6253
                '                        objInputs.AddPoint(dEnd_x, dEnd_y)
6254
                '                        objInputs.AddConnectorTarget(pLMConnector, dStart_x, dStart_y)
6255
                '                    ElseIf sBranchType = "4" Then
6256
                '                        objInputs.AddPoint(dStart_x, dStart_y)
6257
                '                        objInputs.AddConnectorTarget(pLMConnector, dEnd_x, dEnd_y)
6258
                '                    End If
6259
                '                Catch ex As Exception
6260

    
6261
                '                End Try
6262
                '            Else
6263
                '                objInputs.AddPoint(dStart_x, dStart_y)
6264
                '                objInputs.AddPoint(dEnd_x, dEnd_y)
6265
                '            End If
6266
                '            oLinerow(_XML_LINE_DRAWING_TF) = "TRUE"
6267
                '        End If
6268
                '    End If
6269
                'Catch ex As Exception
6270
                'End Try
6271
                'If sCheckModeling Then
6272
                '    Dim sType As String = oLinerow(_XML_LINE_TYPE).ToString()
6273
                '    Dim sSystemPath As String = GetPipeType(sType)
6274
                '    objItem = _Placement.PIDCreateItem(sSystemPath)
6275
                '    objConnector = _Placement.PIDPlaceRun(objItem, objInputs)
6276
                '    For i = 0 To oAddUid_List.Count - 1
6277
                '        Dim oUpdateRow As DataRow() = oLine_Dt.Select(_XML_LINE_UID & " = '" + oAddUid_List(i) + "'")
6278
                '        If oUpdateRow.Length = 1 Then
6279
                '            oUpdateRow(0)(_XML_LINE_SPID) = objConnector.ModelItemID
6280
                '            oUpdateRow(0)(_XML_LINE_LMCONNECTOR) = objConnector
6281
                '        End If
6282
                '    Next
6283

    
6284
                '    oPipeRun = oDatasource.GetPipeRun(objConnector.ModelItemID)
6285
                '    oAddUid_List.Clear()
6286

    
6287
                '    Dim oAttributeRow() As DataRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sLineNoUid + "'")
6288
                '    If oAttributeRow.Length > 0 Then
6289
                '        For Each oAttribute In oAttributeRow
6290
                '            Try
6291
                '                Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6292
                '                Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6293
                '                If sPIDValue.Contains("'") Then
6294
                '                    sPIDValue = sPIDValue.Replace("'", """")
6295
                '                End If
6296
                '                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6297
                '                oPipeRun.Attributes(sSPPIDAttribute).Value = sPIDValue
6298
                '            Catch ex As Exception
6299
                '            End Try
6300
                '        Next
6301
                '        oPipeRun.Commit()
6302
                '    End If
6303

    
6304
                '    If pLMConnector IsNot Nothing Then
6305
                '        Dim sID_1 As String = pLMConnector.ModelItemID
6306
                '        Dim sID_2 As String = objConnector.ModelItemID
6307
                '        Dim objSurvivorItem As LMAItem = Nothing
6308
                '        Dim oPipeRun1 As LMPipeRun = oDatasource.GetPipeRun(sID_1)
6309
                '        Dim oPipeRun2 As LMPipeRun = oDatasource.GetPipeRun(sID_2)
6310
                '        _Placement.PIDJoinRuns(oPipeRun1, oPipeRun2)
6311
                '        '     oDatasource.CommitTransaction()
6312
                '        '_Placement.PIDAutoJoin(oPipeRun1.AsLMAItem, AutoJoinEndConstants.autoJoin_End, objSurvivorItem)
6313
                '        'oPipeRun1.Commit()
6314
                '        'oDatasource.CommitTransaction()
6315
                '        'objSurvivorItem = Nothing
6316
                '        '_Placement.PIDAutoJoin(oPipeRun2.AsLMAItem, AutoJoinEndConstants.autoJoin_Start, objSurvivorItem)
6317
                '        'oPipeRun2.Commit()
6318
                '        'oDatasource.CommitTransaction()
6319
                '    End If
6320
                '    sCheckModeling = False
6321
                '  End If
6322
            Next
6323
        Catch ex As Exception
6324
        End Try
6325
    End Sub
6326

    
6327

    
6328
    Private Sub SymbolModeling(ByVal CDrawing As Drawing, ByVal oLine_DT As DataTable, ByVal oSymbolRow As DataRow, ByVal oAttribute_Dt As DataTable,
6329
                               ByVal sLineNoText As String)
6330
        Try
6331

    
6332
            Dim sCheckModeling As String = oSymbolRow(_XML_SYMBOL_DRAWING_TF).ToString()
6333
            If sCheckModeling = "FALSE" Then
6334
                Dim sSymbolUid As String = oSymbolRow(_XML_SYMBOL_UID)
6335
                Dim oSymbol As LMSymbol = Nothing
6336
                Dim sSPID As String = oSymbolRow(_XML_SYMBOL_SPID).ToString()
6337
                Dim sSystemPath As String = oSymbolRow(_XML_SYMBOL_SYSTEMPATH).ToString()
6338
                Dim oDatasource As Object = _Placement.PIDDataSource
6339
                Dim sSymbolCompType As String = oSymbolRow(_XML_SYMBOL_TYPE).ToString()
6340
                Dim dLocationX As Double = 0.0
6341
                Dim dLocationY As Double = 0.0
6342
                Dim dX As Double = 0.0
6343
                Dim dY As Double = 0.0
6344
                Dim sOriginalPoint As String = oSymbolRow(_XML_SYMBOL_ORIGINALPOINT).ToString()
6345
                ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY)
6346
                dX = dLocationX
6347
                dY = dLocationY
6348
                ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
6349

    
6350
                Dim dAngle As Double = oSymbolRow(_XML_SYMBOL_ANGLE)
6351

    
6352

    
6353
                'Dim oDatarow() As DataRow = oLine_DT.Select("[" & _XML_LINE_Conn1_Uid & "] = '" & sSymbolUid & "'")
6354
                'If oDatarow.Length = 0 Then
6355
                '    oDatarow = oLine_DT.Select("[" & _XML_LINE_Conn2_Uid & "] = '" & sSymbolUid & "'")
6356
                'End If
6357
                'Dim dFix_X As Double = 0.0
6358
                'Dim dFix_Y As Double = 0.0
6359
                'If oDatarow.Length > 0 Then
6360
                '    If dAngle <> 0 Then
6361
                '        sOriginalPoint = oDatarow(0)(_XML_LINE_STARTPOINT).ToString()
6362
                '        ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY)
6363

    
6364
                '        ConvertPointByImage(dLocationX, dLocationY, _IMG_X, _IMG_Y)
6365
                '        dX = dLocationX
6366
                '    Else
6367
                '        sOriginalPoint = oDatarow(0)(_XML_LINE_STARTPOINT).ToString()
6368
                '        ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY)
6369
                '        ConvertPointByImage(dLocationX, dLocationY, _IMG_X, _IMG_Y)
6370
                '        dY = dLocationY
6371
                '    End If
6372

    
6373
                'End If
6374

    
6375

    
6376

    
6377
                oSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY,, dAngle)
6378
                SetListBoxItems(ListBox_Result, "Place Fitting.." & sSymbolUid & " (" & dLocationX & "," & dLocationY & ")..." & _iFittingcnt & " count ")
6379

    
6380
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Place Fitting : " & sSymbolUid)
6381
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "LineNo : " & sLineNoText)
6382
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection1 : " & oSymbolRow(_XML_SYMBOL_Conn1_Uid).ToString())
6383
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection2 : " & oSymbolRow(_XML_SYMBOL_Conn2_Uid).ToString())
6384
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection3 : " & oSymbolRow(_XML_SYMBOL_Conn3_Uid).ToString())
6385
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Connection4 : " & oSymbolRow(_XML_SYMBOL_Conn4_Uid).ToString())
6386
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Angle : " & dAngle)
6387
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "OriginalPoint : " & dLocationX & "," & dLocationY)
6388
                ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, "Fitting Count : " & _iFittingcnt)
6389

    
6390

    
6391
                _iFittingcnt = _iFittingcnt + 1
6392
                oSymbolRow(_XML_SYMBOL_DRAWING_TF) = "TRUE"
6393
                Dim oAttributeRow() As DataRow
6394
                oAttributeRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sSymbolUid + "'")
6395
                If oAttribute_Dt.Rows.Count > 0 Then
6396

    
6397
                    If sSymbolCompType.ToUpper() = _SYMBOL_INSTUMENT.ToUpper() Then
6398
                        Dim oInstrument As LMInstrument
6399
                        oInstrument = oDatasource.GetInstrument(oSymbol.ModelItemID)
6400
                        Try
6401
                            If oAttributeRow.Length > 0 Then
6402
                                For Each oAttribute In oAttributeRow
6403
                                    Try
6404
                                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6405
                                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6406
                                        Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6407
                                        oInstrument.Attributes(sSPPIDAttribute).Value = sPIDValue
6408
                                    Catch ex As Exception
6409
                                    End Try
6410
                                Next
6411
                                oInstrument.Commit()
6412
                            End If
6413
                        Catch ex As Exception
6414
                        End Try
6415
                    Else
6416
                        Try
6417
                            If oAttributeRow.Length > 0 And oSymbol IsNot Nothing Then
6418
                                For Each oAttribute In oAttributeRow
6419
                                    Try
6420
                                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6421
                                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6422

    
6423
                                        If sPIDAttribute = "SIZE" Then
6424

    
6425
                                            'Nominal diamter1,2속성이름뭔지 찾아봐야됨 (2018-07-20)
6426
                                            If sPIDValue.Contains("x") Then
6427
                                                Dim sSplitSize() As String = sPIDValue.Split("x")
6428
                                                If sSplitSize.Count > 1 Then
6429
                                                    'Connection Point와 연결되어 있는 라인을 가져와서 라인프로퍼티를 변경
6430
                                                    Dim oConnector_1 As LMConnector = Nothing
6431
                                                    Dim oConnector_2 As LMConnector = Nothing
6432
                                                    If oSymbol IsNot Nothing Then
6433
                                                        If oSymbol.Connect1Connectors.Count >= 1 Then
6434
                                                            For Each Tconnector In oSymbol.Connect1Connectors
6435
                                                                If Tconnector.ItemStatus = "Active" Then
6436
                                                                    If Tconnector.ModelItemObject.ItemTypeName = "PipeRun" Then
6437
                                                                        oConnector_1 = Tconnector
6438
                                                                    End If
6439
                                                                End If
6440
                                                            Next
6441
                                                        End If
6442
                                                        If oSymbol.Connect1Connectors.Count >= 1 Then
6443
                                                            For Each Tconnector In oSymbol.Connect1Connectors
6444
                                                                If Tconnector.ItemStatus = "Active" Then
6445
                                                                    If Tconnector.ModelItemObject.ItemTypeName = "PipeRun" Then
6446
                                                                        oConnector_2 = Tconnector
6447
                                                                    End If
6448
                                                                End If
6449
                                                            Next
6450
                                                        End If
6451
                                                    End If
6452
                                                    Dim oPipeRun1 As LMPipeRun = oDatasource.GetPipeRun(oConnector_1.ModelItemID)
6453
                                                    Dim oPipeRun2 As LMPipeRun = oDatasource.GetPipeRun(oConnector_2.ModelItemID)
6454
                                                    If dAngle = 3.14 Then
6455
                                                        oPipeRun1.Attributes("NominalDiameter").Value = sSplitSize(1)
6456
                                                        oPipeRun2.Attributes("NominalDiameter").Value = sSplitSize(0)
6457
                                                    Else
6458
                                                        oPipeRun1.Attributes("NominalDiameter").Value = sSplitSize(0)
6459
                                                        oPipeRun2.Attributes("NominalDiameter").Value = sSplitSize(1)
6460
                                                    End If
6461

    
6462

    
6463
                                                End If
6464

    
6465
                                            Else
6466
                                                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6467
                                                oSymbol.Attributes(sSPPIDAttribute).Value = sPIDValue
6468
                                            End If
6469
                                        Else
6470
                                            Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6471
                                            oSymbol.Attributes(sSPPIDAttribute).Value = sPIDValue
6472
                                        End If
6473

    
6474
                                    Catch ex As Exception
6475
                                    End Try
6476
                                Next
6477
                                oSymbol.Commit()
6478
                            End If
6479
                        Catch ex As Exception
6480
                        End Try
6481
                    End If
6482
                End If
6483

    
6484

    
6485

    
6486
            End If
6487

    
6488

    
6489

    
6490
            'Dim sSymbolUid As String = oSymbolRow(_XML_SYMBOL_UID).ToString()
6491
            'Dim sConnTypeNo As String = ""
6492
            '' Line과 연결되어있는 Symbol인지 확인
6493
            'Dim oLine_Dt As DataTable = GetPipeFromConnection(CDrawing, sSymbolUid, sConnTypeNo)
6494
            ''Symbol과 연결되어 있는 Symbol인지 확인
6495
            'Dim oSymbol_Dt As DataTable = GetSymbolFromConnection(CDrawing, sSymbolUid, sConnTypeNo)
6496
            'Dim oSymbol As LMSymbol = Nothing
6497
            'Dim sSPID As String = oSymbolRow(_XML_SYMBOL_SPID).ToString()
6498
            'Dim sSystemPath As String = oSymbolRow(_XML_SYMBOL_SYSTEMPATH).ToString()
6499
            'Dim oDatasource As Object = _Placement.PIDDataSource
6500
            'Dim sSymbolCompType As String = oSymbolRow(_XML_SYMBOL_TYPE).ToString()
6501

    
6502
            'Dim dAngle As Double = 0.0
6503
            'If IsNumeric(oSymbolRow(_XML_SYMBOL_ANGLE).ToString()) Then
6504
            '    dAngle = Double.Parse(oSymbolRow(_XML_SYMBOL_ANGLE).ToString())
6505
            'End If
6506

    
6507
            'Dim dLocationX As Double = 0.0
6508
            'Dim dLocationY As Double = 0.0
6509
            'Dim dX As Double = 0.0
6510
            'Dim dY As Double = 0.0
6511
            'Dim sOriginalPoint As String = oSymbolRow(_XML_SYMBOL_ORIGINALPOINT).ToString()
6512
            'ConvertPointBystring(sOriginalPoint, dLocationX, dLocationY)
6513
            'dX = dLocationX
6514
            'dY = dLocationY
6515
            'ConvertPointByImage(dX, dY, _IMG_X, _IMG_Y)
6516
            'Dim bCheckModeling As Boolean = False
6517

    
6518
            'If oLine_Dt.Rows.Count > 0 Then
6519

    
6520
            '    If sSPID <> "" Then
6521
            '        Dim dX1 As Double = 0
6522
            '        Dim dX2 As Double = 0
6523
            '        Dim dY1 As Double = 0
6524
            '        Dim dY2 As Double = 0
6525
            '        Dim oLMSymbol As LMSymbol = oDatasource.GetSymbol(sSPID)
6526
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 1, dX1, dY1)
6527
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 2, dX2, dY2)
6528

    
6529
            '        Dim dCalcPoint As Double = -1
6530
            '        Dim dModeling_X As Double = 0
6531
            '        Dim dModeling_Y As Double = 0
6532
            '        If dX1 <> 0 And dY1 <> 0 Then
6533
            '            dCalcPoint = Math.Abs(dX1 - dX) + Math.Abs(dY1 - dY)
6534
            '            dModeling_X = dX1
6535
            '            dModeling_Y = dY1
6536
            '        End If
6537
            '        If dX2 <> 0 And dY2 <> 0 Then
6538

    
6539
            '            If (Math.Abs(dX2 - dX) + Math.Abs(dY2 - dY) > dCalcPoint) Then
6540
            '                dCalcPoint = Math.Abs(dX2 - dX) + Math.Abs(dY2 - dY)
6541
            '                dModeling_X = dX2
6542
            '                dModeling_Y = dY2
6543
            '            End If
6544
            '        End If
6545

    
6546

    
6547

    
6548
            '        If dModeling_X <> 0 And dModeling_Y <> 0 Then
6549
            '            oSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dModeling_X, dModeling_Y,, dAngle, ExistingItem:=oLMSymbol.AsLMAItem,
6550
            '                TargetItem:=oLMSymbol.AsLMRepresentation)
6551
            '            bCheckModeling = True
6552
            '        End If
6553

    
6554

    
6555
            '    End If
6556
            'End If
6557
            'If oSymbol_Dt.Rows.Count > 0 Then
6558
            '    If sSPID <> "" Then
6559
            '        Dim dX1 As Double = 0
6560
            '        Dim dX2 As Double = 0
6561
            '        Dim dX3 As Double = 0
6562
            '        Dim dX4 As Double = 0
6563
            '        Dim dY1 As Double = 0
6564
            '        Dim dY2 As Double = 0
6565
            '        Dim dY3 As Double = 0
6566
            '        Dim dY4 As Double = 0
6567
            '        Dim oLMSymbol As LMSymbol = oDatasource.GetSymbol(sSPID)
6568
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 1, dX1, dY1)
6569
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 2, dX2, dY2)
6570
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 3, dX3, dY3)
6571
            '        _Placement.PIDConnectPointLocation(oLMSymbol, 4, dX4, dY4)
6572

    
6573
            '        Dim dCalcPoint As Double = -1
6574
            '        Dim dModeling_X As Double = 0
6575
            '        Dim dModeling_Y As Double = 0
6576
            '        If dX1 <> 0 And dY1 <> 0 Then
6577
            '            dCalcPoint = Math.Abs(dX1 - dX) + Math.Abs(dY1 - dY)
6578
            '            dModeling_X = dX1
6579
            '            dModeling_Y = dY1
6580
            '        End If
6581
            '        If dX2 <> 0 And dY2 <> 0 Then
6582

    
6583
            '            If (Math.Abs(dX2 - dX) + Math.Abs(dY2 - dY) > dCalcPoint) Then
6584
            '                dCalcPoint = Math.Abs(dX2 - dX) + Math.Abs(dY2 - dY)
6585
            '                dModeling_X = dX2
6586
            '                dModeling_Y = dY2
6587
            '            End If
6588
            '        End If
6589
            '        If dX3 <> 0 And dY3 <> 0 Then
6590
            '            If (Math.Abs(dX3 - dX) + Math.Abs(dY3 - dY) > dCalcPoint) Then
6591
            '                dCalcPoint = Math.Abs(dX3 - dX) + Math.Abs(dY3 - dY)
6592
            '                dModeling_X = dX3
6593
            '                dModeling_Y = dY3
6594
            '            End If
6595
            '        End If
6596
            '        If dX4 <> 0 And dY4 <> 0 Then
6597
            '            If (Math.Abs(dX4 - dX) + Math.Abs(dY4 - dY) > dCalcPoint) Then
6598
            '                dCalcPoint = Math.Abs(dX4 - dX) + Math.Abs(dY4 - dY)
6599
            '                dModeling_X = dX4
6600
            '                dModeling_Y = dY4
6601
            '            End If
6602
            '        End If
6603
            '        If dModeling_X <> 0 And dModeling_Y <> 0 Then
6604
            '            oSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dModeling_X, dModeling_Y,, dAngle, ExistingItem:=oLMSymbol.AsLMAItem,
6605
            '                TargetItem:=oLMSymbol.AsLMRepresentation)
6606
            '            bCheckModeling = True
6607
            '        End If
6608

    
6609

    
6610
            '    End If
6611

    
6612
            'End If
6613

    
6614
            'If (oLine_Dt.Rows.Count = 0 And oSymbol_Dt.Rows.Count = 0) Or bCheckModeling = False Then
6615
            '    oSymbol = _Placement.PIDPlaceSymbol(sSystemPath, dX, dY, , dAngle)
6616
            '    SetListBoxItems(ListBox_Result, "Place Fittings..(" & dLocationX & "," & dLocationY & ")..." & _iFittingcnt & " count ")
6617
            '    _iFittingcnt = _iFittingcnt + 1
6618
            'End If
6619
            'Dim oAttributeRow() As DataRow
6620
            'oAttributeRow = oAttribute_Dt.Select(_XML_ATTRIBUTE_UID & " = '" + sSymbolUid + "'")
6621
            'If oAttribute_Dt.Rows.Count > 0 Then
6622

    
6623
            '    If sSymbolCompType.ToUpper() = _SYMBOL_INSTUMENT.ToUpper() Then
6624
            '        Dim oInstrument As LMInstrument
6625
            '        oInstrument = oDatasource.GetInstrument(oSymbol.ModelItemID)
6626
            '        Try
6627
            '            If oAttributeRow.Length > 0 Then
6628
            '                For Each oAttribute In oAttributeRow
6629
            '                    Try
6630
            '                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6631
            '                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6632
            '                        Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6633
            '                        oInstrument.Attributes(sSPPIDAttribute).Value = sPIDValue
6634
            '                    Catch ex As Exception
6635
            '                    End Try
6636
            '                Next
6637
            '                oInstrument.Commit()
6638
            '            End If
6639
            '        Catch ex As Exception
6640
            '        End Try
6641
            '    Else
6642
            '        Try
6643
            '            If oAttributeRow.Length > 0 And oSymbol IsNot Nothing Then
6644
            '                For Each oAttribute In oAttributeRow
6645
            '                    Try
6646
            '                        Dim sPIDAttribute As String = oAttribute(_XML_ATTRIBUTE_NAME).ToString()
6647
            '                        Dim sPIDValue As String = oAttribute(_XML_ATTRIBUTE_VALUE).ToString()
6648

    
6649
            '                        If sPIDAttribute = "SIZE" Then
6650

    
6651
            '                            'Nominal diamter1,2속성이름뭔지 찾아봐야됨 (2018-07-20)
6652
            '                            If sPIDValue.Contains("x") Then
6653
            '                                Dim sSplitSize() As String = sPIDValue.Split("x")
6654
            '                                If sSplitSize.Count > 1 Then
6655
            '                                    'Connection Point와 연결되어 있는 라인을 가져와서 라인프로퍼티를 변경
6656
            '                                    Dim oConnector_1 As LMConnector = Nothing
6657
            '                                    Dim oConnector_2 As LMConnector = Nothing
6658
            '                                    If oSymbol IsNot Nothing Then
6659
            '                                        If oSymbol.Connect1Connectors.Count >= 1 Then
6660
            '                                            For Each Tconnector In oSymbol.Connect1Connectors
6661
            '                                                If Tconnector.ItemStatus = "Active" Then
6662
            '                                                    If Tconnector.ModelItemObject.ItemTypeName = "PipeRun" Then
6663
            '                                                        oConnector_1 = Tconnector
6664
            '                                                    End If
6665
            '                                                End If
6666
            '                                            Next
6667
            '                                        End If
6668
            '                                        If oSymbol.Connect1Connectors.Count >= 1 Then
6669
            '                                            For Each Tconnector In oSymbol.Connect1Connectors
6670
            '                                                If Tconnector.ItemStatus = "Active" Then
6671
            '                                                    If Tconnector.ModelItemObject.ItemTypeName = "PipeRun" Then
6672
            '                                                        oConnector_2 = Tconnector
6673
            '                                                    End If
6674
            '                                                End If
6675
            '                                            Next
6676
            '                                        End If
6677
            '                                    End If
6678
            '                                    Dim oPipeRun1 As LMPipeRun = oDatasource.GetPipeRun(oConnector_1.ModelItemID)
6679
            '                                    Dim oPipeRun2 As LMPipeRun = oDatasource.GetPipeRun(oConnector_2.ModelItemID)
6680
            '                                    If dAngle = 3.14 Then
6681
            '                                        oPipeRun1.Attributes("NominalDiameter").Value = sSplitSize(1)
6682
            '                                        oPipeRun2.Attributes("NominalDiameter").Value = sSplitSize(0)
6683
            '                                    Else
6684
            '                                        oPipeRun1.Attributes("NominalDiameter").Value = sSplitSize(0)
6685
            '                                        oPipeRun2.Attributes("NominalDiameter").Value = sSplitSize(1)
6686
            '                                    End If
6687

    
6688

    
6689
            '                                End If
6690

    
6691
            '                            Else
6692
            '                                Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6693
            '                                oSymbol.Attributes(sSPPIDAttribute).Value = sPIDValue
6694
            '                            End If
6695
            '                        Else
6696
            '                            Dim sSPPIDAttribute As String = GetAttributeMapping(sPIDAttribute, _DB_COLUMN_ATTRIBUTE_SPPID_ATTRIBUTE)
6697
            '                            oSymbol.Attributes(sSPPIDAttribute).Value = sPIDValue
6698
            '                        End If
6699

    
6700
            '                    Catch ex As Exception
6701
            '                    End Try
6702
            '                Next
6703
            '                oSymbol.Commit()
6704
            '            End If
6705
            '        Catch ex As Exception
6706
            '        End Try
6707
            '    End If
6708
            'End If
6709
        Catch ex As Exception
6710
        End Try
6711
    End Sub
6712

    
6713

    
6714

    
6715
    Private Function AutoModeling() As Boolean
6716
        Try
6717
            '_AllLine_DT = Line_Dt()
6718
            '_AllSymbol_DT = Symbol_Dt()
6719
            _ModelingLine_Dt = Line_Dt()
6720
            _ModelingSymbol_Dt = Symbol_Dt()
6721
            _CompleteConvert = False
6722
            Label_Progress.Text = "0%"
6723
            SetListBoxItems(ListBox_Result, " Auto converting 시작....")
6724
            ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, " Auto converting 시작....")
6725
            Dim oDwg_Dt As DataTable = LoadAllDrawing()
6726
            _Log_File = "AutoConverting_" + DateTime.Now.ToString("yyyyMMdd") + "_" + DateTime.Now.ToString("HHmmss")
6727
            _allItem = GetAllCheckNodeCount()
6728
            _Itemcnt = 0
6729
            '1.Equipment
6730
            '2.Piping OPC
6731
            '3.OPC 시작되는 Line
6732

    
6733
            'InitAutoRouting()
6734
            'EquipmentModeling(oDwg_Dt)
6735
            'PipingModeling()
6736

    
6737
            '' 1. Primary Line만 먼저 그림
6738
            PrimaryPipeModeling()
6739
            '' 2. Draw Symbols Prinmary에 붙는 Symbol만 / Reducer 제외
6740

    
6741

    
6742

    
6743

    
6744

    
6745

    
6746

    
6747
            '   PipeLine_Fitting_Modeling()
6748

    
6749
            SetProgressbar(ProgressBar_Status, 100)
6750
            Label_Progress.Text = "100%"
6751
            SetListBoxItems(ListBox_Result, " Auto converting 완료")
6752
            ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, " Auto converting 완료")
6753
            _CompleteConvert = True
6754
            Return True
6755
        Catch ex As Exception
6756
            Return False
6757
        End Try
6758
    End Function
6759

    
6760

    
6761

    
6762
    Private Sub ThreadConvert()
6763
        If _DrawingsList IsNot Nothing Then
6764
            If _DrawingsList.Count > 0 Then
6765
                'TestBranchLine()
6766
                AutoModeling()
6767
            End If
6768
        End If
6769
    End Sub
6770

    
6771
    Private Sub ThreadOPCRemove()
6772
        While _CompleteConvert = False
6773
            Dim oFindOPC As New FindOpc
6774
            oFindOPC.RemoveOPCDlg()
6775
        End While
6776

    
6777
    End Sub
6778

    
6779

    
6780
    Private Function OpenDrawing(ByVal oDt As DataTable, ByVal sDwgName As String) As String
6781
        Dim oRows As DataRow() = oDt.Select("[Name] = '" & sDwgName & "'")
6782
        Dim oPath As String = ""
6783
        If oRows.Length > 0 Then
6784
            oPath = oRows(0).Item("Path").ToString()
6785
        End If
6786
        Return oPath
6787
    End Function
6788

    
6789
    Private Sub LoadXmlToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles LoadXmlToolStripMenuItem.Click
6790

    
6791
        If (FolderBrowserDialog1.ShowDialog() = DialogResult.OK) Then
6792
            LoadDB()
6793
            LoadXmlItem(FolderBrowserDialog1.SelectedPath)
6794
        End If
6795
    End Sub
6796
    Private Sub LoadXmlItem(ByVal sFolderPath As String)
6797
        _DrawingsList = New List(Of Drawing)
6798
        Dim sfileEntries As String() = Directory.GetFiles(sFolderPath)
6799
        If Tree_Result.Nodes.Count > 0 Then
6800
            Tree_Result.Nodes(0).Nodes.Clear()
6801
            For Each sfileName In sfileEntries
6802
                Dim sExtension As String = Path.GetExtension(sfileName)
6803
                If sExtension = ".xml" Then
6804
                    Dim sDwgName As String = Path.GetFileNameWithoutExtension(sfileName)
6805
                    Dim sDwgPath As String = sfileName
6806
                    Dim oNode As TreeNode = Tree_Result.Nodes(0).Nodes.Add(sDwgPath, sDwgName, 15)
6807
                    Dim oDwg As Drawing = AddSymbolItem(sDwgPath, oNode)
6808

    
6809
                    _DrawingsList.Add(oDwg)
6810
                End If
6811
            Next
6812
            Tree_Result.Nodes(0).Expand()
6813
        End If
6814
    End Sub
6815

    
6816
    Private Sub GenerateRelation(ByRef oDwg_Ds As Drawing)
6817
        Dim oLineLists As List(Of Line_no) = oDwg_Ds.Line_nos
6818
        Dim oEqpLists As List(Of Eqp_no) = oDwg_Ds.Eqp_nos
6819
        Dim oTrimLineLists As List(Of Line_no) = oDwg_Ds.TrimLine_nos
6820
        Dim oRelation As New GenerateRelation()
6821
        For Each oLinelist In oLineLists
6822
            oRelation.CalcLineConnectionItem_Equal(oLinelist.Dt_Line, oLineLists)
6823
            oRelation.CalcLineConnectionItem_NonEqual(oLinelist.Dt_Line, oLineLists)
6824
            oRelation.CalcSymbolConnectionItem_Equal(oLinelist.Dt_Symbol, oLineLists)
6825
            oRelation.CalcSymbolConnectionItem_NonEqual(oLinelist.Dt_Symbol, oLineLists)
6826
        Next
6827
    End Sub
6828

    
6829
    Private Sub SetSymbol_LineNumberByUID(ByVal symbols As List(Of Symbol), ByVal lineNumber As LineNumber, ByVal uid As String)
6830
        For Each symbol As Symbol In symbols
6831
            If symbol.UID = uid Then
6832
                symbol.LINENUMBER = lineNumber
6833
                Exit For
6834
            End If
6835
        Next
6836
    End Sub
6837

    
6838
    Private Sub SetLine_LineNumberByUID(ByVal lines As List(Of Line), ByVal lineNumber As LineNumber, ByVal uid As String)
6839
        For Each line As Line In lines
6840
            If line.UID = uid Then
6841
                line.LINENUMBER = lineNumber
6842
                Exit For
6843
            End If
6844
        Next
6845
    End Sub
6846

    
6847
    ''' <summary>
6848
    '''  XML Tree 구조 생성 
6849
    ''' </summary>
6850
    ''' <param name="sDwgPath"></param>
6851
    Private Function AddSymbolItem(ByVal sDwgPath As String, ByVal oParentNode As TreeNode) As Drawing
6852
        Dim oDwg_Ds As Drawing = LoadSymbolInXml(sDwgPath)
6853

    
6854
        If oDwg_Ds IsNot Nothing Then
6855

    
6856
            Dim oLineNos As List(Of LineNumber) = oDwg_Ds.LINENUMBERS
6857

    
6858
            Dim oTrimLines As List(Of LineNumber) = oDwg_Ds.TRIMLINES
6859

    
6860
            Dim oSymbols As List(Of Symbol) = oDwg_Ds.SYMBOLS
6861

    
6862
            Dim oLines As List(Of Line) = oDwg_Ds.LINES
6863

    
6864
            '' TreeView 구성 및 하위 아이템 상위 구성
6865
            ' LIne Number
6866
            For Each lineNo As LineNumber In oLineNos
6867
                Dim node As TreeNode = New TreeNode(lineNo.UID)
6868
                node.Name = lineNo.UID
6869
                node.Tag = lineNo
6870

    
6871
                oParentNode.Nodes.Add(node)
6872

    
6873
                For Each uid In lineNo.SYMBOLRUNITEMS
6874
                    SetSymbol_LineNumberByUID(oSymbols, lineNo, uid)
6875
                Next
6876

    
6877
                For Each uid In lineNo.LINERUNITEMS
6878
                    SetLine_LineNumberByUID(oLines, lineNo, uid)
6879
                Next
6880
            Next
6881

    
6882
            ' Trim Line
6883
            For index = 0 To oTrimLines.Count - 1
6884
                Dim trimLine As LineNumber = oTrimLines(index)
6885

    
6886
                Dim node As TreeNode = New TreeNode("TrimLine" + index.ToString)
6887
                node.Name = trimLine.UID
6888
                node.Tag = trimLine
6889

    
6890
                oParentNode.Nodes.Add(node)
6891

    
6892
                For Each uid In trimLine.SYMBOLRUNITEMS
6893
                    SetSymbol_LineNumberByUID(oSymbols, trimLine, uid)
6894
                Next
6895

    
6896
                For Each uid In trimLine.LINERUNITEMS
6897
                    SetLine_LineNumberByUID(oLines, trimLine, uid)
6898
                Next
6899
            Next
6900
            ' symbol
6901
            For Each symbol As Symbol In oSymbols
6902

    
6903
                Dim node As TreeNode = New TreeNode(symbol.TYPE)
6904
                node.Name = symbol.UID
6905
                node.Tag = symbol
6906

    
6907
                If symbol.LINENUMBER IsNot Nothing Then
6908
                    Dim nodeIndex As Integer = oParentNode.Nodes.IndexOfKey(symbol.LINENUMBER.UID)
6909
                    oParentNode.Nodes.Item(nodeIndex).Nodes.Add(node)
6910
                Else
6911
                    oParentNode.Nodes.Add(node)
6912
                End If
6913
            Next
6914
            ' line
6915
            For Each line As Line In oLines
6916

    
6917
                Dim node As TreeNode = New TreeNode(line.TYPE)
6918
                node.Name = line.UID
6919
                node.Tag = line
6920

    
6921
                If line.LINENUMBER IsNot Nothing Then
6922
                    Dim nodeIndex As Integer = oParentNode.Nodes.IndexOfKey(line.LINENUMBER.UID)
6923
                    oParentNode.Nodes.Item(nodeIndex).Nodes.Add(node)
6924
                Else
6925
                    oParentNode.Nodes.Add(node)
6926
                End If
6927
            Next
6928

    
6929
        End If
6930

    
6931
        Return oDwg_Ds
6932
    End Function
6933
    Private Sub Tree_Result_AfterCheck(sender As Object, e As TreeViewEventArgs) Handles Tree_Result.AfterCheck
6934
        If e.Node.Checked = True Then
6935
            For Each oNode As TreeNode In e.Node.Nodes
6936
                oNode.Checked = True
6937
            Next
6938
        Else
6939
            For Each oNode As TreeNode In e.Node.Nodes
6940
                oNode.Checked = False
6941
            Next
6942
        End If
6943
    End Sub
6944

    
6945
    Private Sub Btn_Setting_Click(sender As Object, e As EventArgs) Handles Btn_Setting.Click
6946
        Dim oSettings As Settings = New Settings()
6947
        oSettings.ShowDialog()
6948
    End Sub
6949

    
6950

    
6951
    Private Sub TestBranchLine()
6952
        Dim objPlacement As Placement
6953
        objPlacement = New Placement
6954
        Dim PipeRunLocation As String
6955
        Dim objItem As LMAItem
6956
        Dim objConnector As LMConnector
6957
        Dim objInputs As PlaceRunInputs
6958
        Dim objSymbol As LMSymbol
6959
        Dim ValveLocation As String
6960
        PipeRunLocation = "\Piping\Routing\Process Lines\Primary Piping.sym"
6961
        objInputs = New PlaceRunInputs
6962
        objInputs.AddPoint(0.1, 0.1)
6963
        objInputs.AddPoint(0.2, 0.1)
6964
        objItem = objPlacement.PIDCreateItem(PipeRunLocation)
6965
        objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
6966
        ValveLocation = "\Piping\Valves\2 Way Common\Ball Valve.sym"
6967
        objSymbol = objPlacement.PIDPlaceSymbol(ValveLocation, 0.15, 0.3, , 1.57)
6968
        objInputs = New PlaceRunInputs
6969
        objInputs.AddConnectorTarget(objConnector, 0.15, 0.1)
6970
        '   objInputs.AddConnectorTarget(objConnector, 0.12, 0.1)
6971
        objInputs.AddPoint(0.15, 0.15)
6972
        objInputs.AddPoint(0.12, 0.15)
6973
        objInputs.AddPoint(0.12, 0.2)
6974
        objInputs.AddPoint(0.15, 0.2)
6975
        objInputs.AddSymbolTarget(objSymbol, 0.15, 0.3)
6976
        objItem = objPlacement.PIDCreateItem(PipeRunLocation)
6977
        objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
6978

    
6979
        objInputs = New PlaceRunInputs
6980
        objInputs.AddConnectorTarget(objConnector, 0.17, 0.1)
6981
        objInputs.AddPoint(0.17, 0.15)
6982
        objItem = objPlacement.PIDCreateItem(PipeRunLocation)
6983
        objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
6984

    
6985
        objInputs = New PlaceRunInputs
6986
        objInputs.AddConnectorTarget(objConnector, 0.19, 0.1)
6987
        objInputs.AddPoint(0.19, 0.15)
6988
        objItem = objPlacement.PIDCreateItem(PipeRunLocation)
6989
        objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
6990

    
6991
        objInputs = New PlaceRunInputs
6992
        objInputs.AddConnectorTarget(objConnector, 0.12, 0.1)
6993
        objInputs.AddPoint(0.12, 0.15)
6994
        objItem = objPlacement.PIDCreateItem(PipeRunLocation)
6995
        objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
6996
    End Sub
6997

    
6998
    Private Sub Btn_TestNozzle_Click(sender As Object, e As EventArgs) Handles Btn_TestNozzle.Click
6999

    
7000
        Dim sVessel_ID As String = "841D5E640AE5421B9A017DDC2E87FF11"
7001
        Dim objVessel As LMVessel
7002
        objVessel = _Placement.PIDDataSource.GetVessel(sVessel_ID)
7003
        Dim oVesselLocation As LMLocations = objVessel.Locations
7004
        Dim symVessel As LMSymbol = _Placement.PIDDataSource.GetSymbol(objVessel.Representations.Nth(1).Id)
7005
        Dim XCoordinate As String = symVessel.Attributes("XCoordinate").Value
7006
        Dim YCoordinate As String = symVessel.Attributes("YCoordinate").Value
7007
        symVessel.Attributes("XCoordinate").Value = XCoordinate + 0.01
7008
        symVessel.Attributes("YCoordinate").Value = YCoordinate + 0.01
7009
        symVessel.Commit()
7010
        Dim sValve_ID As String = "DB7B0CA8A2664A6BA7A9615764BA62B0"
7011
        Dim objValve As LMSymbol
7012
        Dim objValves As LMPipingComp = _Placement.PIDDataSource.GetPipingComp(sValve_ID)
7013
        objValve = _Placement.PIDDataSource.GetSymbol(objValves.Representations.Nth(1).Id)
7014
        objValve.Commit()
7015
        Dim dVesselX As Double = XCoordinate
7016
        Dim dVesselY As Double = YCoordinate
7017
        Dim X1 As Double, Y1 As Double, X2 As Double, Y2 As Double
7018

    
7019
        _Placement.PIDConnectPointLocation(objValve, 1, X1, Y1)
7020

    
7021
        _Placement.PIDConnectPointLocation(objValve, 2, X2, Y2)
7022

    
7023
        Dim nozzlename As String = "\Equipment Components\Nozzles\Flanged Nozzle.sym"
7024
        Dim dCalc_x As Double = 0
7025
        Dim dCalc_y As Double = 0
7026

    
7027
        If dVesselX - X2 > 0 Then
7028
            dCalc_x = dVesselX - (dVesselX - X2)
7029
        Else
7030
            dCalc_x = dVesselX + (X2 - dVesselX)
7031
        End If
7032
        If dVesselY - Y2 > 0 Then
7033
            dCalc_y = dVesselY - (dVesselY - Y2)
7034
        Else
7035
            dCalc_y = dVesselY + (Y2 - dVesselY)
7036
        End If
7037

    
7038
        Dim objNozzle As LMSymbol = _Placement.PIDPlaceSymbol(nozzlename, dCalc_x, dCalc_y,
7039
            TargetItem:=symVessel.AsLMRepresentation)
7040

    
7041
        Dim blnSuccess As Boolean = _Placement.PIDConnectPointLocation(objNozzle, 1, X1, Y1)
7042
        blnSuccess = _Placement.PIDConnectPointLocation(objNozzle, 2, X1, Y1)
7043

    
7044
        objValve = _Placement.PIDPlaceSymbol(objValve.FileName, X1, Y1, ExistingItem:=objValve.AsLMAItem,
7045
          TargetItem:=objNozzle.AsLMRepresentation)
7046

    
7047

    
7048

    
7049
    End Sub
7050

    
7051
    Private Sub Btn_SymbolLibrary_Click(sender As Object, e As EventArgs) Handles Btn_SymbolLibrary.Click
7052
        Dim oMapping As New Mapping(_PIDSymbol_DB)
7053
        oMapping.Show()
7054
    End Sub
7055

    
7056
    Private Sub Btn_Stop_Click(sender As Object, e As EventArgs) Handles Btn_Stop.Click
7057
        Try
7058
            SetListBoxItems(ListBox_Result, " Auto converting 중지....")
7059
            ComUtil.MessageLog.CEventLog.Log_Write_Update(_Log_Path, _Log_File, " Auto converting 중지....")
7060
            _Main_trd.Abort()
7061
            _Opc_trd.Abort()
7062
        Catch ex As Exception
7063

    
7064
        End Try
7065
    End Sub
7066

    
7067
    Private Sub AutoCheckTreeNode(ByVal iType As Integer, ByVal bCheck As Boolean)
7068

    
7069
        For Each oDrwing As TreeNode In Tree_Result.Nodes
7070
            For Each oDwgNode As TreeNode In oDrwing.Nodes
7071
                Dim sDwgName As String = Path.GetFileNameWithoutExtension(oDwgNode.Text)
7072
                Dim CDrawing As Drawing = GetDrawing(sDwgName)
7073
                If CDrawing IsNot Nothing Then
7074
                    Dim iAllLineNoCount As Integer = Tree_Result.Nodes.Count ' GetCheckNodeCount(oLinenoNode)
7075
                    Dim iPipingOPC_count As Integer = 0 ' GetCheckNodeCount(oLinenoNode)
7076
                    For Each oNode As TreeNode In oDwgNode.Nodes
7077
                        Dim iItemcnt As Integer = 0
7078
                        Dim sNodeUid As String = oNode.Name
7079
                        Dim oPipeRun_Dt As DataTable = PipeRun_Dt()
7080

    
7081
                        If iType = 0 Then 'Symbol
7082
                            Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
7083
                            If CLineNo IsNot Nothing Then
7084
                                Dim oSymbol_Dt As DataTable = CLineNo.Dt_Symbol
7085
                                For Each oSymbolRow In oSymbol_Dt.Rows
7086
                                    Dim sSymbolUid As String = oSymbolRow(_XML_SYMBOL_UID).ToString()
7087
                                    For Each oSymbolNode As TreeNode In oNode.Nodes
7088
                                        Dim sSymbolNodeUid As String = oSymbolNode.Name
7089
                                        If sSymbolNodeUid = sSymbolUid Then
7090
                                            oSymbolNode.Checked = bCheck
7091
                                            Exit For
7092
                                        End If
7093
                                    Next
7094
                                Next
7095
                            End If
7096
                            Dim TrimLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
7097
                            If TrimLineNo IsNot Nothing Then
7098
                                Dim oSymbol_Dt As DataTable = TrimLineNo.Dt_Symbol
7099
                                For Each oSymbolRow In oSymbol_Dt.Rows
7100
                                    Dim sSymbolUid As String = oSymbolRow(_XML_SYMBOL_UID).ToString()
7101
                                    For Each oSymbolNode As TreeNode In oNode.Nodes
7102
                                        Dim sSymbolNodeUid As String = oSymbolNode.Name
7103
                                        If sSymbolNodeUid = sSymbolUid Then
7104
                                            oSymbolNode.Checked = bCheck
7105
                                            Exit For
7106
                                        End If
7107
                                    Next
7108
                                Next
7109
                            End If
7110
                        End If
7111
                        If iType = 1 Then 'Line
7112
                            Dim CLineNo As Line_no = GetLineNo(CDrawing, sNodeUid)
7113
                            If CLineNo IsNot Nothing Then
7114
                                Dim oLine_Dt As DataTable = CLineNo.Dt_Line
7115
                                For Each oLineRow In oLine_Dt.Rows
7116
                                    Dim sLineUid As String = oLineRow(_XML_LINE_UID).ToString()
7117
                                    For Each oLineNode As TreeNode In oNode.Nodes
7118
                                        Dim sLineNodeUid As String = oLineNode.Name
7119
                                        If sLineNodeUid = sLineUid Then
7120
                                            oLineNode.Checked = bCheck
7121
                                            Exit For
7122
                                        End If
7123
                                    Next
7124
                                Next
7125
                            End If
7126
                            Dim TrimLineNo As Line_no = GetTrimLineNo(CDrawing, sNodeUid)
7127
                            If TrimLineNo IsNot Nothing Then
7128
                                Dim oLine_Dt As DataTable = TrimLineNo.Dt_Line
7129
                                For Each oLineRow In oLine_Dt.Rows
7130
                                    Dim sLineUid As String = oLineRow(_XML_SYMBOL_UID).ToString()
7131
                                    For Each oLineNode As TreeNode In oNode.Nodes
7132
                                        Dim sLineNodeUid As String = oLineNode.Name
7133
                                        If sLineNodeUid = sLineUid Then
7134
                                            oLineNode.Checked = bCheck
7135
                                            Exit For
7136
                                        End If
7137
                                    Next
7138
                                Next
7139
                            End If
7140
                        End If
7141
                        If iType = 2 Then 'Equipment
7142
                            Dim CEqpNo As Eqp_no = GetEqpNo(CDrawing, sNodeUid)
7143
                            If CEqpNo IsNot Nothing Then
7144
                                Dim oEqp_Dt As DataTable = CEqpNo.Dt_Equipment
7145
                                For Each oEqpRow In oEqp_Dt.Rows
7146
                                    Dim sEqpUid As String = oEqpRow(_XML_LINE_UID).ToString()
7147
                                    For Each oEqpNode As TreeNode In oNode.Nodes
7148
                                        Dim sEqpNodeUid As String = oEqpNode.Name
7149
                                        If sEqpNodeUid = sEqpUid Then
7150
                                            oEqpNode.Checked = bCheck
7151
                                            Exit For
7152
                                        End If
7153
                                    Next
7154
                                Next
7155
                            End If
7156
                        End If
7157
                    Next
7158
                End If
7159
            Next
7160
        Next
7161

    
7162

    
7163
    End Sub
7164

    
7165

    
7166

    
7167
    Private Sub Chk_Symbol_CheckedChanged(sender As Object, e As EventArgs) Handles Chk_Symbol.CheckedChanged
7168
        AutoCheckTreeNode(0, Chk_Symbol.Checked)
7169
    End Sub
7170

    
7171
    Private Sub Chk_Line_CheckedChanged(sender As Object, e As EventArgs) Handles Chk_Line.CheckedChanged
7172
        AutoCheckTreeNode(1, Chk_Line.Checked)
7173
    End Sub
7174

    
7175
    Private Sub Chk_Equipment_CheckedChanged(sender As Object, e As EventArgs) Handles Chk_Equipment.CheckedChanged
7176
        AutoCheckTreeNode(2, Chk_Equipment.Checked)
7177
    End Sub
7178
End Class
7179

    
7180

    
7181
Public Class DrawingInfo
7182
    Public mDrawingName As String
7183
    Public mSpID As String
7184
    Public mPath As String
7185
End Class
7186

    
7187

    
7188

    
7189

    
7190

    
클립보드 이미지 추가 (최대 크기: 500 MB)