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

Delphi Discussion :

Pourquoi mon Thread ne marche pas ?


Sujet :

Delphi

  1. #1
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 75

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut Pourquoi mon Thread ne marche pas ?
    Bonjour

    j ai 2 questions

    1 - Pourquoi ma méthode pour remplir un TlistView, avec des images est lente, comment l 'optimiser
    2 - vu la lenteur, j ai voulu mettre cette methode dans un thread, il y rentre bien dedans, mais rien ne s affiche. POurquoi et comment faire ??

    merci

    voici mon code


    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
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    constructor TThreadJob.Create(CreateSuspended: Boolean);
    begin
      inherited Create(CreateSuspended);
     
      FreeOnTerminate := true;
      Priority := tpNormal; //  TThreadPriority = (tpIdle, tpLowest, tpLower, tpNormal, tpHigher, tpHighest, tpTimeCritical);
    end;
     
    procedure TThreadJob.Execute;
    var
      i, iIncrement, iCountImages: integer;
      bmp: TBitmap;
      bmpjpg: TBitmap;
      jpg: TJpegImage;
      sNomImage: string;
      tQuery: TIBQuery;
      bOk: Boolean;
      tampon: TMemoryStream;
    begin
      with FBiblioMultimedia do
        begin
         ListView1.DisableAlign;
          btnDel.Enabled := False;
     
          Label1.Caption := '';
          ImageList1.Clear;
     
          ImageList1.Height := I_TAILLE;
          ImageList1.Width := I_TAILLE;
     
          ListView1.Items.Clear;
          ListView1.Clear;
          iIncrement := 0;
     
          tQuery := TIBQuery.Create(FBiblioMultimedia);
          tQuery.Database := dm.ibd_BASE;
          tQuery.Transaction := dm.IBT_BASE;
          tQuery.Close;
          tQuery.SQL.Clear;
          tQuery.SQL.Add(lsSQL);
     
          tQuery.DisableControls;
          tQuery.Params[0].AsInteger := dm.NumDossier;
          tQuery.Open;
          tQuery.Last;
          tQuery.First;
     
          iCountImages := tQuery.RecordCount;
     
          if iCountImages <= 0 then
            begin
              tQuery.close;
              tQuery.EnableControls;
              tQuery.Free;
              exit;
            end;
     
          SetLength(tNameImage, iCountImages);
          SetLength(tClefImage, iCountImages);
     
          while not tQuery.Eof do
            begin
              bOk := False;
     
              sNomImage := tQuery.FieldByName('MULTI_PATH').asstring;
              tNameImage[iIncrement] := sNomImage;
              tClefImage[iIncrement] := tQuery.FieldByName('MULTI_CLEF').AsInteger;
     
              Inc(iIncrement);
     
              jpg := TJpegImage.Create;
              bmp := TBitmap.Create;
              bmpjpg := TBitmap.Create;
     
              Tampon := TMemoryStream.Create;
              TBlobField(tQuery.FieldByName('MULTI_REDUITE')).SaveToStream(tampon);
              tampon.Seek(0, soFromBeginning);
              jpg.LoadFromStream(tampon);
     
              tampon.Destroy;
     
              if (jpg.Width > I_TAILLE) or (jpg.Height > I_TAILLE) then
                if (jpg.Width > 500) or (jpg.Height > 400) then
                  jpg.Scale := jsEighth;
     
              if tQuery.FieldByName('MULTI_IMAGE_RTF').AsInteger < 1 then
                begin
                  if (jpg.Width > I_TAILLE) or (jpg.Height > I_TAILLE) then
                    ResizeJpg2bmp(jpg, bmp, I_TAILLE)
                end
              else
                ResizeJpg2bmp(jpg, bmp, 36);
     
              CentreDansBmpCtr(bmp);
              ImageList1.Add(bmp, nil);
     
              bmp.Free;
              jpg.Free;
              bmpjpg.Free;
     
              tQuery.next;
            end;
     
          tQuery.Close;
          tQuery.EnableControls;
          tQuery.Free;
     
          btnSelection.Enabled := iIncrement > 0;
     
          if iIncrement > 0 then
            begin
              with ListView1 do
                begin
                  with Columns.Add do
                    begin
                      Caption := 'Image';
                      Autosize := True;
                      Alignment := taLeftJustify;
                    end;
                  with Columns.Add do
                    begin
                      Caption := 'Nom';
                      Autosize := True;
                      Width := 500;
                    end;
     
                  for i := 0 to iIncrement - 1 do
                    begin
                      with Items.Add do
                        begin
                          Caption := ExtractFileName(tNameImage[i]);
                          SubItems.Add(tNameImage[i]);
                          ImageIndex := i; // numéro de l'image dans ImageList1
                        end;
                    end;
                end;
     
              ListView1.ItemIndex := 0;
            end;
     
          btnDel.Enabled := ListView1.Items.Count > 0;
          ListView1.EnableAlign;
     
         //showmessage('oui');
          if ListView1.Items.Count > 0 then
            begin
              ibMajMultimedia.Close;
              ibMajMultimedia.Params[0].AsInteger := dm.NumDossier;
              ibMajMultimedia.Open;
     
              ListView1.Items[ListView1.Items.Count - 1].Selected := True;
              ListView1Click(Self);
            end;
     
        end;
     
      // -- On tue le thread -------------------
      Terminate;
    end;

  2. #2
    Membre chevronné
    Avatar de Clorish
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 474
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 474
    Points : 2 158
    Points
    2 158
    Par défaut
    LEs acces a la VCL ne peuvent etre fait que depuis le thread Principal.
    Il faut donc implementer une methode qui manipule la VCL et y faire appel a l'aide de la methode "synchronize" du thread et non directement depuis la methode "execute" du thread, seulle methode reelement threadée.

  3. #3
    Expert éminent sénior

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Points : 10 154
    Points
    10 154
    Par défaut
    Pour l'optimiser, tu pourrais au moins voir s'il n'y a pas un méthode BeginUpdate/EndUpdate dans le TreeView ou dans les TreeNodes. Souvent, un simple encadrement d'un long remplissage de contrôle visuel par ces méthodes accélère considérablement la vitesse

  4. #4
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 75

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    Il faut donc implementer une methode qui manipule la VCL et y faire appel a l'aide de la methode "synchronize" du thread et non directement depuis la methode "execute" du thread, seulle methode reelement threadée.
    Pourrais tu m expliquer, ou un petit exemple de code

    je n ai jamais utiliser de thread

  5. #5
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 75

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    BeginUpdate/EndUpdate
    Y a pas ces methodes dans le listview

  6. #6
    Membre chevronné
    Avatar de Clorish
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    2 474
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 2 474
    Points : 2 158
    Points
    2 158
    Par défaut
    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
     
    TForm1 = Class...
    Public
      Procedure UpateTreeView;
    End;
     
    Var Form1 : TForm1;
     
    TMonThread = Class(TThread)
    Public
      Procedure Execute; Override;
    End;
     
    Procedure TMonThread.Execute;
    Begin
    [...]
    Self.Synchronize(Form1.UpdateTreeView);
    [...]
    End;

  7. #7
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 75

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    Merci

    mais dois je laisser mon code de remplissage de Listview dans le thread.execute ?
    ou je le sors du thread pour le mettre dans la methode UpdateListView

  8. #8
    Expert éminent sénior

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Points : 10 154
    Points
    10 154
    Par défaut
    Ton thread doit préparer dans des variables d'instance ce qu'il va falloir ajouter à la list view. Et puis dans UpdateListView tu utilises ces variables d'instances pour faire un AddItem ou ce que tu veux d'autre.

  9. #9
    Membre extrêmement actif Avatar de Cazaux-Moutou-Philippe
    Inscrit en
    Mai 2005
    Messages
    674
    Détails du profil
    Informations personnelles :
    Âge : 75

    Informations forums :
    Inscription : Mai 2005
    Messages : 674
    Points : 171
    Points
    171
    Par défaut
    Merci

    Mais avec mon code en boucle, je ne comprends pas trop comment faire

  10. #10
    Expert éminent sénior

    Avatar de sjrd
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Juin 2004
    Messages
    4 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Suisse

    Informations professionnelles :
    Activité : Directeur de projet
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2004
    Messages : 4 517
    Points : 10 154
    Points
    10 154
    Par défaut
    Eh bien ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    for i := 0 to iIncrement - 1 do
    begin
      with Items.Add do
      begin
        Caption := ExtractFileName(tNameImage[i]);
        SubItems.Add(tNameImage[i]);
        ImageIndex := i; // numéro de l'image dans ImageList1
      end;
    end;
    Tu remplaces par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for i := 0 to iIncrement - 1 do
    begin
      ItemCaption := ExtractFileName(tNameImage[i]);
      ItemImgName := tNameImage[i];
      ItemImgIndex := i; // numéro de l'image dans ImageList1
      Synchronize(AddLineToListView);
    end;
    avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    procedure TThreadJob.AddLineToListView;
    begin
      with ListView1.Items.Add do
      begin
        Caption := ItemCaption;
        SubItems.Add(ItemImgName);
        ImageIndex := ItemImgIndex;
      end;
    end;
    Un truc dans ce genre-là.

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

Discussions similaires

  1. [AC-2007] pourquoi mon code ne marche pas
    Par erebios dans le forum VBA Access
    Réponses: 16
    Dernier message: 04/05/2010, 23h43
  2. diaporama: pourquoi mon code ne marche pas
    Par secondechance dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 01/05/2009, 02h04
  3. [MASM] Pourquoi mon *.exe ne marche pas ?
    Par link25000 dans le forum x86 16-bits
    Réponses: 1
    Dernier message: 24/04/2009, 23h57
  4. Pourquoi mon script ne marche pas ?
    Par chrifus dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 28/05/2008, 18h04
  5. Pourquoi mon script ne marche pas?
    Par amarcil dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 30/05/2006, 21h37

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