IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Controle des éléments Shape


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Décembre 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2012
    Messages : 24
    Points : 13
    Points
    13
    Par défaut Controle des éléments Shape
    Bonjour à tous.
    Ma question est simple. je cherche à contrôler par macros ces 2 points.
    Nom : Edition Shape.JPG
Affichages : 690
Taille : 30,9 Ko

    J'ai trouvé comment dimensionner, et positionner l'élément shape.
    J'ai aussi trouvé des solutions 3D avec ".ThreeD"
    Mais ça je bute dessus.
    Est'ce possible ?
    (Je suis sur Excel 2010.)

    Merci d'avance.

  2. #2
    Membre émérite Avatar de antonysansh
    Homme Profil pro
    Chargé d'études RH
    Inscrit en
    Mai 2014
    Messages
    1 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé d'études RH
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2014
    Messages : 1 115
    Points : 2 439
    Points
    2 439
    Par défaut
    Bonjour Tsteel,

    Comme tu es sur 2010, tu peux utiliser l'enregistreur de macro pour générer du code est ensuite t'inspirer du code.

    Voilà ce que m'a sortir l'enregistreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Macro1()
        ActiveSheet.Shapes.Range(Array("Block Arc 1")).Select
        Selection.ShapeRange.Adjustments.Item(2) = 134.9730166667
        Selection.ShapeRange.Adjustments.Item(1) = 157.02485
    End Sub
    Antony

    Mieux vaut ne rien dire et passer pour un con que de l'ouvrir et ne laisser aucun doute à ce sujet.
    Gustave Parking


    Si le post vous est utile un petit fait toujours plaisir et pensez à passer en

    Et surtout -> Balise CODE

  3. #3
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Décembre 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2012
    Messages : 24
    Points : 13
    Points
    13
    Par défaut
    Merci Anthony, tu m'a devancé.
    Je viens de trouvé ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Angle_segment_1()
       ActiveSheet.Shapes("Segment").Select
       Selection.ShapeRange.Adjustments.Item(1) = Range("A1")
       Selection.ShapeRange.Adjustments.Item(2) = Range("A2")
    End Sub
    Les 2 points en question c'est "item(n° du point)"
    ça permet de contrôler l'angle du segment mais pas sont épaisseur.
    Nom : Edition Shape.JPG
Affichages : 631
Taille : 30,1 Ko

    Comment donc ?
    Peut être le terme ".Adjustments" qu'il faut changer ?

  4. #4
    Membre émérite Avatar de antonysansh
    Homme Profil pro
    Chargé d'études RH
    Inscrit en
    Mai 2014
    Messages
    1 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé d'études RH
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2014
    Messages : 1 115
    Points : 2 439
    Points
    2 439
    Par défaut
    Tout simplement l'Item(3) !

    Test ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    Sub PACMAN()
        Dim shp As Shape, i&
        Set shp = ActiveSheet.Shapes.AddShape(msoShapeBlockArc, 186, 123.75, 72, 72)
        With shp
            .Fill.ForeColor.RGB = RGB(255, 255, 0)
            .Line.ForeColor.RGB = RGB(255, 255, 0)
            .Adjustments.Item(1) = 30
            .Adjustments.Item(2) = 360 - 30
            For i = 0 To 500
                Application.Wait Now + TimeSerial(0, 0, 0.1)
                .Adjustments.Item(3) = i / 1000
            Next i
            For i = 1 To 10
                Application.Wait Now + TimeSerial(0, 0, 0.6)
                If i Mod 2 = 0 Then
                    .Adjustments.Item(1) = 10
                    .Adjustments.Item(2) = 360 - 10
                Else
                    .Adjustments.Item(1) = 30
                    .Adjustments.Item(2) = 360 - 30
                End If
            Next i
            For i = 500 To 0 Step -1
                Application.Wait Now + TimeSerial(0, 0, 0.1)
                .Adjustments.Item(3) = i / 1000
            Next i
            .Delete
        End With
    fin:
        Set shp = Nothing
    End Sub
    Item(3) n’a un intérêt que pour des valeurs entre 0 et 0.5 c'est en fait une proportion du diamètre.
    Antony

    Mieux vaut ne rien dire et passer pour un con que de l'ouvrir et ne laisser aucun doute à ce sujet.
    Gustave Parking


    Si le post vous est utile un petit fait toujours plaisir et pensez à passer en

    Et surtout -> Balise CODE

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Décembre 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2012
    Messages : 24
    Points : 13
    Points
    13
    Par défaut
    Super le Pacman.

    J'avais pas compris la signification de "Item".
    Je pensais que c'était la désignation du point.

    Le difficulté maintenant c'est de trouver une correspondance en mm, par rapport à mon application.
    ce schéma représente l'épaisseur d'un tube dans la réalité.

    Merci c'est parfait.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 11
    Dernier message: 26/09/2013, 16h05
  2. tranférer des éléments d'une base
    Par john_wayne dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 21/06/2004, 15h33
  3. [VB.NET] Enregistrement des éléments d'une listBox
    Par Hoegaarden dans le forum Windows Forms
    Réponses: 9
    Dernier message: 18/05/2004, 14h48
  4. couleurs des éléments 3D d'une appli
    Par Eugénie dans le forum MFC
    Réponses: 29
    Dernier message: 12/03/2004, 11h31
  5. [TShellListView] Tri des éléments
    Par M.Dlb dans le forum Composants VCL
    Réponses: 4
    Dernier message: 16/12/2003, 22h35

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo