프로젝트

일반

사용자정보

통계
| 개정판:

hytos / DTI_PID / SPPIDConverter / Main.vb @ 78b49c9b

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

1 4f359afa Gyusu
Imports System.IO
2
Imports System.Data.SqlClient
3
Imports System.Data.SQLite
4
Imports Plaice
5
Imports Llama
6
Imports PidA
7 962b2464 Gyusu
8 4f359afa Gyusu
Public Class Main
9
10
    Dim _DB As DataTable = New DataTable()
11
    Dim _Placement As New Placement
12
    Dim _DWG_X = 0.84 '0.695 '1 '
13
    Dim _DWG_Y = 0.594 '0.585 '0.8 '
14
15
    Dim _IMG_X = 0
16
    Dim _IMG_Y = 0
17
18 31d47a80 Gyusu
    'Drawing 전역변수
19
    Dim _objPIDADrawing As Object
20
21 4f359afa Gyusu
    Private Sub Main_Load(sender As Object, e As EventArgs) Handles MyBase.Load
22
        Dim sDBPath As String = "C:\Users\kyusu\Desktop\Auto SPPID 변환 프로젝트\PID.db"
23
        LoadDB(sDBPath)
24 962b2464 Gyusu
        SetUpListViewColumns()
25
        LoadTree()
26 31d47a80 Gyusu
        ' TestOpen()
27 962b2464 Gyusu
28
    End Sub
29
    Private Sub LoadTree()
30
31
        Dim i As Integer
32
        Dim j() As String
33
        j = Directory.GetLogicalDrives
34
        For i = 0 To UBound(j)
35
36
            Dim cdrive As System.IO.DriveInfo
37
            cdrive = My.Computer.FileSystem.GetDriveInfo(j(i).ToString)
38
39
            Select Case cdrive.DriveType
40
                Case DriveType.Fixed
41
                    Tree_XMLFiles.Nodes.Add(j(i), j(i).ToString, 3)
42
                Case DriveType.CDRom
43
                    Tree_XMLFiles.Nodes.Add(j(i), j(i).ToString, 11)
44
                Case DriveType.Network
45
                    Tree_XMLFiles.Nodes.Add(j(i), j(i).ToString, 5)
46
                Case DriveType.Removable
47
                    Tree_XMLFiles.Nodes.Add(j(i), j(i).ToString, 12)
48
            End Select
49
50
        Next
51
    End Sub
52
53
    Private Sub SetUpListViewColumns()
54
        ' TODO: Add code to set up listview columns
55
        ListView_File.Columns.Add("  Name ")
56
        '   ListView_File.Columns.Add(" Size  ")
57
        '    ListView_File.Columns.Add(" Extension  ")
58
        ListView_File.Columns.Add(" Date Modified  ")
59
        SetView(View.Details)
60 4f359afa Gyusu
    End Sub
61
62 962b2464 Gyusu
63
    Private Sub SetView(ByVal View As System.Windows.Forms.View)
64
        'Figure out which menu item should be checked
65
        'Dim MenuItemToCheck As ToolStripMenuItem = Nothing
66
        'Select Case View
67
        '    Case View.Details
68
        '        MenuItemToCheck = DetailsToolStripMenuItem
69
        '    Case View.LargeIcon
70
        '        MenuItemToCheck = LargeIconsToolStripMenuItem
71
        '    Case View.List
72
        '        MenuItemToCheck = ListToolStripMenuItem
73
        '    Case View.SmallIcon
74
        '        MenuItemToCheck = SmallIconsToolStripMenuItem
75
        '    Case View.Tile
76
        '        MenuItemToCheck = TileToolStripMenuItem
77
        '    Case Else
78
        '        Debug.Fail("Unexpected View")
79
        '        View = View.Details
80
        '        MenuItemToCheck = DetailsToolStripMenuItem
81
        'End Select
82
83
        ''Check the appropriate menu item and deselect all others under the Views menu
84
        'For Each MenuItem As ToolStripMenuItem In ListViewToolStripButton.DropDownItems
85
        '    If MenuItem Is MenuItemToCheck Then
86
        '        MenuItem.Checked = True
87
        '    Else
88
        '        MenuItem.Checked = False
89
        '    End If
90
        'Next
91
92
        'Finally, set the view requested
93
        ListView_File.View = View.Details
94
    End Sub
95
96
    Private Sub Btn_FolderPath_Click(sender As Object, e As EventArgs)
97 4f359afa Gyusu
        Dim oOpenFolderDlg = New FolderBrowserDialog()
98
        Dim result As DialogResult = oOpenFolderDlg.ShowDialog()
99
        Dim sFolderName As String = ""
100
101
        If (result = DialogResult.OK) Then
102
            sFolderName = oOpenFolderDlg.SelectedPath
103 962b2464 Gyusu
            '    Txt_FolderPath.Text = sFolderName
104 4f359afa Gyusu
            InitXMLTree(sFolderName)
105
        End If
106
107
    End Sub
108
109
    Private Sub InitXMLTree(ByVal sFolderPath As String)
110
        Tree_XMLFiles.Nodes.Clear()
111
        Dim oRootNode As TreeNode = Tree_XMLFiles.Nodes.Add("XML")
112
        '.XML 만 로드
113
        Dim sfileEntries As String() = Directory.GetFiles(sFolderPath, "*.xml")
114
        ' Process the list of files found in the directory.
115
        Dim sfileName As String
116
        For Each sfileName In sfileEntries
117
            oRootNode.Nodes.Add(sfileName)
118
        Next sfileName
119
        oRootNode.ExpandAll()
120
    End Sub
121
122 1229ad76 Gyusu
123
124
125
126 31d47a80 Gyusu
127 1229ad76 Gyusu
128
129
    Private Function CreateDwg(ByVal oDwgName As String) As Boolean
130
        Dim objPIDADrawing As Object = Nothing
131
        Dim objPIDAutoApp As Object = Nothing
