Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  SolidWorks
  How to extract a part from ToolBox with API

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für SOLIDWORKS
  
Dokumentenmanagement leicht gemacht mit 3DEXPERIENCE SOLIDWORKS
Autor Thema:  How to extract a part from ToolBox with API (1131 mal gelesen)
swPeter
Mitglied



Sehen Sie sich das Profil von swPeter an!   Senden Sie eine Private Message an swPeter  Schreiben Sie einen Gästebucheintrag für swPeter

Beiträge: 10
Registriert: 26.04.2005

erstellt am: 26. Apr. 2005 23:51    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

How to extract a part from ToolBox with API, if you know the name of this part?

for example:
DIN 912 M4 x 12 --- 12N.SLDPRT

Hi from Spain. Please to respond in Ingles or Spanish to me.

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

StefanBerlitz
Guter-Geist-Moderator
IT Admin (CAx)



Sehen Sie sich das Profil von StefanBerlitz an!   Senden Sie eine Private Message an StefanBerlitz  Schreiben Sie einen Gästebucheintrag für StefanBerlitz

Beiträge: 8756
Registriert: 02.03.2000

SunZu sagt:
Analysiere die Vorteile, die
du aus meinem Ratschlag ziehst.
Dann gliedere deine Kräfte
entsprechend und mache dir
außergewöhnliche Taktiken zunutze.

erstellt am: 27. Apr. 2005 07:53    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für swPeter 10 Unities + Antwort hilfreich

Hi mate,

I did a brief internet research and browsed the API section at www.solidworks.com  , but I was unable to find any sample code to use toolbox via API. There are some Toolbox helper objects in the API since 2004, but these are only some events fired to notify PDMWorks (if that is installed).

So I suspect there is no API for toolbox. I re3commend that you try to contact API support directly (the mail adress is apisupport@solidworks.com ) and ask them for some API calls. At least they take the enhancement request and put it on their ToDo list.

Hope that helps,
Stefan

------------------
Inoffizielle deutsche SolidWorks Hilfeseite
http://solidworks.cad.de

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

swPeter
Mitglied



Sehen Sie sich das Profil von swPeter an!   Senden Sie eine Private Message an swPeter  Schreiben Sie einen Gästebucheintrag für swPeter

Beiträge: 10
Registriert: 26.04.2005

erstellt am: 27. Apr. 2005 08:13    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Exactly, they do not have implemented this possibility.
Your you have a page in Internet?
  I have seen that GIF in a Web or not?

Equal I happen to me when I wanted to hide rows in BOM(EXCEL).

Thanks

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

swPeter
Mitglied



Sehen Sie sich das Profil von swPeter an!   Senden Sie eine Private Message an swPeter  Schreiben Sie einen Gästebucheintrag für swPeter

Beiträge: 10
Registriert: 26.04.2005

erstellt am: 27. Apr. 2005 08:23    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Yes,http://swtools.cad.de/us_index.htm
Man is an honor I frequently I visit you Web, for my you are a referring one of VB in SoLidWorks.
Good, good to celebrate I put the code to you that I made to hide the rows.

Code:

'----------------------------------------------------
' How to hide rows in a BOM(Excel).
'
' Autor: Ing.Sup.Mec. Pedro Omar Sánchez Curbelo
' Sevilla. Spain. 9 april 2005
'
' Preconditions:
'
'      (1) Drawing document is open.
'      (2) Drawing contains one View with BOM(Excel).
'
' Postconditions: Hide Rows in BOM (from 3 to 4).
'
'----------------------------------------------------
Option Explicit

Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (hpvDest As Any, hpvSource As Any, ByVal cbCopy As Long)
Public Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
Public Declare Function PostMessage Lib "user32" Alias "PostMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long

Public Const WM_MOUSEACTIVATE = &H21
Public Const WM_LBUTTONDOWN = &H201
Public Const WM_SETCURSOR = &H20
Public Const WM_PAINT = &HF
Public Const MK_LBUTTON = &H1
Public Const HTCLIENT = 1

