Bonjour à tous, je cherche actuellement un moyen d'automatiser la réorientation de la vue front d'un fichier importé directement d'un site constructeur, sinon la pièce n'est pas reconnu sur Altium. Ce sont seulement les plans d'origine qui ne sont pas bien orientés, et le fichier téléchargé sur le site ne me permet pas de le modifier.
Je pense que tu peut regarder du coter la fonction Copier deplacer http://help.solidworks.com/2016/french/solidworks/sldworks/hidd_dve_feat_move_surf.htm
regarde si la fonction correspond et dans quel cas tu pourra enregistré la macro de ce qui t'interesse (Rotation 90° sur X ou Y ou Z)
@MaD, comme j'ai pu comprendre, il ne cherche pas à déplacer la pièce, mais modifier la vue sur la pièce.
Essaye avec l'enregistreur de macro de te placer dessus et voir si tu as un code utilisable.
@KVuilleumier, c'est bien l'orientation de la pièce que je veux pouvoir modifier par rapport au repère pour que la vue de face soit celle que je souhaite. Il me faut également redéfinir le placement du repère, j'aurais peut être du passer d'abord par la. Je suis novice dans solidworks, j'étais auparavent sur ProE et donc je ne sais pas comment m'y prendre d'autant plus que je ne sais pas faire de macro (il faudra bien un jour que je me l'apprenne) .
Merci pour vos réponses !
Peut tu mettre la piece que tu as au depart et nous dire l'orientation que tu veut au final ?
Voila la pièce qui est seulement la pour illustrer physiquement ce que je désire faire. La vue de face est actuellement une vue perçée, je souhaites faire en sorte changer l'orientation de la pièce par rapport au repère afin d'avoir la vue de face sur la face actuelle du dessus (non perçé).
Ce code fonctionne je te laisse l'adapté a ton besoin
Dim swApp As Object
Dim Part As Object
Dim boolstatus As Boolean
Dim longstatus As Long, longwarnings As Long
Sub main()
Set swApp = Application.SldWorks
Set Part = swApp.ActiveDoc
boolstatus = Part.Extension.SelectByID2("Congé9", "SOLIDBODY", 0.306720518918638, 0.145146136734809, 2.68172410638385E-02, False, 1, Nothing, 0)
Dim myFeature As Object
Set myFeature = Part.FeatureManager.InsertMoveCopyBody2(0, 0, 0, 0, 0, 0, 0, 0, 0, 1.5707963267949, False, 1)
End Sub
Pour la fonction voir ce lien
Pour la macro d'exemple SW http://help.solidworks.com/2016/english/api/sldworksapi/Move_Bodies_Example_VB.htm
'-------------------------------------------------------------
' Preconditions:
' 1. Specified part document to open exists.
' 2. Run the macro.
'
' Postconditions: All of the bodies in the part document
' are moved to the specified location.
'
' NOTE: Because this part is used elsewhere, do not save
' any changes when closing it.
'--------------------------------------------------------------
Option Explicit
Sub SelectBodies(swApp As SldWorks.SldWorks, swModel As SldWorks.ModelDoc2, bodyArr As Variant)
' Select and mark the bodies to move
Dim swSelMgr As SldWorks.SelectionMgr
Dim swSelData As SldWorks.SelectData
Dim body As Variant
Dim swBody As SldWorks.Body2
Dim status As Boolean
Set swSelMgr = swModel.SelectionManager
Set swSelData = swSelMgr.CreateSelectData
If IsEmpty(bodyArr) Then Exit Sub
For Each body In bodyArr
Set swBody = body
swSelData.Mark = 1
status = swBody.Select2(True, swSelData)
Next body
End Sub
Sub main()
Dim swApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc2
Dim swPart As SldWorks.PartDoc
Dim bodyArr As Variant
Dim swFeatMgr As SldWorks.FeatureManager
Dim swFeat As SldWorks.Feature
Dim fileName As String
Dim errors As Long
Dim warnings As Long
Set swApp = Application.SldWorks
fileName = "C:\Program Files\SOLIDWORKS Corp\SOLIDWORKS\samples\tutorial\multibody\multi_inter.sldprt"
Set swModel = swApp.OpenDoc6(fileName, swDocPART, swOpenDocOptions_e.swOpenDocOptions_Silent, "", errors, warnings)
Set swPart = swModel
Set swFeatMgr = swModel.FeatureManager
swModel.ClearSelection2 True
' Get the bodies to move
bodyArr = swPart.GetBodies2(swAllBodies, false)
SelectBodies swApp, swModel, bodyArr
' Move the bodies
Set swFeat = swFeatMgr.InsertMoveCopyBody2(0.1, 0.2, 0.3, 0#, 0#, 0#, 0#, 0#, 0#, 0#, False, 1)
End Sub
Merci beaucoup pour les indications, je vais essayer de mettre tout ça en oeuvre. Je te tiendrais au courant si la macro fonctionne sur ma pièce.
Bon, j'ai essayer la macro après avoir pris en main solidworks. J'ai changer le filename pour avoir la pièce que je souhaitais, mais en éxecutant la macro la pièce à seulement été expulsée très loin de ses plans mais son orientation reste la même et les plans ont la même coincidence à leur surface respective qu'avant le run de la macro.
Je vais tenter de mieux m'expliquer sur mon problème. Je souhaite faire passer ma vue de dessus en vue front. Car lorsque je veux faire ma mise en plan dans SW je veux faire un projeter des vues de mon plan front.
J'espère que je suis assez clair même si j'avou que j'ai un peu de mal à expliquer ce que je souhaite faire merci à vous dans tous les cas !
La deuxieme macro est une mecro d'exemple dans ton cas change
InsertMoveCopyBody2(0.1, 0.2, 0.3, 0#, 0#, 0#, 0#, 0#, 0#, 0#, False, 1)
par
InsertMoveCopyBody2(0, 0, 0, 0, 0, 0, 0, 0, 0, 1.5707963267949, False, 1)
ou 1.57 est la valeur de rotation en radians
Plus d'info sur la fonction InsertMoveCopy http://help.solidworks.com/2016/english/api/sldworksapi/solidworks.interop.sldworks~solidworks.interop.sldworks.ifeaturemanager~insertmovecopybody2.html
La macro marche parfaitement après avoir remplacer la ligne insertmovecopybody, mais je me suis aperçu que j'aurais aimé également faire tourner la pièce à 180° sur Y en gardant fixe mon repère et mes plans.
Merci pour cette macro qui m'est d'une grande utilité !
Je te laisse marqué ton probleme comme résolu dan ce cas la pour ce qui est de la Rotation en Y je te laisse mettre la valeur dans la meme ligne que tu a modifié regarde dans l'aide precedement fourni pour trouer l'emplacement de la rotation en Y
D'accord et pour information j'ai également changé le chemin du filename pour que lorsque j'éxécute la Macro, ce soit ma pièce qui est active dans solidworks et non toujours la même du filename sur qui l'opération s'effectue.
Merci encore pour ton coup de main très précieux !