Microsoft 365 Utilisation d'un Spinbutton down sur plage filtrée

  • Initiateur de la discussion Initiateur de la discussion Skyna
  • Date de début Date de début

Skyna

XLDnaute Occasionnel
Bonjour,
Je souhaiterais utiliser un spinbutton sur une plage filtrée. Je parviens à le faire en un avec le code suivant :
With ActiveCell
With .Offset(1, 0).Resize(Rows.Count - .Row, 1)
.SpecialCells(xlCellTypeVisible).Cells(1, 1).Select
End With
End With

mais je ne parviens pas à le faire fonctionner en mode filtre avec le down :
With ActiveCell
With .Offset(-1, 0).Resize(Rows.Count - .Row, 1)
.SpecialCells(xlCellTypeVisible).Cells(1, 1).Select
End With
End With

En double cliquant sur une cellule du tableau (du classeur joint) le userform apparaît.

Auriez-vous une solution svp ?

Merci
 

Pièces jointes

mapomme

XLDnaute Barbatruc
Supporter XLD
Bonsoir @Skyna :),

Voir le fichier joint.
VB:
Private Sub SpinButton1_SpinDown()
Dim haut&, col&, depart&, i&
   With Sheets("Feuil1")
      haut = .ListObjects("Tableau1").DataBodyRange.Row
      col = ActiveCell.Column
      depart = ActiveCell.Row - 1
      For i = depart To haut Step -1
         If Rows(i).Hidden = False Then Cells(i, col).Select: Exit Sub
      Next i
   End With
End Sub

Private Sub SpinButton1_Spinup()
Dim bas&, col&, depart&, i&
   With Sheets("Feuil1")
      bas = .ListObjects("Tableau1").DataBodyRange.Row + .ListObjects("Tableau1").DataBodyRange.Rows.Count - 1
      col = ActiveCell.Column
      depart = ActiveCell.Row + 1
      For i = depart To bas Step 1: If Rows(i).Hidden = False Then Cells(i, col).Select: Exit Sub
      Next i
   End With
End Sub
 

Pièces jointes

Dernière édition:

laurent950

XLDnaute Barbatruc
Bonsoir,

Selon le Poste #1

VB:
Option Explicit
Private Sub SpinButton1_SpinDown()
Dim Rgn, Plg, T As Range
    Set Rgn = ActiveCell
    If Rgn.Row > CLng(2) Then
        With Rgn
            Set Plg = .Offset(-.Row + 3, 0).Resize(.Row, 1)
                With Plg
                    Set T = .SpecialCells(xlCellTypeVisible)
                        If T.Areas.Count > 1 Then Cells(T.Areas.Item(T.Areas.Count - 1).Row, .Column).Select
                End With
        End With
    End If
    Set Rgn = Nothing: Set Plg = Nothing: Set T = Nothing
End Sub
' -----------------------------------------------------------------------------------'
Private Sub SpinButton1_SpinUp()
Dim Rgn, Plg, T As Range
    Set Rgn = ActiveCell
    If Rgn.Row < CLng(2) + Cells(65536, 2).End(xlUp).Row Then
        With Rgn
            Set Plg = .Resize(Cells(65536, 2).End(xlUp).Row - .Row, 1)
                With Plg
                    Set T = .SpecialCells(xlCellTypeVisible)
                        If T.Areas.Count > 1 Then Cells(T.Areas.Item(2).Row, .Column).Select
                End With
        End With
    End If
    Set Rgn = Nothing: Set Plg = Nothing: Set T = Nothing
End Sub
 
Dernière édition:

mapomme

XLDnaute Barbatruc
Supporter XLD
Re,

Une version plus "élégante" :
VB:
Private Sub SpinButton1_SpinDown()
   HautBas -1
End Sub

Private Sub SpinButton1_Spinup()
   HautBas 1
End Sub

Sub HautBas(sens&)
Dim bas&, col&, borne1&, borne2&, i&
   With Sheets("Feuil1")
      If .ListObjects("Tableau1").DataBodyRange Is Nothing Then Exit Sub
      borne1 = ActiveCell.Row + sens
      borne2 = IIf(sens = -1, .ListObjects("Tableau1").DataBodyRange.Row, .ListObjects("Tableau1").DataBodyRange.Row + .ListObjects("Tableau1").DataBodyRange.Rows.Count - 1)
      col = ActiveCell.Column
      For i = borne1 To borne2 Step sens
         If Rows(i).Hidden = False Then Cells(i, col).Select: Exit Sub
      Next i
   End With
End Sub
 

Pièces jointes

laurent950

XLDnaute Barbatruc
Bonjour,
Poste #3 en 1 Ligne de code

VB:
Option Explicit
Private Sub SpinButton1_SpinDown()
    If ActiveCell.Offset(-ActiveCell.Row + 3, 0).Resize(ActiveCell.Row, 1).SpecialCells(xlCellTypeVisible).Areas.Count > 1 Then Cells(ActiveCell.Offset(-ActiveCell.Row + 3, 0).Resize(ActiveCell.Row, 1).SpecialCells(xlCellTypeVisible).Areas.Item(ActiveCell.Offset(-ActiveCell.Row + 3, 0).Resize(ActiveCell.Row, 1).SpecialCells(xlCellTypeVisible).Areas.Count - 1).Row, ActiveCell.Offset(-ActiveCell.Row + 3, 0).Resize(ActiveCell.Row, 1).Column).Select
End Sub
' -----------------------------------------------------------------------------------'
Private Sub SpinButton1_SpinUp()
    If ActiveCell.Resize(Cells(65536, 2).End(xlUp).Row - ActiveCell.Row, 1).SpecialCells(xlCellTypeVisible).Areas.Count > 1 Then Cells(ActiveCell.Resize(Cells(65536, 2).End(xlUp).Row - ActiveCell.Row, 1).SpecialCells(xlCellTypeVisible).Areas.Item(2).Row, ActiveCell.Column).Select
End Sub
 

Discussions similaires

Réponses
12
Affichages
545
Réponses
8
Affichages
422
Réponses
6
Affichages
287
Réponses
10
Affichages
700
Réponses
2
Affichages
357
Réponses
3
Affichages
557
Réponses
2
Affichages
403

Statistiques des forums

Discussions
315 290
Messages
2 118 077
Membres
113 423
dernier inscrit
stevolino2