132
        Dim datasource As LMADataSource = Nothing
133 4f359afa Gyusu
        Try
134
            Dim DrawingNumber As String
135
            Dim DrawingName As String
136 1229ad76 Gyusu
            Dim sPlantGroupName As String = "Test"
137
            Dim sTemplateName As String = "\\desktop-9vlq0dp\Test02Site\P188943_SPPID_Plant\P&ID Reference Data\Template Files\Gazprom Project.pid"
138
            Dim objDrawing As LMDrawing
139
            Dim objDrawings As LMDrawings
140
            objDrawings = New LMDrawings
141
            datasource = New LMADataSource
142
            Debug.Print(datasource.ProjectNumber)
143
            Debug.Print(datasource.SiteNode)
144
            Debug.Print(datasource.IsSatellite)
145
            Debug.Print(datasource.GetSystemEditingToolbarSetting)
146
            objDrawings.Collect(datasource)
147
            Dim sPath As String = "‪\\desktop-9vlq0dp\Test02Site\P188943_SPPID_Plant\Plant_Hierarchy\8121\8121-1\188943-8121-PR-DW-011001.pid"
148
            objPIDAutoApp = CreateObject("PIDAutomation.Application")
149
            For Each objDrawing In objDrawings
150
                If objDrawing.Attributes("ItemStatus").Index = 1 Then '1 stands for Active
151
                    objPIDADrawing = objPIDAutoApp.Drawings.OpenDrawing(sPath)
152
                    If Not objPIDADrawing Is Nothing Then
153
154
                        objPIDADrawing.CloseDrawing
155
                    End If
156
                End If
157
            Next
158 4f359afa Gyusu
159
            Dim extension As String = Path.GetExtension(oDwgName)
160
            oDwgName = oDwgName.Replace(extension, "")
161 1229ad76 Gyusu
162 4f359afa Gyusu
            objPIDAutoApp = CreateObject("PIDAutomation.Application")
163 1229ad76 Gyusu
164
            'For Each objDrawing In objPIDAutoApp.Drawings
165
            '    objDrawing.CloseDrawing(True)
166
            'Next
167
168
            objPIDAutoApp.Drawings.OpenDrawing(oDwgName + ".pid")
169
170
            objPIDAutoApp.ActiveWindow.Fit()
171
172
173
174
175
176
177
            'objPIDAutoApp.WindowState = 2  'pidWindowStateMaximized
178
179
180
            'Dim oItems As Object 'LMAItems
181
            'Dim objItem As Object 'LMAItem
182
            'Dim objItems As Object 'LMAItems
183
            ''Collec items
184
            'objItems = CreateObject("Llama.LMAItems", "")
185
            'oItems = CreateObject("Llama.LMAItems", "")
186
187
            'For i = 0 To itemList.Count - 1
188
            '    itemData = itemList.Item(i)
189
            '    itemType = itemData.itemType
190
            '    spid = itemData.spid
191
192
            '    oItems = GetLMAItemsForDrawing(itemType, spid, drawingInfo.mSpID)
193
194
            '    If Not oItems Is Nothing Then
195
            '        objItems.AddCollection(oItems)
196
            '    End If
197
            'Next
198
            'Dim objSPPIDApp As Object 'SmartPlantPID.Application
199
            'Dim radApp As Object
200
            'Dim objReturnGraphics As Collection
201
202
            'objSPPIDApp = GetObject(, "SmartPlantPID.Application")
203
            'radApp = objSPPIDApp.RADApplication
204
205
            'If objItems.Count > 0 Then
206
            '    '---------------------------------------------------------
207
            '    'Start dealing with graphic
208
            '    '---------------------------------------------------------
209
            '    'translate LMAItem to Graphic object
210
            '    'if LMAItem is a piperun, connector graphic object will be returned
211
            '    objReturnGraphics = New Collection
212
213 31d47a80 Gyusu
            '    '     IncrementProgressBar objProgressBar, "Translate need To be highlighted LMAItems To graphic Object..."
214 1229ad76 Gyusu
            '    'For Each objItem In objItems
215
            '    '    objReturnGraphics = GetGraphicsFromLMAItem(objItem, radApp.ActiveDocument.ActiveSheet, drawingInfo.mDrawingName)
216
            '    '    For Each objGraphic In objReturnGraphics
217
            '    '        blnGraphic = True
218
            '    '        'add graphic object to Rad2d.ActiveSelectSet
219
            '    '        radApp.ActiveSelectSet.Add(objGraphic)
220
            '    '        'If Err.Number <> 0 Then
221
            '    '        '    If Err.Number = CONST_ErrNumber457 Then
222
            '    '        '        Err.Clear()
223
            '    '        '    Else
224
            '    '        '        GoTo errorHandler
225
            '    '        '    End If
226
            '    '        'End If
227
228
            '    '    Next
229
            '    'Next
230
            '    'If Not blnGraphic Then
231 31d47a80 Gyusu
            '    '    Debug.WriteLine("Items are In drawing stockpile, use EDE to view.")
232 1229ad76 Gyusu
            '    'Else
233 31d47a80 Gyusu
            '    '    Debug.WriteLine("Complete!   " & objItems.Count & " items are highled in drawing:  " & spid)
234 1229ad76 Gyusu
            '    'End If
235
236
            'Else
237
238
239
            'End If
240
            ''    radApp.ActiveWindow.Repaint
241
242
            'objpidauto.ActiveWindow.Fit()
243
244
245
            'sPlantGroupName = "8121-7"
246
            ''PlantGroupName = "8121-1"
247
            ''PlantGroupName = "Unit01"
248
            ''considering accessing T_OptinSetting to read the template files path, which will be more flexible
249
            'DrawingNumber = "Test"
250
            'DrawingName = "Test"
251
            'objPIDADrawing = objPIDAutoApp.Drawings.Add(sPlantGroupName, sTemplateName, DrawingNumber, DrawingName)