Public Declare Function GetWindow Lib "user32" (ByVal hwnd As Long, ByVal wCmd As Long) As Long
' Constantes de GetWindow()
Public Const GW_CHILD = 5
Public Const GW_HWNDFIRST = 0
Public Const GW_HWNDLAST = 1
Public Const GW_HWNDNEXT = 2
Public Const GW_HWNDPREV = 3
Public Const GW_MAX = 5
Public Const GW_OWNER = 4

Public Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Public Declare Function IsWindow Lib "user32" (ByVal hwnd As Long) As Long

Public Const swDocDRAWING = 3        '  Used to be TYPE_DRAWING

Public swApp                        As Object ' SldWorks.SldWorks '
Public swModel                      As Object 'SldWorks.ModelDoc2  '
Public swDraw                        As Object 'SldWorks.DrawingDoc  '
Public swView                        As Object 'SldWorks.View  '
Public swViewBOM                    As Object ' SldWorks.BomTable '

Public SwHwnd                        As Long
Public hWndMView                    As Long
Public BeforehWindow            As Long

Sub main()

Dim Frme                            As Object 'SldWorks.Frame '
Dim mModelView                      As Object 'SldWorks.ModelView  '
Dim swView_Name                    As String
Dim bRet                            As Boolean

Set swApp = GetObject(, "SldWorks.Application")
  If swApp Is Nothing Then
  MsgBox "It was not possible to be connected with SolidWorks"
  Exit Sub
  End If
 
Set Frme = swApp.Frame
  SwHwnd = Frme.GetHWnd 'Handle de SW.
Set Frme = Nothing

Set swModel = swApp.ActiveDoc
  If swModel Is Nothing Then
  MsgBox "There is no active document"
  Set swApp = Nothing
    Exit Sub
  End If
 
  If swModel.GetType <> swDocDRAWING Then
  MsgBox "Only Allowed on document DRAWs"
  Set swApp = Nothing
    Exit Sub
  End If
 
  Set mModelView = swModel.ActiveView
  hWndMView = mModelView.GetViewHWnd()
  Set mModelView = Nothing
 
BeforehWindow = GetWindow(hWndMView, GW_CHILD)

Set swDraw = swModel

Set swView = swDraw.GetFirstView
  Set swView = swView.GetNextView
  Do While Not swView Is Nothing
    swView_Name = swView.Name
    bRet = swModel.Extension.SelectByID2(swView_Name, "DRAWINGVIEW", 0, 0, 0, False, 0, Nothing, 0)
      If bRet <> False Then
      Set swViewBOM = swView.GetBomTable
        If Not swViewBOM Is Nothing Then
        'Hide 2 to 4 rows
        If HideRows(3, 4) Then
          Call ActivaMView
          Exit Do
        End If
        End If
      End If
    Set swView = swView.GetNextView
  Loop
 
Set swView = Nothing
Set swDraw = Nothing
Set swModel = Nothing
Set swApp = Nothing

End Sub

Public Function HideRows(FromRow As Long, ToRow As Long) As Boolean

On Error GoTo ErrorControl

Dim xlsApp As Object 'Excel.Application '
Dim xlsWB  As Object 'Excel.Workbook '
Dim xlsSht As Object 'Excel.Worksheet '
Dim i As Long
Dim bRet As Boolean

bRet = swViewBOM.Attach3

If Abs(CLng(bRet)) <> 1 Then
  MsgBox "Error attacking the BOM"
  HideRows = False
  Exit Function
End If

Set xlsApp = GetObject(, "Excel.Application")

If xlsApp Is Nothing Then
  MsgBox "It was not possible to be connected with Excel"
  HideRows = False
  Exit Function
End If

