XL 2016 Gestion et placement de photos avec le nom

Webperegrino

XLDnaute Impliqué
Supporter XLD
Bonjour Le Forum,

Dans la petite application ci-jointe j’ai réussi à faire parfaitement fonctionner deux macros commandées par les deux boutons « Place à l’unité » et « Efface tout » jouant dans le pavé B2:J26.

Pour la troisième macro, quant à elle liée au bouton central « PLACE TOUT », je ne peux la faire fonctionner convenablement :

  • Je dois l’arrêter avec un blocage de fonctionnement en boucle tant que je n’actionne pas "Ctrl + Pause" pour sortir de la macro
  • Une seule et première photo se place partout dans ce pavé B2 :J26, au lieu de placer les suivantes, une à une et selon l’ordre positionné dans un dossier voisin « TROMBINOSCOPE » contenant les photos ou images.
Merci d’avance à celui qui pourra corriger cette troisième macro ; j'y suis depuis quatre jours et je bloque désespérément...

Webperegrino
 

Pièces jointes

  • LE TROMBINOSCOPE 2023.xlsm
    42.7 KB · Affichages: 5
  • TROMBINOSCOPE.zip
    274.3 KB · Affichages: 6
Solution
Salut, dans le classeur joint:
Module ThisWorkBook pour renseigner la variable de classeur PhotoDir :
VB:
Private Sub Workbook_Open()
    Do While Dir([PhotoDir]) = ""
        Set Fd = Application.FileDialog(msoFileDialogFolderPicker)
        With Fd
            .AllowMultiSelect = False
            .Filters.Clear
            .Title = "Sélection du dossier des Photos"
            .InitialFileName = [PhotoDir]
            If .Show = -1 Then
                Names("PhotoDir").RefersToR1C1 = .SelectedItems(1) & "\"
            Else
                ThisWorkbook.Close False
            End If
        End With
        Set Fd = Nothing
    Loop
End Sub
1675267893223.png

Modification dans Feuil1 de la sub CommandButton2_Click
VB:
Private Sub...

fanch55

XLDnaute Barbatruc
Salut, dans le classeur joint:
Module ThisWorkBook pour renseigner la variable de classeur PhotoDir :
VB:
Private Sub Workbook_Open()
    Do While Dir([PhotoDir]) = ""
        Set Fd = Application.FileDialog(msoFileDialogFolderPicker)
        With Fd
            .AllowMultiSelect = False
            .Filters.Clear
            .Title = "Sélection du dossier des Photos"
            .InitialFileName = [PhotoDir]
            If .Show = -1 Then
                Names("PhotoDir").RefersToR1C1 = .SelectedItems(1) & "\"
            Else
                ThisWorkbook.Close False
            End If
        End With
        Set Fd = Nothing
    Loop
End Sub
1675267893223.png

Modification dans Feuil1 de la sub CommandButton2_Click
VB:
Private Sub CommandButton2_Click() 'Tout placer
Dim Row As Integer, Col As Integer
Dim File As Variant, Fso As Object
Application.ScreenUpdating = False
    CommandButton3_Click
    [A3] = 0
    Set Fso = CreateObject("Scripting.FileSystemObject")
        Row = 3
        Col = Columns("B").Column
        For Each File In Fso.GetFolder([PhotoDir]).Files
            If File.Name Like "*.jpg" Then
                [A3] = [A3] + 1
                Cells(Row, Col) = Fso.getBasename(File)
                PlaceThePictureInCenterRange Cells(Row - 1, Col), Shapes.AddPicture(File, False, True, 20, 20, -1, -1), 90
                If Col = Columns("J").Column Then
                    Col = 2: Row = Row + 3
                Else
                    Col = Col + 2
                End If
            End If
        Next
    Set Fso = Nothing ' Libération mémoire
End Sub

End Sub
 

Pièces jointes

  • LE TROMBINOSCOPE 2023.xlsm
    207.2 KB · Affichages: 9
Dernière édition:

Membres actuellement en ligne

Statistiques des forums

Discussions
314 499
Messages
2 110 249
Membres
110 711
dernier inscrit
chmessi