252
            'If Not objPIDADrawing Is Nothing Then
253
            '    '이미 오픈
254
            '    objPIDADrawing.CloseDrawing
255
            'End If
256
257
            Return True
258
        Catch ex As Exception
259
            If objPIDADrawing IsNot Nothing Then
260 4f359afa Gyusu
                objPIDADrawing.CloseDrawing
261
            End If
262 1229ad76 Gyusu
            If objPIDAutoApp IsNot Nothing Then
263
                objPIDAutoApp.Quit
264
            End If
265
            datasource = Nothing
266 4f359afa Gyusu
            objPIDAutoApp = Nothing
267
            objPIDADrawing = Nothing
268
            Return False
269
        End Try
270 1229ad76 Gyusu
        If objPIDADrawing IsNot Nothing Then
271
            objPIDADrawing.CloseDrawing
272
        End If
273 4f359afa Gyusu
274
    End Function
275
276 1229ad76 Gyusu
277
    '    Public Function GetGraphicsFromLMAItem(ByVal objItem As Llama.LMAItem, ByVal objSheet As Object, ByVal strDrawingName As String) As Collection
278
    '        On Error GoTo errorHandler
279
    '        Dim strError As String
280
    '        Dim objGraphic As Object
281
    '        Dim strGraphicOID As String
282
    '        Dim strGraphicName As String
283
    '        Dim objRep As Object 'LMRepresentation
284
    '        Dim strName As String
285
286
    '        GetGraphicsFromLMAItem = New Collection
287
    '        'label is special, because label is a representation, different from other items
288
    '        If objItem.ItemType = CONST_LabelPersist Then
289
    '            If Not mDataSource.GetLabelPersist(objItem.Id).AsLMRepresentation Is Nothing Then
290
    '                If mDataSource.GetLabelPersist(objItem.Id).AsLMRepresentation.ItemStatus = CONST_Active And Not mDataSource.GetLabelPersist(objItem.Id).AsLMRepresentation.DrawingObject Is Nothing Then
291
    '                    If mDataSource.GetLabelPersist(objItem.Id).AsLMRepresentation.DrawingObject.Attributes("Name").Value = strDrawingName Then
292
    '                        If mDataSource.GetLabelPersist(objItem.Id).AsLMRepresentation.GraphicOID Is Nothing Then
293
    '                            'RaiseError 2000, "Label GraphicOID is NULL"
294
    '                            'ignore it
295
    '                        Else
296
    '                            strGraphicOID = mDataSource.GetLabelPersist(objItem.Id).AsLMRepresentation.GraphicOID
297
    '                            strGraphicName = "xxx " & strGraphicOID
298
    '                            objGraphic = objSheet.DrawingObjects(strGraphicName)
299
    '                            If Not objGraphic Is Nothing Then
300
    '                                'to ensure not get a graphic is in other drawings
301
    '                                'sometime, if the graphic object is in other drawing,
302
    '                                'set objgraphic=objsheet.drawingobjects(strgraphicname)
303
    '                                'is not returning nothing, but when you try to add it,
304
    '                                'you will get an error
305
    '                                On Error Resume Next
306
    '                                strName = objGraphic.Name
307
    '                                If Err.Number = 0 Then
308
    '                                    GetGraphicsFromLMAItem.Add(objGraphic)
309
    '                                End If
310
    '                                On Error GoTo errorHandler
311
    '                            End If
312
    '                        End If
313
    '                    End If
314
    '                End If
315
    '            End If
316
    '        Else
317
    '            'else, any items other than label
318
    '            'Piperun is special, we want to break down piperun to connector as drawing graphic
319
    '            If mDataSource.GetModelItem(objItem.Id).ItemTypeName = "PipeRun" Then
320
    '                For Each objRep In mDataSource.GetModelItem(objItem.Id).Representations
321
    '                    If objRep.ItemStatus = CONST_Active And Not objRep.DrawingObject Is Nothing Then
322
    '                        If objRep.DrawingObject.Attributes("Name").Value = strDrawingName Then
323
    '                            If objRep.RepresentationType = "Connector" Then
324
    '                                If objRep.GraphicOID Is Nothing Then
325
    '                                    'RaiseError 2000, "Connector GraphicOID is NULL"
326
    '                                Else
327
    '                                    strGraphicOID = objRep.GraphicOID
328
    '                                    strGraphicName = "xxx " & strGraphicOID
329
    '                                    objGraphic = objSheet.DrawingObjects(strGraphicName)
330
    '                                    If Not objGraphic Is Nothing Then
331
    '                                        'to ensure not get a graphic is in other drawings
332
    '                                        On Error Resume Next
333
    '                                        strName = objGraphic.Name
334
    '                                        If Err.Number = 0 Then
335
    '                                            GetGraphicsFromLMAItem.Add(objGraphic)
336
    '                                        End If
337
    '                                        On Error GoTo errorHandler
338
    '                                    End If
339
    '                                End If
340
    '                            End If
341
    '                        End If
342
    '                    End If
343
    '                Next
344
    '            Else
345
    '                If Not mDataSource.GetModelItem(objItem.Id) Is Nothing Then
346
    '                    For Each objRep In mDataSource.GetModelItem(objItem.Id).Representations
347
    '                        'if it is a multiple representation, only check active representation's GraphicOID
348
    '                        If objRep.ItemStatus = CONST_Active And Not objRep.DrawingObject Is Nothing Then
349
    '                            If objRep.DrawingObject.Attributes("Name").Value = strDrawingName Then
350
    '                                If objRep.GraphicOID Is Nothing Then
351
    '                                    'RaiseError 2000, "GraphicOID is NULL"
352
    '                                Else
353
    '                                    strGraphicOID = objRep.GraphicOID
354
    '                                    strGraphicName = "xxx " & strGraphicOID
355
    '                                    objGraphic = objSheet.DrawingObjects(strGraphicName)