Set xlsWB = xlsApp.ActiveWorkbook
  If Not xlsWB Is Nothing Then
  Set xlsSht = xlsWB.Sheets(1)
    If Not xlsSht Is Nothing Then
    For i = FromRow To ToRow
      xlsSht.Rows(i & ":" & i).Hidden = True
    Next i
    End If
  Set xlsSht = Nothing
  End If
 
 
Set xlsWB = Nothing
Set xlsApp = Nothing
  'swViewBOM.Detach
  Set swViewBOM = Nothing
 
HideRows = True

Exit Function

ErrorControl:
Err.Clear
  HideRows = False
  MsgBox "Error While work with Excel"

End Function

Public Sub ActivaMView()

Dim PtoPack As Long
Dim hWindow As Long
Dim lngResult As Long

SendMessage hWndMView, WM_MOUSEACTIVATE, ByVal CLng(SwHwnd), ByVal MAKELONG(HTCLIENT, WM_LBUTTONDOWN)
SendMessage hWndMView, WM_SETCURSOR, ByVal CLng(hWndMView), ByVal MAKELONG(HTCLIENT, WM_LBUTTONDOWN)
    PtoPack = (1 * &H10000) + 1
PostMessage hWndMView, WM_LBUTTONDOWN, ByVal CLng(MK_LBUTTON), ByVal PtoPack
SendMessage hWndMView, WM_PAINT, 0, ByVal 0

OTRS:
hWindow = GetWindow(hWndMView, GW_CHILD)
If hWindow = BeforehWindow Then Exit Sub
  lngResult = WaitForSingleObject(hWindow, 2000)

If IsWindow(hWindow) = 0 Then
  Exit Sub
Else
  DoEvents
  GoTo OTRS
End If

End Sub

Public Function MAKELONG(wLow As Long, wHigh As Long) As Long

MAKELONG = LOWORD(wLow) Or (&H10000 * LOWORD(wHigh))

End Function

Public Function LOWORD(dwValue As Long) As Integer

CopyMemory LOWORD, dwValue, 2

End Function



Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

StefanBerlitz
Guter-Geist-Moderator
IT Admin (CAx)



Sehen Sie sich das Profil von StefanBerlitz an!   Senden Sie eine Private Message an StefanBerlitz  Schreiben Sie einen Gästebucheintrag für StefanBerlitz

Beiträge: 8756
Registriert: 02.03.2000

SunZu sagt:
Analysiere die Vorteile, die
du aus meinem Ratschlag ziehst.
Dann gliedere deine Kräfte
entsprechend und mache dir
außergewöhnliche Taktiken zunutze.

erstellt am: 27. Apr. 2005 12:36    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für swPeter 10 Unities + Antwort hilfreich

Hi Pedro,

thanks for the macro and thanks for the cheers 

Your macro is running like a charm, thanks for sharing. For other users: the macro needs SolidWorks 2005 or above to work (and installed Eccel of corse). Also when copy/pasting the code segment from Pedro to a new macro make sure to move the Sub main to the very end of the macro code to be able to run it from Tools/macros/run. If you launch it from the macro editor or from a toolbar icon this shouldn't be an issue for you are suppose to specify the starting procedure 

Now in german:

Vielen Dank an Pedro, dass er das Makro mit uns teilt; das Makro zeigt beispielhaft, wie per Makro in einer Excel-Stückliste bestimmte Reihen (hier 2-4) ausgeblendet werden können. Läuft erst ab 2005 und bitte aufpassen, falls der ganmze Code einfach in ein neues Makro reinkopiert wird, dass die Sub main ganz ans Ende geschoben wird, damit das Makro auch funktioniert, wenn es einfach per Extras/Makros/Ausführen gestartet wird. Aus dem Editor oder selbstgemachten Toolbaricon ist das kein Problem, da dann die Startprozedur ja angegeben wird.

Ciao and many greeting to spain,
Stefan

------------------
Inoffizielle deutsche SolidWorks Hilfeseite
http://solidworks.cad.de

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2024 CAD.de | Impressum | Datenschutz