Excel & VB - Récupérer le nom objet cliqué

ridertart Messages postés 14 Statut Membre -  
 OBO29 -
Bonjour,

J'aurais souhaité savoir comment récupérer le nom d'un objet sur lequel on aura cliqué (sur excel) à l'aide de VB.

Par exemple j'ai plusieurs rectangle et je voudrais récupérer les paramètres de couleur par exemple du rectangle sur lequel j'aurais cliqué.

Par contre lorsque je clique sur un rectangle, il lance une macro ... cela pose t'il un problème pour récupérer le nom ... ???

Merci d'avance.
Configuration: Windows XP
Internet Explorer 7.0

4 réponses

  1. Willy
     
    Essaye cela :

    Sub ShapeClick()

    Dim NomShape As String
    NomShape = Application.Caller

    Msgbox NomShape

    End Sub

    Tu affectes la macro aux objets désirés

    Merci à ChrisKang dans une autre discussion !
    12
    1. Foxter
       
      Merci beaucoup !!!
      0
    2. Inconnu
       
      Super Willy, merci mille fois
      0
    3. Ahkrane
       
      Merci beaucoup, ça répond parfaitement à un besoin que j'avais

      Ahkrane
      0
    4. OBO29
       
      Nickel Merci,
      0
  2. amigo
     
    Bonjour,

    Je vois que tu es toujours en galère avec tes rectangles colorés.

    Comme on te l'as déjà dit, il suffit quelque fois d'enregistrer une macro pour que la lumière soit.
    Je vais t'expliquer comment je procède.

    Par exemple, je dessine un rectangle "Rectangle 1", puis j'enregitre une macro "Macro1" (Menu Outils Macro Nouvelle Macro)
    Clic droit sur le rectangle, Format de la forme automatique...
    Je change la couleur du fond, la bordure...Je ferme la boite de dialogue.
    J'arrete l'enregistrement de Macro1, Editeur Visual Basic, Module1 (ou Module2...),et je recupère le code

    Sub Macro1()
    '
    ' Macro1 Macro
    ' Macro enregistrée le 18/02/2008
    '
    '
    ActiveSheet.Shapes("Rectangle1").Select
    Selection.ShapeRange.Fill.Visible = msoTrue
    Selection.ShapeRange.Fill.Solid
    Selection.ShapeRange.Fill.ForeColor.SchemeColor = 11
    Selection.ShapeRange.Fill.Transparency = 0#
    Selection.ShapeRange.Line.Weight = 0.75
    Selection.ShapeRange.Line.DashStyle = msoLineSolid
    Selection.ShapeRange.Line.Style = msoLineSingle
    Selection.ShapeRange.Line.Transparency = 0#
    Selection.ShapeRange.Line.Visible = msoTrue
    Selection.ShapeRange.Line.ForeColor.SchemeColor = 11
    Selection.ShapeRange.Line.BackColor.RGB = RGB(255, 255, 255)
    End Sub

    C'est pas bien compliqué. Maintemant je veux afficher certaines propriété de ce rectangle quand je clic dessus.

    Je crée une macro qui s'appelle Rectangle1_QuandClic(), atention à l'orthographe, le nom est important car il fait référence à un évènement prédéfini.

    Sub Rectangle1_QuandClic()
    'pour repondre à ta question j'affiche le nom
    'mais je ne vois pas trop l'interet de connaitre le nom de l'obet
    MsgBox ActiveSheet.Shapes("Rectangle 1").Name

    'Accessoirement voici la couleur de l'objet
    ActiveSheet.Shapes("Rectangle 1").Select
    MsgBox Selection.ShapeRange.Fill.ForeColor.SchemeColor
    End Sub

    Je vais dans ma feille excel, clic droit sur rectangle1, Affecter une macro -> Rectangle1_QuandClic()
    C'est terminé. Quand je passe sur le rectangle, le curseur change. Je clic dessus et les messages programmés s'affichent.

    J'espère que ça t'avencera un peu. Salut.
    2
    1. ridertart
       
      As tu une réponse qui pourrait m'aider ?
      0
  3. ridertart Messages postés 14 Statut Membre 17
     
    Oui merci pour ton aide !

    Le problème c'est que j'ai bien compris la procédure d'enregistyrement de macro pour récupérer tous les paramètres de mon rectangle.

    En fait j'ai une 30 aine de rectangle chacun avec une couleur et motifs différents.

    J'ai une macro assigné pour tous les rectangles (1 à 30).

    Et je voudrais que cette macro récupere les paramètres du rectangle cliqué pour les transférer vers un autre rectangle que j'aurais dessiné préalablement (et qui est blanc à l'origine).

    Ceci pourra éviter de faire une macro pour chaque rectangle de couleur et de motif spécifique ... : (on évite tout ca :)
    Sub Rectangle1_QuandClic()
    ...
    End Sub

    Sub Rectangle2_QuandClic()
    ...
    End Sub
    ...
    ...
    ...
    Sub Rectangle29_QuandClic()
    ...
    End Sub
    Sub Rectangle30_QuandClic()
    ...
    End Sub

    Comme ca je n'ai qu'une macro qui récupere le nom du rectangle cliqué qui récupere la couleur et le motif de ce rectangle et qui permet de colorier un autre rectangle grace à ces paramètres récupérés ...

    Ca doit pas être bien compliqué pourtant ??? Mais trop pour moi pour l'instant.

    Merci à tous et surtout à Amigo :)
    1
  4. Yopboy
     
    Cool, est ce que qqn aurait les termes à utiliser pour récupérer non pas le nom, mais la position et les dimensions de mon rectangle de la même manière?
    0