356
    '                                    If Not objGraphic Is Nothing Then
357
    '                                        'to ensure not get a graphic is in other drawings
358
    '                                        On Error Resume Next
359
    '                                        strName = objGraphic.Name
360
    '                                        If Err.Number = 0 Then
361
    '                                            GetGraphicsFromLMAItem.Add(objGraphic)
362
    '                                        End If
363
    '                                        On Error GoTo errorHandler
364
    '                                    End If
365
    '                                End If
366
    '                            End If
367
    '                        End If
368
    '                    Next
369
    '                End If
370
    '            End If
371
    '        End If
372
    '        Exit Function
373
374
    'errorHandler:
375
    '        strError = " - error happened when " & strError & " @ Function cLMAItemGraphicTranslate::GetGraphicsFromLMAItem"
376
    '        Debug.WriteLine(strError)
377
    '    End Function
378
379
380
381 4f359afa Gyusu
#Region "Load Pipe"
382
    Private Function LoadPipe_DT() As DataTable
383
        Dim oDt As New DataTable
384
        oDt.Columns.Add("start_x")
385
        oDt.Columns.Add("start_y")
386
        oDt.Columns.Add("end_x")
387
        oDt.Columns.Add("end_y")
388
        oDt.Columns.Add("Symbol")
389
        Return oDt
390
391
    End Function
392
393
#End Region
394
395
#Region "Load Symbol"
396
    Private Function LoadSymbol_DT() As DataTable
397
        Dim oDt As New DataTable
398
        oDt.Columns.Add("Name")
399
        oDt.Columns.Add("x")
400
        oDt.Columns.Add("y")
401
        oDt.Columns.Add("Angle")
402
        oDt.Columns.Add("Symbol")
403
        oDt.Columns.Add("Text")
404
        Return oDt
405
    End Function
406
407
#End Region
408
409
    Private Function GetSymbolMapping(ByVal oSymbolName As String) As String
410
        Dim oSystemPath As String = ""
411
        Dim oSelectRow() As DataRow = _DB.Select("[pid_symbolname] = '" + oSymbolName + "'")
412
        If oSelectRow.Length = 1 Then
413
            oSystemPath = oSelectRow(0).Item("sppid_systempath").ToString()
414
        End If
415
        Return oSystemPath
416
    End Function
417
418
    Private Function LoadSymbolInXml(ByVal sXmlPath As String) As DataTable
419
        Dim oDt As DataTable = LoadSymbol_DT()
420
        Dim oElement As XElement = XElement.Load(sXmlPath)
421
        If oElement IsNot Nothing Then
422
            For Each symbols As Object In oElement.Elements("SYMBOLS")
423
                For Each page As Object In symbols.Elements("SYMBOL")
424
                    Dim oAddrow As DataRow = oDt.NewRow()
425
                    Dim oObj As XElement = page.Element("NAME")
426
                    Dim oSymbol = oObj.Value
427
428
                    oObj = page.Element("TEXT")
429 962b2464 Gyusu
                    Dim oText = oObj.Value
430
                    oObj = page.Element("CLASS")
431
                    Dim oClass = oObj.Value
432
                    oObj = page.Element("TYPE")
433
                    Dim oType = oObj.Value
434
                    oObj = page.Element("ITEM")
435
                    Dim oItem = oObj.Value
436
437
                    ' Dim oSymbolPath As String = "\" + oSymbol + "\" + oClass + "\" + oType + "\" + oItem + ".sym"
438
                    Dim oSymbolPath As String = GetSymbolMapping(oItem)
439
440
                    oObj = page.Element("ORIGINALPOINT")
441
                    Dim sOriginPoint = oObj.Value
442
443
                    oObj = page.Element("ANGLE")
444
                    Dim oAngle = oObj.Value
445
446
                    Dim oSplitPos As String() = sOriginPoint.Split(",")
447
                    Dim oX As Double = 0.0
448
                    Dim oY As Double = 0.0
449
                    If IsNumeric(oSplitPos(0)) Then
450
                        oX = Double.Parse(oSplitPos(0))
451
                    End If
452
                    If IsNumeric(oSplitPos(1)) Then
453
                        oY = Double.Parse(oSplitPos(1))
454
                    End If
455 4f359afa Gyusu
456
                    ConvertPoint(oX, oY, _DWG_X, _DWG_Y)
457
                    oAddrow("X") = oX '+ 0.05
458 962b2464 Gyusu
                    oAddrow("Y") = oY
459
                    oAddrow("Angle") = oAngle
460
                    oAddrow("Symbol") = oSymbolPath
461
                    oAddrow("Text") = oText
462
                    oAddrow("Name") = oSymbol
463 4f359afa Gyusu
464
                    oDt.Rows.Add(oAddrow)
465
466
                Next
467
            Next
468
469
        End If
470
    End Function
471
472
473
474
    Private Function LoadPipeInXml(ByVal sXmlPath As String) As DataTable
475
        Try
476
            Dim oDt As DataTable = LoadPipe_DT()
477
            Dim oElement As XElement = XElement.Load(sXmlPath)
478
            If oElement IsNot Nothing Then
479
                Dim DWGElement As XElement = oElement.Element("DWGNAME")
480
                Dim DWGNAME = DWGElement.Value
481
                Dim sXY As XElement = oElement.Element("SIZE")
482
                Dim sSize = sXY.Value
483
                Dim oSplitDWGPos As String() = sSize.Split(",")
484
485
                If IsNumeric(oSplitDWGPos(0)) Then
486
                    _IMG_X = Double.Parse(oSplitDWGPos(0))
487
                End If
488
                If IsNumeric(oSplitDWGPos(1)) Then
489
                    _IMG_Y = Double.Parse(oSplitDWGPos(1))
490
                End If
491
492
                For Each pipes As Object In oElement.Elements("IMGLINES")
493
                    For Each pipe As Object In pipes.Elements("IMGLINE")
