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 :

Désactiver bouton option [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 215
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 215
    Par défaut Désactiver bouton option
    Bonjour,

    J'ai créé un quizz de 27 questions avec pour chacune d'entre elles quatre cases d'option. Chacun de ce groupe de 4 cases est délimiter dans une zone de groupe.
    Je voudrais qu'à l'ouverture de l'onglet "Quizz", que toutes les cases d'option soient désactivées.

    J'ai essayé en déclenchant une nouvelle macro puis en sélectionnant le 1er groupe des 4 cases d'option, puis le 2ème et ainsi de suite jusqu'au 3ème mais lorsque je déclenche cette macro, j'ai un bug sur la ligne 38 ".Value = xlOff " avec le message suivant :
    Impossible de définir la propriété Value de la classe DrawingObjects.
    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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    Sub Macro3()
    '
    ' Macro3 Macro
        ActiveSheet.Shapes.Range(Array("Option Button 1")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2")). _
            Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            )).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            , "Option Button 151")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            , "Option Button 151", "Option Button 152")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            , "Option Button 151", "Option Button 152", "Option Button 154")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            , "Option Button 151", "Option Button 152", "Option Button 154", _
            "Option Button 155")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            , "Option Button 151", "Option Button 152", "Option Button 154", _
            "Option Button 155", "Option Button 156")).Select
        ActiveSheet.Shapes.Range(Array("Option Button 1", "Option Button 2", _
            "Option Button 3", "Option Button 4", "Option Button 149", "Option Button 150" _
            , "Option Button 151", "Option Button 152", "Option Button 154", _
            "Option Button 155", "Option Button 156", "Option Button 157")).Select
        With Selection
            .Value = xlOff
            .LinkedCell = ""
            .Display3DShading = True
        End With
        Range("A1").Select
    End Sub

  2. #2
    Membre extrêmement actif Avatar de mjpmjp
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2012
    Messages
    1 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hautes Alpes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2012
    Messages : 1 133
    Par défaut
    bonjour,
    les options button inter agissent entre eux (par groupe...de 4 ?),

    peut être avec un peu de magie ... ( et de la stratégie ?)

    je te propose cette solution
    1) tu met un 5° option button (invisible) par groupe, c'est lui que tu sélectionne --> ce qui désélectionne les 4 autres
    2) tu nommes style "OB1..à OB27"
    3) tu utilise une boucle qui sélectionne les controles("OB" & n)

    @+JP
    Caractéristiques (WEB) phpMyAdmin 4-74 , PHP 5-631 , Apache 2-427 , MySQL 5-719
    Présentation NAS DS-3615xs + 20Go , DSM 6.1.6-15266 Up1 , 12 * WD 4To WD4000F9YZ (10 raid 6+ )+(2 raid 1+) , LinkSys comutateur-switch lgs528p-eu , Onduleur UPS 720W Power Boxx Lcd (4*UPS + 4*MOD)
    Mes contributions (EXCEL) Form GRAPHIQUE: Gestion des boutons , Liste Onglet dynamique...GESTION de FILM

  3. #3
    Membre extrêmement actif Avatar de mjpmjp
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2012
    Messages
    1 133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hautes Alpes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Santé

    Informations forums :
    Inscription : Avril 2012
    Messages : 1 133
    Par défaut
    bonjour,

    Nom : video11.gif
Affichages : 1582
Taille : 103,2 Ko

    la boucle,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Private Sub CommandButton1_Click()
        For n = 1 To 2
            ActiveSheet.OLEObjects("OB" & n).Object.Value = True
        Next n
    End Sub
    Visible,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Private Sub CommandButton2_Click()
        If OB1.Visible = True Then
            OB1.Visible = False
            OB2.Visible = False
        Else
            OB1.Visible = True
            OB2.Visible = True
        End If
    End Sub
    @+JP
    Caractéristiques (WEB) phpMyAdmin 4-74 , PHP 5-631 , Apache 2-427 , MySQL 5-719
    Présentation NAS DS-3615xs + 20Go , DSM 6.1.6-15266 Up1 , 12 * WD 4To WD4000F9YZ (10 raid 6+ )+(2 raid 1+) , LinkSys comutateur-switch lgs528p-eu , Onduleur UPS 720W Power Boxx Lcd (4*UPS + 4*MOD)
    Mes contributions (EXCEL) Form GRAPHIQUE: Gestion des boutons , Liste Onglet dynamique...GESTION de FILM

  4. #4
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    S'agissant de contrôles de formulaire, il faut procéder ainsi.

    Pour un unique OptionButton :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub Macro1()
        ActiveSheet.Shapes("Option Button 1").OLEFormat.Object.Value = -4146
    End Sub
    Pour tous les OptionButton de la feuille active :
    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
    Sub Macro2()
    Dim Shp As Shape
        'pour tous les Shapes de la feuille
        For Each Shp In ActiveSheet.Shapes
            's'il s'agit d'un contrôle de formulaire
            If Shp.Type = msoFormControl Then 'inutile, mais pour montrer que cela existe
                's'il s'agit d'un bouton d'option
                If Shp.FormControlType = xlOptionButton Then
                    's'il est "ON"
                    If Shp.ControlFormat.Value = 1 Then
                        'on le mets "OFF"
                        Shp.ControlFormat.Value = -4146
                    End If
                End If
            End If
        'suivant...
        Next Shp
    End Sub

  5. #5
    Membre éprouvé Avatar de graphikris
    Homme Profil pro
    Pas tres doué
    Inscrit en
    Décembre 2012
    Messages
    1 215
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Pas tres doué
    Secteur : Conseil

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 215
    Par défaut
    Bonjour et merci à vous deux.
    Néanmoins la solution de Pijaku me semble la plus appropriée à mon souci.


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

Discussions similaires

  1. [VB]Désactivation de boutons options
    Par frevale dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 21/03/2006, 20h07
  2. bouton option ou case a ccocher
    Par zouille dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 20/12/2005, 21h10
  3. Désactivation bouton = formulaire non soumis
    Par Gwipi dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 31/05/2005, 16h11
  4. [HTML][Select]désactiver une option sous IE ?
    Par tiPouick dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 05/11/2004, 12h13
  5. Réponses: 8
    Dernier message: 24/07/2003, 10h45

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