Macro pour changement d'orientation des vue sous solidworks

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

http://help.solidworks.com/2016/english/api/sldworksapi/solidworks.interop.sldworks~solidworks.interop.sldworks.ifeaturemanager~insertmovecopybody2.html

 

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

https://www.google.fr/webhp?sourceid=chrome-instant&rlz=1C1RLNS_frFR739FR739&ion=1&espv=2&ie=UTF-8#q=90deg+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 !