494
                        Dim oAddrow As DataRow = oDt.NewRow()
495
                        Dim oObj As XElement = pipe.Element("ITEM")
496
                        Dim oItem = oObj.Value
497
                        ' Dim oSymbolPath As String = "\" + oSymbol + "\" + oClass + "\" + oType + "\" + oItem + ".sym"
498
                        Dim oSymbolPath As String = GetSymbolMapping(oItem)
499
                        oObj = pipe.Element("START")
500
                        Dim oStartPoint = oObj.Value
501
                        Dim oSplitPos As String() = oStartPoint.Split(",")
502
                        Dim oStartpos_X As Double = 0.0
503
                        Dim oStartpos_Y As Double = 0.0
504
                        If IsNumeric(oSplitPos(0)) Then
505
                            oStartpos_X = Double.Parse(oSplitPos(0))
506
                        End If
507
                        If IsNumeric(oSplitPos(1)) Then
508
                            oStartpos_Y = Double.Parse(oSplitPos(1))
509
                        End If
510
511
                        ConvertPoint(oStartpos_X, oStartpos_Y, _DWG_X, _DWG_Y)
512
                        oObj = pipe.Element("END")
513
                        Dim oEndPoint = oObj.Value
514
                        oSplitPos = oEndPoint.Split(",")
515
                        Dim oEndpos_X As Double = 0.0
516
                        Dim oEndpos_Y As Double = 0.0
517
                        If IsNumeric(oSplitPos(0)) Then
518
                            oEndpos_X = Double.Parse(oSplitPos(0))
519
                        End If
520
                        If IsNumeric(oSplitPos(1)) Then
521
                            oEndpos_Y = Double.Parse(oSplitPos(1))
522
                        End If
523
                        ConvertPoint(oEndpos_X, oEndpos_Y, _DWG_X, _DWG_Y)
524
525
                        oAddrow("start_x") = oStartpos_X '+ 0.05
526
                        oAddrow("start_y") = oStartpos_Y
527
                        oAddrow("end_x") = oEndpos_X
528
                        oAddrow("end_y") = oEndpos_Y
529
                        oAddrow("Symbol") = oSymbolPath
530
                        oDt.Rows.Add(oAddrow)
531
532
533
                    Next
534
                Next
535
536
            End If
537
538
539
            Return oDt
540
        Catch ex As Exception
541
            Return Nothing
542
        End Try
543
    End Function
544
545
546
    Private Sub ConvertPoint(ByRef dX As Double, ByRef dY As Double, ByVal dDwgX As Double, ByVal dDwgY As Double)
547
548
        Dim calcx As Double = 0
549
        Dim calcy As Double = 0
550
        calcx = (dX * _DWG_X) / dDwgX 'Math.Round((dX * _DWG_X) / dDwgX, 2)
551
        calcy = _DWG_Y - (dY * _DWG_Y) / dDwgY '_DWG_Y - Math.Round((dY * _DWG_Y) / dDwgY, 2)
552
        dX = calcx
553
        dY = calcy
554
    End Sub
555
556
557
558
559
    Private Function AutoConverting(ByVal oPipe_Dt As DataTable, ByVal oSymbol_Dt As DataTable) As Boolean
560
        Dim iSymbolcount = 0
561
        Dim datasource As LMADataSource
562
        datasource = _Placement.PIDDataSource
563
        Dim iPipecnt As Integer = 0
564
565
        For Each oRow As DataRow In oPipe_Dt.Rows
566
            Dim oposition As String = oRow("position").ToString()
567
            Dim oSymbol As String = oRow("Symbol").ToString()
568
            Dim oSplitStr As String() = Split(oposition, " ")
569
            Dim objConnector As LMConnector
570
            Dim objInputs As PlaceRunInputs
571
            objInputs = New PlaceRunInputs
572
            Dim oDwg_x As Double = 9933
573
            Dim oDwg_y As Double = 7016
574
            For Each sposition As String In oSplitStr
575
                Dim opointstr As String() = Split(sposition, ",")
576
577
                If (opointstr.Length > 1) Then
578
                    If IsNumeric(opointstr(0)) And IsNumeric(opointstr(1)) Then
579
                        Dim ox As Double = opointstr(0)
580
                        Dim oy As Double = opointstr(1)
581
                        ConvertPoint(ox, oy, oDwg_x, oDwg_y)
582
                        objInputs.AddPoint(ox, oy)
583
                    End If
584
                End If
585
            Next
586
            Dim objItem As LMAItem
587
            objItem = _Placement.PIDCreateItem(oSymbol)
588
            objConnector = _Placement.PIDPlaceRun(objItem, objInputs)
589
590
            'Dim objPipeRun As LMPipeRun = datasource.GetPipeRun(objConnector.ModelItemID)
591
            'objPipeRun.Attributes("OperFluidCode").Value = "AFS"
592
            'objPipeRun.Commit()
593
            iPipecnt = iPipecnt + 1
594
595
        Next
596
597
598
        For Each oRow As DataRow In oSymbol_Dt.Rows
599
600
            Dim oSymbol As String = oRow("Symbol").ToString()
601
            Dim oType As String = oRow("Name").ToString()
602
            Dim oText As String = oRow("Text").ToString()
603
            Dim oX As Double = 0.0
604
            Dim oY As Double = 0.0
605
            If IsNumeric(oRow("x").ToString()) Then
606
                oX = Double.Parse(oRow("x").ToString())
607
            End If
608
            If IsNumeric(oRow("y").ToString()) Then
609
                oY = Double.Parse(oRow("y").ToString())
610
            End If
611
            Dim oAngle As Double = 0.0
612
            If IsNumeric(oRow("Angle").ToString()) Then
613
                oAngle = Double.Parse(oRow("Angle").ToString())
614
            End If
615
            '   oSymbol = "\INSTRUMENTation\SYSTEM FUNCTIONS\D C S\DCS FUNC ACCESS IN PRIME LOC.sym"
616
            If oSymbol <> "" Then
617
                If oType = "INSTRUMENT" Then
618
                    Dim sTagsuffix As String = ""
619
                    Dim sTagSequenceNo As String = ""
620
                    Dim sMeasuredVariableCode As String = ""
621
                    Dim sInstrumentTypeModifier As String = ""
622
                    If oText <> "" Then
623
                        If oText.Contains(",") Then
624
                            Dim splitstr() As String = oText.Split(",")
625
                            For i = 0 To splitstr.Count - 1
626
                                If i = 0 Then
627
                                    sMeasuredVariableCode = Mid(splitstr(i), 1, 1)
628
                                    sTagSequenceNo = Mid(splitstr(i), 2, Len(splitstr(i)))
629
                                Else
630
                                    If Len(splitstr(i)) = 1 Then
631
                                        sInstrumentTypeModifier = splitstr(i)
632
                                    ElseIf Len(splitstr(i)) = 0 Then
633
634
                                    ElseIf Len(splitstr(i)) > 1 Then
635
                                        sInstrumentTypeModifier = Mid(splitstr(i), 1, 1)
636
                                        sTagsuffix = Mid(splitstr(i), 2, Len(splitstr(i)))
637
                                    End If
638
                                End If
639
                            Next
640
                        Else
641
                            sMeasuredVariableCode = Mid(oText, 1, 1)
642
                            sTagSequenceNo = Mid(oText, 2, Len(oText))
643
                        End If
644
645
                    End If
646
647
                    Dim objInstrSym As LMSymbol
648
                    objInstrSym = _Placement.PIDPlaceSymbol(oSymbol, oX, oY, , oAngle)
649
                    Dim objInstr As LMInstrument
650
                    objInstr = datasource.GetInstrument(objInstrSym.ModelItemID)
651
652
                    Dim objItem As LMAItem
653
                    objItem = _Placement.PIDCreateItem(oSymbol)
654
655
                    'Dim objInstrClass As LMInstrument
656
                    'objInstrClass = datasource.GetInstrument(objItem.Id)
657
                    objInstr.Attributes("MeasuredVariableCode").Value = sMeasuredVariableCode
658
                    objInstr.Attributes("InstrumentTypeModifier").Value = sInstrumentTypeModifier
659
                    objInstr.Attributes("TagSuffix").Value = sTagsuffix
660
                    objInstr.Attributes("TagSequenceNo").Value = sTagSequenceNo
661
                    objInstr.Commit()
662
663
664
                    'objItem = objPlacement.PIDCreateItem(oSymbol)
665
                    'Dim objInstrLoop As LMInstrLoop
666
                    'objInstrLoop = datasource.GetInstrLoop(objItem.Id)
667
668
                    'objInstrLoop.Commit()
669
670
                ElseIf oType = "GATE VALVE WITH PLUG" Then
671
672
                ElseIf oType = "MEDIUM 1D 1TO1" Then
673
674
1:
675
                Else
676
                    _Placement.PIDPlaceSymbol(oSymbol, oX, oY, , oAngle)
677
678
                End If
679
                iSymbolcount = iSymbolcount + 1
680
            Else
681
            End If
682
683
        Next
684
        'For Each oRow As DataRow In oPipe_Dt.Rows
685
        '    Dim oSymbol As String = oRow("Symbol").ToString()
686
        '    Dim oStartPos_x As Double = 0.0
687
        '    Dim oStartPos_y As Double = 0.0
688
        '    Dim oEndPos_x As Double = 0.0
689
        '    Dim oEndPos_y As Double = 0.0
690
        '    If IsNumeric(oRow("start_x").ToString()) Then
691
        '        oStartPos_x = Double.Parse(oRow("start_x").ToString())
692
        '    End If
693
        '    If IsNumeric(oRow("start_y").ToString()) Then
694
        '        oStartPos_y = Double.Parse(oRow("start_y").ToString())
695
        '    End If
696
697
        '    If IsNumeric(oRow("end_x").ToString()) Then
698
        '        oEndPos_x = Double.Parse(oRow("end_x").ToString())
699
        '    End If
700
        '    If IsNumeric(oRow("end_y").ToString()) Then
701
        '        oEndPos_y = Double.Parse(oRow("end_y").ToString())
702
        '    End If
703
        '    Dim objConnector As LMConnector
704
        '    Dim objInputs As PlaceRunInputs
705
        '    objInputs = New PlaceRunInputs
706
        '    objInputs.AddPoint(oStartPos_x, oStartPos_y)
707
        '    objInputs.AddPoint(oEndPos_x, oEndPos_y)
708
        '    Dim objItem As LMAItem
709
        '    objItem = objPlacement.PIDCreateItem(oSymbol)
710
        '    objConnector = objPlacement.PIDPlaceRun(objItem, objInputs)
711
        '    'Dim objPipeRun As LMPipeRun = datasource.GetPipeRun(objConnector.ModelItemID)
712
        '    'objPipeRun.Attributes("OperFluidCode").Value = "AFS"
713
        '    'objPipeRun.Commit()
714
        '    pipecnt = pipecnt + 1
715
716
        'Next
717
718
719
720
721
        MsgBox("symbol: " & iSymbolcount & "개, pipe : " & iPipecnt & "개 변환완료")
722
    End Function
723
724
725
    Private Sub Tree_XMLFiles_AfterCheck(sender As Object, e As TreeViewEventArgs) Handles Tree_XMLFiles.AfterCheck
726
        If e.Node.Checked = True Then
727
            For Each oNode As TreeNode In e.Node.Nodes
728
                oNode.Checked = True
729
            Next
730
        Else
731
            For Each oNode As TreeNode In e.Node.Nodes
732
                oNode.Checked = False
733
            Next
734
        End If
735
    End Sub
736
737
    Private Sub LoadDB(ByVal sDBPath As String)
738
739
        Try
