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 :

Userform - Parcourir les frames


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Février 2011
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2011
    Messages : 11
    Par défaut Userform - Parcourir les frames
    Bonjour à tous,

    J'utilise ce code pour parcourir des Frames et voir si un choix a été fait dans les boutons option (si ce n'est pas le cas j'encadre le Frame en rouge)

    La structure de mon userform est Userform > Frame_meca > Frame2 > Boutons.

    Frame_meca contient une dizaine de Frames sur lesquels je boucle et qui contiennent chacun des boutons options

    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
    Public Sub val_vide()
    Dim Frame_test
    Dim ole1 As Control
    Dim ole2 As Control
    
            For Each ole1 In Me.Frame_meca.Controls
                If Left(ole1.Name, 5) = "Frame" Then
                    If ole1.Visible = True Then
                        Frame_test = ole1.Name
                        coche = ""
    
                        For Each ole2 In Me.Frame_meca.Controls
                               If ole2.Container.Name = Frame_test Then
                                If (TypeOf Ctrl Is OptionButton) Then
                                    If ole2.Value = True Then
                                       coche = "ok"
                                    End If
                                End If
                            End If
                        Next
                        If coche <> "ok" Then
                            ole1.BorderColor = &HFF&
                            ole1.BorderStyle = 1
                        Else
                            ole1.SpecialEffect = 3
                        End If
                    End If
                End If
            Next
    End Sub
    Je bloque donc sur la ligne de code en rouge, mes différents essais de syntaxe étant restés vains.

    Merci d'avance pour votre aide.

  2. #2
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 122
    Par défaut
    Salut

    Peut-être
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    If ole2.Name = Frame_test Then
    J'avoue ne pas tout avoir saisi de la logique du code mais toujours est-il que l'objet "control" n'a pas de membre "container", donc je suppose que c'est ce qui crée l'erreur (intitulé du message d'erreur ?).

    ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Février 2011
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2011
    Messages : 11
    Par défaut
    Bonjour,

    Frame_test = ole1.Name, j'aimerais boucler ensuite sur ce Frame de cette manière :

    For Each ole2 In Me.Frame_meca.Frame_test.Controls mais hélas cela ne marche pas

    ++

  4. #4
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 122
    Par défaut
    SAlut

    Je ne comprends pas la finalité, peux-tu mettre un fichier demo ?

    [Edit]
    ahh
    Tu veux boucler sur les "controls" contenu dans le frame ayant le nom contenu dans la frame Frame_Teste ?
    [/Edit]

    [Edit2]
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    For Each ole2 In Me.Frame_meca.Controls(Frame_Test).controls
    Mais à mon avis il y a des solutions plus simple, je n'en suis pas certain n'ayant pas la structure sous les yeux mais j'en ai le sentiment.

    [/Edit2]
    ++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Février 2011
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2011
    Messages : 11
    Par défaut
    Exactement

    Je cherche à boucler dans les Frames contenu dans le Frame "Frame_meca" pour vérifier si un choix a été fait.

    Nom : frame.jpg
Affichages : 1362
Taille : 226,4 Ko

    ok ça marche nickel. Voici le code fonctionnel après une première simplification. Je suis ouvert à tout autre idée

    Merci beaucoup !

    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
     
    Public Sub val_vide()
    Dim ole1 As Control
    Dim ole2 As Control
     
     
            For Each ole1 In Me.Frame_meca.Controls
                S = ole1.Name
                If Left(ole1.Name, 5) = "Frame" Then
                    If ole1.Visible = True Then
                        coche = ""
                        For Each ole2 In Me.Frame_meca.Controls(ole1.Name).Controls
                            If (TypeOf ole2 Is OptionButton) Then
                                If ole2.Value = True Then
                                   coche = "ok"
                                End If
                            End If
                        Next
                        If coche <> "ok" Then
                            ole1.BorderColor = &HFF&
                            ole1.BorderStyle = 1
                        Else
                            ole1.BorderStyle = 0
                            ole1.BorderColor = &H80000012
                            ole1.SpecialEffect = 3
                        End If
                    End If
                End If
            Next
    End Sub

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

Discussions similaires

  1. Userform parcourir les contrôles (optionbuttons)
    Par HoWeR dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 07/05/2009, 08h09
  2. [VB.NET] Parcourir les attributs d'une classe
    Par pasqwal dans le forum Windows Forms
    Réponses: 3
    Dernier message: 15/02/2005, 09h47
  3. Son dans les frames
    Par mr.t dans le forum Interfaces Graphiques en Java
    Réponses: 7
    Dernier message: 03/01/2005, 16h29
  4. [Débutant] Dialogue Java entre les frames pour client HTML
    Par Carrel dans le forum Général Java
    Réponses: 4
    Dernier message: 03/06/2004, 10h39
  5. Utiliser les frames
    Par laury dans le forum Composants VCL
    Réponses: 5
    Dernier message: 10/05/2003, 10h14

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