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

Composants FMX Delphi Discussion :

TListView/Livebindings quand il y a beaucoup de lignes


Sujet :

Composants FMX Delphi

  1. #1
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 029
    Points : 40 927
    Points
    40 927
    Billets dans le blog
    62
    Par défaut TListView/Livebindings quand il y a beaucoup de lignes
    Bonjour,
    Comme écrit quelque part dans la doc, il faut un nombre "raisonnables" de lignes mais, bon, ce n'est pas toujours possible.

    Je me retrouve avec quelques extractions de données de quelques 5000 lignes et, bien évidemment, le remplissage prends du temps.

    Quelle solution utilisez-vous dans ce genre de cas ?

    Pour pallier mon problème j'ai utilisé un TListView identique lié à une requête qui n'extrait qu'un nombre très limité de lignes pour ensuite continuer le remplissage de la "vraie" liste via un Thread
    un rectangle, contenant entre autres un TAniIndicator me permettant de montrer que le travail continue
    Nom : Capture.PNG
Affichages : 96
Taille : 78,3 Ko
    un thread se charge de la gestion de ces composants
    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
    procedure TMain.LoadArticles;
    begin
    ThreadA_Active:=True;
    ListeVArticles.BeginUpdate;
    ThreadA:=
      TTask.Run( procedure
      begin
       TThread.Synchronize(TThread.Current,
                  procedure
                  begin
                    WaitForLp.Visible := True;
                    Aniwaitforlp.Enabled := True;
                  end);
        Datas.ImgArticles.DisableControls;
        Datas.ImgArticles.Open;
        TThread.Synchronize(TThread.Current,
                  procedure
                  begin
                    Datas.PremiersArticles.Close;
                    ListePremiers.Visible:=False;
                    WaitForLp.Visible := False;
                    Aniwaitforlp.Enabled := False;
                    Datas.imgArticles.EnableControls;
                    ListeVArticles.EndUpdate;
                    ThreadA_Active:=False;
                  end);
      end);
    end;
    ce qui ne me plait pas : le fait d'avoir deux TListView, et deux sources de données différentes.
    J'ai tenté les approches des Fetchoptions de Firedac (Rowsetsize, LiveWindowFastFirst) mais la liaison via LievBindings semble se contrefiche de ces indications contrairement à un TGrid (ce n'est pas la première fois que je le déplore).

    J'ai encore une piste non explorée (totalement oubliée jusqu'à ce que j'écrive ce post) : FecthOptions.Recsmax.

    Sinon, ma question, comment faites-vous dans un cas pareil ?
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  2. #2
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 447
    Points : 24 846
    Points
    24 846
    Par défaut
    J'ai eu un peu ce problème, pas en FMX mais en VCL

    Faire un remplissage incrémental d'une TListView n'est pas aisée effectivement en VCL,
    faudrait conserver ta TListView pour afficher juste la page de données courante, désactiver la scrollBar automatique et ajouter une scrollbar manuellement, en fait lors du défilement, tu vides la TListView et tu la remplis avec le contenu de la page à partir de la nouvelle position, en fait comme une TDBGrid
    C'est ce que j'ai fait en VCL

    Voir si en FMX c'est possible aussi mais pour le LiveBindings, ça doit être la merde cependant, il y a peut-être une astuce
    Tu as ta source de données completes à 5000 lignes, est-il possible en LiveBindings de récupérer dans uen autre source de données qu'un fragment genre un filter RecNo à RecNo +20 et connecter la TListview de fenêtrage.
    La scrollBar étant est lié sur la source complète pour gérer le défilement de 1 à 5000 qui repercuter dans la source de fenêtrage.

    Je suis tellement habitué à tout faire via du code, j'ignore comme on peut chainer les LiveBindings,
    Je vois cela un peu comme une fausse relation Maitre\Detail, le Maitre c'est la source complète, le Détail c'est le fenêtrage.
    Peut-être conserver deux sources mais un seul TListView
    La source des 5000, une source table mémoire rempli lors du OnScroll sur les 5000 qui n'en copie que 20, le TListView braché sur la table mémoire, le scrollBar indépendant toujours connecté sur les 5000.


    Pour un TTreeView devant contenir 500 000 items, j'ai laissé tomber le remplissage complet, comme il y avait 7 origines, j'ai ajouté un TabSheet par origine
    Je ne charge que le niveau 1, j'ouvre le niveau 2 et 3 du premier noeud
    Le reste des niveaux 1 reste replier et c'est rempli à la volée sur OnExpand


    Après, si c'est une application mobile, le concept de pagination comme pour le web peut être une solution, on voit bcp de site web qui gère des simples bouton pages avant\arrière, quelques rares gère une liste incrémentales qui s'agrandit lorsque l'on défile jusqu'à la fin
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  3. #3
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 029
    Points : 40 927
    Points
    40 927
    Billets dans le blog
    62
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    Faire un remplissage incrémental d'une TListView n'est pas aisée effectivement en VCL,
    Oui, c'est un peu le même principe

    En fait, le système de pagination j'ai essayé et c'est un peu ce que je fais avec la solution que j'utilise.
    Mais un système de pagination n'est pas compatible avec la possiblité de faire une recherche (TSearchBox) nécessitant que tous les élements soient dans la liste.
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  4. #4
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 447
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 447
    Points : 24 846
    Points
    24 846
    Par défaut
    Si la donnée est entièrement en mémoire, la pagination n'est pas un problème pour la Recherche

    Tu fais la recherche en mémoire de la ligne parmi les 5000,
    une fois trouvée, tu calcules la fenêtre à afficher,
    selon les capacités de LiveBinding, tu sélectionnes\recopies dans le tampon la fenêtre pour qu'elle soit affiché dans le TListView

    Rappel le TListView ne contient que la fenêtre d'enregistrement jamais les 5000 mais uniquement ce qui est visible (entièrement visible pas de demi-ligne)
    Couplé à la ScrollBar, celle-ci est recalé sur la fenêtre ... d'ailleurs avec la chaine des OnChange, OnScrol et je ne sais quoi, la recherche pourrait juste retourner la fenêtre, déplacer le curseur dans la ScrollBar qui se chargera par ricochet de récupérer la fenêtre, puis ensuite la recherche sélectionne l'item parmi ceux de la fenêtre.

    Encore une fois, j'ignore ce que LiveBinding permet, faisant tout en code, tout ça me semble simple quand on maitrise tous les tampons et les gestionnaires d'évènement


    Si tu veux remplir réellement le TListView sans un système de fenêtrage, là oui le coût d'ajout des lignes juqu'à l'élément recherché, si l'on cherchait le dernier revient à tout charger
    Tout cela est contre-performant car au final, tu as toutes les données une fois en mémoire et une seconde fois dans le controle.
    Mais je pense avec une logique où les listings étaient à 1 000 000 sur une base de 1 000 000 000 d'enregistrement inséré par an
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  5. #5
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 029
    Points : 40 927
    Points
    40 927
    Billets dans le blog
    62
    Par défaut
    Le FMX.Listview est très différent du VCL.ListView
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

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

Discussions similaires

  1. traitement des données, quand y en a beaucoup
    Par nine dans le forum Contribuez / Téléchargez Sources et Outils
    Réponses: 26
    Dernier message: 22/11/2017, 13h43
  2. Conseils quand il y a beaucoup de RIGHT JOIN
    Par rstck dans le forum Langage SQL
    Réponses: 3
    Dernier message: 28/02/2012, 12h39
  3. Indiquer un classpath quand on exécute un jar en ligne de commande
    Par WerKa dans le forum Débuter avec Java
    Réponses: 8
    Dernier message: 30/04/2008, 11h28
  4. Réponses: 0
    Dernier message: 29/04/2008, 17h19
  5. Réponses: 12
    Dernier message: 09/02/2008, 14h41

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