740
            Dim sConnectionstring As String = "Data Source=" & sDBPath & ";Version=3;Synchronous=Off;UTF8Encoding=True;"
741
            Dim conn As SQLiteConnection = New SQLiteConnection(sConnectionstring)
742
            conn.Open()
743
            Dim sQuery As String = "Select * from Mapping"
744
            Dim cmd As SQLiteCommand = conn.CreateCommand()
745
            Dim adapter As SQLiteDataAdapter = New SQLiteDataAdapter(sQuery, conn)
746
            Dim oDataSet As DataSet = New DataSet()
747
            adapter.Fill(oDataSet)
748
            _DB = oDataSet.Tables(0)
749
        Catch ex As Exception
750
751
        End Try
752
753
754
    End Sub
755
756 962b2464 Gyusu
    Dim first_start As Boolean = False
757
    Dim folders_path As String
758
759
    Private Sub Tree_XMLFiles_AfterSelect(sender As Object, e As TreeViewEventArgs) Handles Tree_XMLFiles.AfterSelect
760
        If first_start = False Then Exit Sub
761
        Dim pa = e.Node.FullPath.ToString
762
763
        printfilesfolders_here(pa, e.Node)
764
765
        displayfiles(pa)
766
767
        ''be careful ! displayfils comes BEFORE you change // to / in pa !!!
768
        Dim coco As String = ""
769
        coco = pa.ToString
