Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Software-Projekte der Mitglieder (https://www.delphipraxis.net/26-software-projekte-der-mitglieder/)
-   -   "DoubleA!Zeitgeber" Zeit Erinnerung (https://www.delphipraxis.net/121005-doublea-zeitgeber-zeit-erinnerung.html)

Hador 20. Sep 2008 18:25

Re: "DoubleA!Zeitgeber" Zeit Erinnerung
 
Ich habe es mir ehrlich gesagt nicht ganz duchgesehen, aber hier ein paar Anmerkungen:

Delphi-Quellcode:
OpenDialog1.Execute;
soundpfad:=OpenDialog1.FileName;
If OpenDialog1.Filename=''Then begin soundpfad:=installpfad +'\Sounds\Töne\zap_dela-dog-7593_hifi.wav'; RadioButton2.Checked:=True; end;
Besser:
Delphi-Quellcode:
if OpenDialog1.Execute then // Execute gibt True zurück, wenn erfolgreich eine Datei ausgewählt wurde
  soundpfad := OpenDialog1.FileName
else begin
  soundpfad := installpfad + '\Sounds\Töne\zap_dela-dog-7593_hifi.wav';
  RadioButton2.Checked := True;
end;
Und:
Delphi-Quellcode:
var Reg: TRegistry;
[...]
        installpfad:=ReadString('Pfad');
[...]
soundpfad:=installpfad +'\Sounds\Töne\zap_dela-dog-7593_hifi.wav';
Der Installpfad ist bei dir doch der Pfad, in dem deine Echse liegt. Warum dann das zwischenspeichern und den Umweg über die Registry? Es ist doch viel einfacher:
Delphi-Quellcode:
installpfad := ExtractFilePath(ParamStr(0));
// Anwendungsverzeichnis mit "\" auslesen. Alternativ ExtractFileDir ohne "\" am Ende
soundpfad := installpfad + 'Sounds\Töne\zap_dela-dog-7593_hifi.wav';
---
Delphi-Quellcode:
If CheckBox5.Checked=True Then s5:='True' Else s5:='False';
a) Niemals auf True oder False vergleichen sondern einfach
[delphi]if CheckBox.Checked then .../delphi]
b) das ganze kannst du auch so lösen:
Code:
s5 := BoolToStr(CheckBox5.Checked, True);
---

Code:
Memo1.Lines.SaveToFile(installpfad +'\Save\Settings.ini');
Vorsicht beim speichern im Programmverzeichnis. Du hast nicht immer dort Schreibrechte. Lieber unter Anwendungsdaten speichern

--
... :mrgreen:

EDIT: Schlechtschreibung und: Wiso nimmt der unten die Delphi-Tags nicht :gruebel:
EDIT2: Arrg, meine c-Taste klemmt :?

EDIT3:
Du könntest die voreingestellten Töne übrigends auch als Ressourcen einbinden. Dann kannst du sicher sein, dass die auh nicht jmd. versehentlich verschiebt, löscht oder sonst was damit anstellt.

Darkface 20. Sep 2008 20:12

Re: "DoubleA!Zeitgeber" Zeit Erinnerung
 
Zitat:

Zitat von Luckie
Was ist das eigentlich für ein unsichtbares Memo?

Das Memo benutze ich für das einfache einlesen und speichern der Einstellungen in die Settings.inf!


Zitat:

Zitat von Hador
Der Installpfad ist bei dir doch der Pfad, in dem deine Echse liegt. Warum dann das zwischenspeichern und den Umweg über die Registry?

Das ist nicht ganz richtig, da auf dem Desktop eine zweite exe erstellt wird. Beiden exen ist es bei meiner Variante egal von wo sie gestartet werden, die Sounds werden so immer im Installationsverzeichnis gelesen!

---------------------
Das ich nicht auf True/False überprüfen soll habe ich inzwischen aufgenommen :-).
---------------------
Danke für den Tipp, nicht in das Programmverzeichnis zu speichern.
---------------------
Müsste mir mal ansehen wie ich Sounds in Ressource speichern kann...

Luckie 20. Sep 2008 23:03

Re: "DoubleA!Zeitgeber" Zeit Erinnerung
 
Zitat:

Zitat von Darkface
Zitat:

Zitat von Luckie
Was ist das eigentlich für ein unsichtbares Memo?

Das Memo benutze ich für das einfache einlesen und speichern der Einstellungen in die Settings.inf!

Dann kannst du auch eine StringList nehmen.

Zitat:

Das ist nicht ganz richtig, da auf dem Desktop eine zweite exe erstellt wird. Beiden exen ist es bei meiner Variante egal von wo sie gestartet werden, die Sounds werden so immer im Installationsverzeichnis gelesen!
Warum erstellst du eine zweite Exe auf dem Desktop? Was hat sie dort zu suchen? Ich will dort keine Anwendungen haben.

Hador 20. Sep 2008 23:14

Re: "DoubleA!Zeitgeber" Zeit Erinnerung
 
Zitat:

Zitat von Luckie
[...]
Zitat:

Zitat von Darkface
Das ist nicht ganz richtig, da auf dem Desktop eine zweite exe erstellt wird. Beiden exen ist es bei meiner Variante egal von wo sie gestartet werden, die Sounds werden so immer im Installationsverzeichnis gelesen!

Warum erstellst du eine zweite Exe auf dem Desktop? Was hat sie dort zu suchen? Ich will dort keine Anwendungen haben.

Da stimme ich Luckie völlig zu. Erstell doch (optional) dort eine Verknüpfung mit deiner Anwendung (wenn überhaupt - Denn dein Prgm. wird doch eh automatisch gestartet).

Darkface 21. Sep 2008 09:43

Re: "DoubleA!Zeitgeber" Zeit Erinnerung
 
Ok, dann werde ich das Programm demnächst nach den hier Angesprochenen Kritikpunkten anpassen. Das Programm wird übrigens nichtautomatisch automatisch gestartet, nur auf Wunsch!

Darkface 21. Sep 2008 11:44

Re: "DoubleA!Zeitgeber" Zeit Erinnerung
 
Neue Version, siehe Edit1 erster Post.
Muss mich als nächstes um die Sounds kümmern (müssen in Ressourcen Datei). Wie ich das anstelle weis ich noch nicht, habe noch nie mit einer Ressourcen Datei gearbeitet. Falls jemand einen guten Link zu dem Thema hat, scheut euch nicht ihn zu Posten :D.

Ansonsten bin ich weiterhin offen für Anregungen/Verbesserungsvorschläge/ect. ^^.

MfG Darkface


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:02 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz