Gliser-déposer avec plusieurs listes

Programmation d'applications complexes
Avatar de l’utilisateur
Micoute
Messages : 2522
Inscription : dim. 02/oct./2011 16:17
Localisation : 35520 La Mézière

Gliser-déposer avec plusieurs listes

Message par Micoute »

Bonjour à tous,

bien que ce soit un jeu que j'ai créé pour mes petits enfants, j'ai préféré le placer dans les applications.

Ayant solliciter votre aide bienveillante, je me suis auto corrigé et je poste mon travail

Code : Tout sélectionner

; Les mots avec le son [o] : o, au, eau

EnableExplicit

Enumeration Fenetres
  #Fenetre_principale
EndEnumeration

Enumeration Gadgets
  #Txt_Titre
  #Txt_Signature
  
  #Lst_Cible_1
  #Lst_Cible_2
  #Lst_Cible_3
  
  #Lst_Source
  
  #Btn_Quitter
  #Btn_Suivant
EndEnumeration

Enumeration Polices
  #Police
  #Police_Gras
EndEnumeration

#Nb_Donnees = 8
#Nb_Series = 4

Global Evenement, i, j, Serie = 1, Texte$, Dim Mot.s(#Nb_Donnees), Dim Verif.b(#Nb_Donnees)

LoadFont(#Police, "Arial Nova", 20)
LoadFont(#Police_Gras, "Arial Nova", 20, #PB_Font_Bold)
SetGadgetFont(#PB_Default, FontID(#Police))

Declare Programme_principal()
Declare Lire_Donnees(Serie)
Declare Compliment(Note.b = 0)

Lire_Donnees(Serie)

Procedure Lire_Donnees(Serie)
  Protected$ Nom, Consonnes, Voyelles
  Select Serie
    Case 1
      Restore S1
    Case 2
      Restore S2
    Case 3
      Restore S3
    Case 4
      Restore S4
  EndSelect
  
  i = 0
  While i <= #Nb_Donnees
    Read$ Mot(i)
    Verif(i) = #False
    i + 1
  Wend
  
  Programme_principal()
EndProcedure

Procedure Valider()    
  i = 0
  While i <= #Nb_Donnees
    
    If Verif(i) = #False
      If GetGadgetItemText(#Lst_Cible_1, i) = Mot(i)
        Verif(i) = #True
        Break
      Else
        i - 1
        Break
      EndIf
      
      If GetGadgetItemText(#Lst_Cible_2, i) = Mot(i)
        Verif(i) = #True
        Break
      Else
        i - 1
        Break
      EndIf
      
      If GetGadgetItemText(#Lst_Cible_3, i) = Mot(i)
        Verif(i) = #True
        Break
      Else
        i - 1
        Break
      EndIf
    EndIf 
    i + 1
  Wend
EndProcedure

Procedure Verifier_mot(Texte$)
  Protected Resultat$, Place, Mot$
  
  Mot$ = Texte$
  
  If FindString(Texte$, "eau", 1)
    DragPrivate(3)
  ElseIf FindString(Texte$, "au", 1)
    DragPrivate(2)
  ElseIf FindString(Texte$, "o", 1) Or FindString(Texte$, "ô", 1)
    DragPrivate(1)
  EndIf
EndProcedure

Procedure Suivant()
  Select EventType()
    Case #PB_EventType_LeftClick
      If Serie < #Nb_Series
        Serie + 1
        Lire_Donnees(Serie)
      Else
        HideGadget(#Btn_Suivant, #True)  
      EndIf
  EndSelect    
EndProcedure

Procedure Quitter()
  Select EventType()
    Case #PB_EventType_LeftClick
      CloseWindow(#Fenetre_principale)
      End
  EndSelect    
EndProcedure

Procedure Programme_principal()
  If OpenWindow(#Fenetre_principale, 0, 0, 670, 570, "", #PB_Window_BorderLess | #PB_Window_ScreenCentered)
    TextGadget(#Txt_Titre, 20, 20, 670, 40, "Les mots avec le son [o] : o, au, eau", #PB_Text_Center)
    
    ListIconGadget(#Lst_Cible_1, 20, 70, 150, 390, "o", 145)
    ListIconGadget(#Lst_Cible_2, 180, 70, 150, 390, "au", 145)
    ListIconGadget(#Lst_Cible_3, 340, 70, 150, 390, "eau", 145)
    
    ListIconGadget(#Lst_Source, 500, 70, 150, 390, "o, au, eau", 145)
    
    TextGadget(#Txt_Signature, 20, 460, 670, 40, "Ce logiciel a été conçu et réalisé par Micoute", #PB_Text_Center)
    
    ButtonGadget(#Btn_Quitter, 10, 510, 200, 40, "Quitter")
    ButtonGadget(#Btn_Suivant, 450, 510, 200, 40, "Suivant")
    
    ;remplir la liste source
    i = 0
    While i <= ArraySize(Mot())
      AddGadgetItem(#Lst_Source, i, Mot(i))
      i + 1
    Wend
    
    ; Activer maintenant le transfert sur les gadgets cibles
    EnableGadgetDrop(#Lst_Cible_1, #PB_Drop_Private, #PB_Drag_Copy, 1)
    EnableGadgetDrop(#Lst_Cible_2, #PB_Drop_Private, #PB_Drag_Copy, 2)
    EnableGadgetDrop(#Lst_Cible_3, #PB_Drop_Private, #PB_Drag_Copy, 3)
    
    ;Polices
    SetGadgetFont(#Txt_Titre, FontID(#Police_Gras))
    SetGadgetFont(#Txt_Signature, FontID(#Police_Gras))
    SetGadgetFont(#Btn_Quitter, FontID(#Police_Gras))
    
    ;événements liés
    BindGadgetEvent(#Btn_Quitter, @Quitter())
    BindGadgetEvent(#Btn_Suivant, @Suivant())
  EndIf
EndProcedure

;-boucle
Repeat
  Evenement = WaitWindowEvent()
  
  ; L'événement DragStart sur les gadgets sources, initie un glisser-déposer
  If Evenement = #PB_Event_Gadget And EventType() = #PB_EventType_DragStart
    
    Select EventGadget()
      Case #Lst_Source
        Texte$ = GetGadgetItemText(#Lst_Source, GetGadgetState(#Lst_Source))
        Verifier_mot(Texte$) 
        Debug GetGadgetState(#Lst_Source)  
    EndSelect
    
    ; L'événement de dépose sur les gadgets cibles, reçoit les données déposées
  ElseIf Evenement = #PB_Event_GadgetDrop
    Select EventGadget()
        
      Case #Lst_Cible_1
          AddGadgetItem(#Lst_Cible_1, -1, Texte$)
        
      Case #Lst_Cible_2
          AddGadgetItem(#Lst_Cible_2, -1, Texte$)
        
      Case #Lst_Cible_3
          AddGadgetItem(#Lst_Cible_3, -1, Texte$)
        
        Valider()
    EndSelect
    
  EndIf
  
Until Evenement = #PB_Event_CloseWindow

DataSection
  S1:
  Data$ "cochon", "haut", "sceau", "botte", "veau", "faute", "pauvre", "bureau", "gros"
  S2:
  Data$ "anneau", "enclos", "capot", "peau", "judo", "aube", "préau", "joyau", "faucon"
  S3:
  Data$ "galop", "étau", "cadeau", "kimono", "vélo", "noyau", "fléau", "beau", "aubois"
  S4:
  Data$ "gauche", "tuyau", "ciseau", "Meaux", "sirop", "copine", "beau", "faux", "rôti"
EndDataSection
Microsoft Windows 10 Famille 64 bits : Carte mère : ASRock 970 Extreme3 R2.0 : Carte Graphique NVIDIA GeForce RTX 3080 : Processeur AMD FX 6300 6 cœurs 12 threads 3,50 GHz PB 5.73 PB 6.00 LTS (x64)
Un homme doit être poli, mais il doit aussi être libre !
Avatar de l’utilisateur
Ar-S
Messages : 9472
Inscription : dim. 09/oct./2005 16:51
Contact :

Re: Gliser-déposer avec plusieurs listes

Message par Ar-S »

tu as vu que l'erreur est impossible ? On ne peut pas lacher un mot sur la mauvaise case...
~~~~Règles du forum ~~~~
⋅.˳˳.⋅ॱ˙˙ॱ⋅.˳Ar-S ˳.⋅ॱ˙˙ॱ⋅.˳˳.⋅
W11x64 PB 6.x
Section HORS SUJET : ICI
LDV MULTIMEDIA : Dépannage informatique & mes Logiciels PB
UPLOAD D'IMAGES : Uploader des images de vos logiciels
Avatar de l’utilisateur
Micoute
Messages : 2522
Inscription : dim. 02/oct./2011 16:17
Localisation : 35520 La Mézière

Re: Gliser-déposer avec plusieurs listes

Message par Micoute »

Tout à fait, mais je vais rendre l'application plus intelligente pour éviter de placer plusieurs fois le même terme.
Microsoft Windows 10 Famille 64 bits : Carte mère : ASRock 970 Extreme3 R2.0 : Carte Graphique NVIDIA GeForce RTX 3080 : Processeur AMD FX 6300 6 cœurs 12 threads 3,50 GHz PB 5.73 PB 6.00 LTS (x64)
Un homme doit être poli, mais il doit aussi être libre !
Répondre