2009-03-30 28 views
3

私は0%から始まり、100%になるまでに5秒かかるプログレスバーを作ろうとしています。ボタン1をクリックするとすぐにプログレスバーが上がり始めます。何かアドバイス?私はGoogleで見ましたが、それは私にこのようなことは何も役に立たなかった。Delphiプログレスバー

0%では、Waiting...というラベルがあります。プログレスバーが始まるとWorking...になり、完了したらDone!と表示されます。

答えて

5

のGetTickCount()を使用して初期化変数:タイマーを使用して

uses Windows; 

var mseconds, starttime: integer; 


procedore TForm1.FormCreate() 
begin 
    starttime := GetTickCount(); 
    mseconds := 0; 
    Timer1.Enabled := false; 
    Label1.Caption := ''; 
    ProgressBar1.Position := 0; 
    Label1.Caption := 'Waiting...'; 
end; 

procedure TForm1.Button1Click(Sender: TObject); 
begin 
    ProgressBar1.Min := 0; 
    ProgressBar.Max := 100; 
    ProgressBar1.Position := 0; 
    timer1.Enabled := True; 
    Label1.Caption := 'Working...'; 
end; 

procedure TForm1.Timer1Timer(Sender: TObject); 
begin 
    mseconds := GetTickCount() - starttime; 
    if mseconds < 5000 then 
    ProgressBar1.Position := Trunc(mseconds/50) 
    else begin 
    ProgressBar1.Position := 100; 
    Label1.Caption := 'Done!'; 
    Timer1.Enabled := false; 
    end; 
end; 
+0

あなたのエラーはいくつかありましたが、私はそれらを修正することができます。しかし何らかの理由で、ボタンを押すとラベルがWorking ...に変わりますが、それ以降は何もしません。私は何かが間違っていたかどうかを確認するために見ましたが、それが原因で発生する可能性があります:starttime:= GetTickCount(); (次のコメントを読む) – PuppyKevin

+0

とmseconds:= starttime - GetTickCount(); – PuppyKevin

+0

@PuppyKevin:あなたは正しいトラックにいる。エラーが表示されない場合は、デバッガを使用して、それを見つけるでしょう。また、完了したらTimer1は無効になっていません... – mghie

9

インターバル50のタイマーを使用し、最初にenabledをfalseに設定することができます。

procedure TForm1.Button1Click(Sender: TObject); 
begin 
    timer1.Enabled := True; 
end; 

procedure TForm1.Timer1Timer(Sender: TObject); 
const 
    cnt: integer = 1; 
begin 
    ProgressBar1.Position := cnt; 
    if cnt = 1 then Label1.Caption := 'Waiting...' 
    else if cnt = 100 then begin 
    Label1.Caption := 'Done!'; 
    Timer1.Enabled := False; 
    end else 
    Label1.Caption := 'Working...'; 
    Inc(cnt); 
end; 
+0

一つの問題は、それが5秒かかります保証(ところで、あなたの例では2.5)がないということです。ほとんどの場合、それは非常に近い試合になるでしょう。ストレスフルな環境では、それは数秒で起こる可能性があります。 –

+0

@Lieven:あなたは正しいですが、このダメージの影響は最小限に抑えられます。タイマーティックをカウントせず、イベントハンドラの開始からの経過時間を計算します。メッセージの優先度を高くするには、代わりにバックグラウンドスレッドからWM_USERを100ミリ秒ごとに送信します。 – mghie

+0

これは完璧な解決策ではありませんが、基本的な考え方は正しいです。 –