770
        coco = coco.Replace("\\", "\")
771
        Me.Text = coco
772
        folders_path = coco
773
    End Sub
774
775
    Sub printfilesfolders_here(ByVal path As String, ByRef itree As TreeNode)
776
777
        Dim foldername As String
778
        Dim filename As String
779
        itree.Nodes.Clear()
780
        On Error GoTo eee
781
        For Each foldername In Directory.GetDirectories(path)
782
            On Error GoTo eee
783
            Dim jj = foldername.LastIndexOf("\")
784
            Dim jj1 = foldername.Length - jj
785
            Dim foldr = foldername.Substring((jj + 1), (jj1 - 1))
786
            itree.Nodes.Add(foldr, foldr)
787
        Next ' if you put this next at the end of procedure recursive will be done on first folder only
788
        Exit Sub
789
eee:
790
    End Sub
791
792
    Sub displayfiles(ByVal path As String)
793
794
        Dim lvItem As ListViewItem
795
        ListView_File.Items.Clear()
796
        Me.ToolStripProgressBar1.Visible = True
797
        ' lvItem = ListView.Items.Add("ListViewItem1")
798
        '   lvItem.SubItems.AddRange(New String() {"Size", "extention", "date modified"})
799
800
        Dim filename As String
801
        On Error GoTo wwq
802
        ' Directory.GetFiles(path).Length.
803
        Me.ToolStripProgressBar1.Maximum = Directory.GetFiles(path).Length + 1
804
        Me.ToolStripProgressBar1.Value = 0
805
        For Each filename In Directory.GetFiles(path)
806
            On Error GoTo wwq
807
            Dim jj_ = filename.LastIndexOf("\")
808
            Dim jj1_ = filename.Length - jj_
809
            Dim fil = filename.Substring((jj_ + 1), (jj1_ - 1))
810
            If fil.Contains(".xml") Then
811
                Me.ToolStripProgressBar1.Value = Me.ToolStripProgressBar1.Value + 1
812
                ' ListView.Items.Add(fil, 13) ''old 13 28
813
                lvItem = ListView_File.Items.Add(fil, 13) '2 5 7 work, 0 alos
814
                Dim infoReader As System.IO.FileInfo
815
                infoReader = My.Computer.FileSystem.GetFileInfo(filename)
816
                '    lvItem.SubItems.AddRange(New String() {infoReader.Length.ToString + " Byte", infoReader.Extension.ToString, infoReader.LastWriteTime})
817
                lvItem.SubItems.AddRange(New String() {infoReader.LastWriteTime})
818
                ListView_File.AutoResizeColumns(ColumnHeaderAutoResizeStyle.ColumnContent)
819
            End If
820
821
822
        Next
823
        Me.ToolStripProgressBar1.Visible = False
824
        Exit Sub
825
wwq:
826
        Me.ToolStripProgressBar1.Visible = False
827
        MsgBox(Err.Description)
828
    End Sub
829
830
    Private Sub Tree_XMLFiles_MouseMove(sender As Object, e As MouseEventArgs) Handles Tree_XMLFiles.MouseMove
831
        first_start = True
832
    End Sub
833
834
    Private Sub ListView_File_SelectedIndexChanged(sender As Object, e As EventArgs) Handles ListView_File.SelectedIndexChanged
835
        Dim indexes As ListView.SelectedIndexCollection =
836
                         Me.ListView_File.SelectedIndices
837
        Dim index As Integer
838
839
        For Each index In indexes
840
            'On Error Resume Next
841
            If folders_path.EndsWith("\") = True Then
842
                Me.Status_Main.Items(0).Text = folders_path + (Me.ListView_File.Items(index).Text)
843
                'On Error Resume Next
844
            Else
845
                Me.Status_Main.Items(0).Text = folders_path + "\" + (Me.ListView_File.Items(index).Text)
846
            End If
847
848
            Dim infoReader As System.IO.FileInfo
849
            infoReader = My.Computer.FileSystem.GetFileInfo(Me.Status_Main.Items(0).Text)
850
            Me.Status_Main.Items(1).Text = " Created : " + infoReader.CreationTime.ToString + " " + infoReader.Attributes.ToString
851
        Next
852
    End Sub
853
854
    Private Sub Procees()
855
        Dim indexes As ListView.SelectedIndexCollection =
856
                            Me.ListView_File.SelectedIndices
857
        Dim index As Integer
858
859
        For Each index In indexes
860
            'On Error Resume Next
861
            If folders_path.EndsWith("\") = True Then
862
                On Error GoTo out
863
                Me.Status_Main.Items(0).Text = folders_path + (Me.ListView_File.Items(index).Text)
864
                On Error GoTo out
865
                'On Error Resume Next
866
            Else
867
                Me.Status_Main.Items(0).Text = folders_path + "\" + (Me.ListView_File.Items(index).Text)
868
                On Error GoTo out
869
            End If
870
871
            Dim infoReader As System.IO.FileInfo
872
            infoReader = My.Computer.FileSystem.GetFileInfo(Me.Status_Main.Items(0).Text)
873
            Me.Status_Main.Items(1).Text = " Created : " + infoReader.CreationTime.ToString + " " + infoReader.Attributes.ToString
874
            On Error GoTo out
875
            MsgBox(Me.Status_Main.Items(0).Text + " is processed")
876
            On Error GoTo out
877
        Next
878
        Exit Sub
879
out:
880
        MsgBox(Err.Description)
881
    End Sub
882
883 31d47a80 Gyusu
    Private Function LoadAllDrawing() As DataTable
884
        Dim oDt As DataTable = Drawing_Dt()
885
        _objPIDADrawing = CreateObject("PIDAutomation.Application")
886
        For Each objDrawing In _objPIDADrawing.Drawings
887
            Dim sName As String = objDrawing.Attributes("Name").Value
888
            Dim sPath As String = objDrawing.Attributes("Path").Value
889
            Dim oAddRow As DataRow = oDt.NewRow()
890
            oAddRow("Name") = sName
891
            oAddRow("Path") = sPath
892
            oDt.Rows.Add(oAddRow)
893
        Next
894
        Return oDt
895
    End Function
896
897
    Private Sub TestOpen()
898
        Dim datasource As LMADataSource
899
        Dim objPIDAutoApp As Object
900
        Dim objPIDADrawing As Object
901
        Dim objDrawing As Object 'Drawing
902
        'Dim objDrawing As LMDrawing
903
        'Dim objDrawings As LMDrawings
904
905
        datasource = New LMADataSource
906
907
        '    objDrawings = New LMDrawings
908
        'objDrawings.Collect(datasource)
909
        objPIDAutoApp = CreateObject("PIDAutomation.Application")
910
911
        For Each objDrawing In objPIDAutoApp.Drawings
912
            objDrawing.CloseDrawing(True)
913
        Next
914
        Try
915
            objPIDADrawing = objPIDAutoApp.Drawings.OpenDrawing("UY1-K-2000_P1_300dpi_0321_TEST_1")
916
        Catch ex As Exception
917
            Process.Start("\\desktop-9vlq0dp\Test02Site\P188943_SPPID_Plant\Plant_Hierarchy\8121\8121-1\UY1-K-2000_P1_300dpi_0321_TEST_1.pid")
918
        End Try
919
920
921
922
        Dim sType As Type = objPIDAutoApp.GetType()
923
        Dim iCount As Integer = 0
924
        ' Dim sPath As String = "‪\\desktop-9vlq0dp\Test02Site\P188943_SPPID_Plant\Plant_Hierarchy\8121\8121-1\188943-8121-PR-DW-011001.pid"
925
926
        objPIDADrawing = objPIDAutoApp.Drawings.OpenDrawing("1")
927
928
        For Each objDrawing In objPIDAutoApp.Drawings
929
            If objDrawing.Attributes("ItemStatus").Index = 1 Then '1 stands for Active
930
                Try
931
932
                    Dim sName As String = objDrawing.Attributes("Name").Value
933
934
                    iCount = iCount + 1
935
                    If sName = "UY1-K-2000_P1_300dpi_0321_TEST_1" Then
936
                        objPIDADrawing = objPIDAutoApp.Drawings.OpenDrawing(objDrawing.Attributes("Name"))
937
                        objPIDADrawing = objPIDAutoApp.Drawings.OpenDrawing("\8121\8121-1\UY1-K-2000_P1_300dpi_0321_TEST_1.pid")
938
                        If Not objPIDADrawing Is Nothing Then
939
                            objPIDADrawing.CloseDrawing()
940
                        End If
941
                    End If
942
943
944
                Catch ex As Exception
945
946
                End Try
947
948
            End If
949
        Next
950
        objPIDAutoApp.Quit
951
        objPIDAutoApp = Nothing
952
        objPIDADrawing = Nothing
953
        objDrawing = Nothing
954
        '   objDrawings = Nothing
955
    End Sub
956 962b2464 Gyusu
    Private Sub Btn_Convert_Click(sender As Object, e As EventArgs) Handles Btn_Convert.Click
957 31d47a80 Gyusu
958 962b2464 Gyusu
        If ListView_File.Items.Count > 0 Then
959 31d47a80 Gyusu
            Dim oDwg_Dt As DataTable = LoadAllDrawing()
960
961 962b2464 Gyusu
            For Each oItem As ListViewItem In ListView_File.Items
962
                If oItem.Checked Then
963
                    Dim sDwgName As String = oItem.Text
964
                    Dim sDwgNo As String = oItem.Text
965
                    Dim oDwgPath As String = ""
966
                    oDwgPath = Tree_XMLFiles.SelectedNode.FullPath + "\" + sDwgName
967 1229ad76 Gyusu
968
                    Dim oPipe_Dt As DataTable = Nothing 'LoadPipeInXml(oDwgPath)
969 962b2464 Gyusu
                    Dim oSymbol_Dt As DataTable = LoadSymbolInXml(oDwgPath)
970
                    '도면 생성
971 1229ad76 Gyusu
                    If CreateDwg(sDwgName) Then
972 962b2464 Gyusu
                        'AutoConverting
973
                        AutoConverting(oPipe_Dt, oSymbol_Dt)
974
                    End If
975
                End If
976 4f359afa Gyusu
977 962b2464 Gyusu
            Next
978
        End If
979
    End Sub
980 4f359afa Gyusu
End Class
클립보드 이미지 추가 (최대 크기: 500 MB)