Rechercher : dans
Par :

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

Dernière réponse le 26 nov 2009 à 12:48:48 ridertart, le 18 fév 2008 à 11:39:33 
 Signaler ce message aux modérateurs

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

Meilleures réponses pour « Excel & VB Récupérer le nom objet cliqué » dans :
[Excel] Chemin et nom de stockage de feuille de calcul VoirIndiquer automatiquement le chemin d'accès (path) et le nom de stockage de toute feuille de calcul Noter dans une cellule (A& par exemple) la formule : =cellule("nomfichier";A1) A chaque sauvegarde et/ou déplacement de fichier dans votre...
Objet FileSystemObject (FSO) VoirFileSystemObject L'objet FileSystemObject (FSO) permet de manipuler le système de fichiers de Windows. L'utilisation du modèle d'objet FileSystemObject s'effectue en créant une instance de l'objet Scripting.FileSystemObject l'intermédiaire de la...
Fichier BRIBE VoirFormat BRIBE Un document bribe est une partie d'un document Word, d'une feuille de calcul Excel ou d'une présentation Powerpoint qui a été glissée-déposée sur le bureau de Windows. Il peut s'agir d'une partie de texte, d'un objet, d'une image ou...

1

amigo, le 18 fév 2008 à 16:52:40

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.

Répondre à amigo

4

ridertart, le 25 fév 2008 à 15:42:57

As tu une réponse qui pourrait m'aider ?

Répondre à ridertart

2

ridertart, le 21 fév 2008 à 10:16:50
  • +1

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 :)

Répondre à ridertart

5

Willy, le 1 avr 2008 à 10:53:17

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 !

Répondre à Willy

6

 Foxter, le 26 nov 2009 à 12:48:48

Merci beaucoup !!!

Répondre à Foxter
Collection CommentÇaMarche.net