AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Hilfe erstellen

Ein Thema von Delbor · begonnen am 16. Jul 2018 · letzter Beitrag vom 21. Jul 2018
Antwort Antwort
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.582 Beiträge
 
Delphi 12 Athens
 
#1

AW: Hilfe erstellen

  Alt 16. Jul 2018, 15:43
Siehe OH?

Command gibt an was es für eine Hilfe ist. (Context oder Keyword)
und in Data ist dann entweder der Context (Integer) oder das Keyword (PString) drin.

Und in CallHelp gibst DU an, ob du die Hilfe-Anfrage verarbeitet hast, oder ob es doch noch an Standardbehandlung weitergereicht werden soll.

[add] Der Anfang von etwas, dass ich mal vor paar Jahren schrieb.
Delphi-Quellcode:
function THelpModul.ApplicationEvents1Help(Command: Word; Data: Integer; var CallHelp: Boolean): Boolean;
...
begin
  Log := '';
  try
    {$REGION 'originalen Hilfeaufruf loggen'}
    case Command of
      HELP_CONTEXT: S := ' - HELP_CONTEXT (Display topic in ulTopic)';
      HELP_QUIT: S := ' - HELP_QUIT (Terminate help)';
      HELP_INDEX: S := ' - HELP_INDEX/HELP_CONTENTS (Display index)';
      HELP_HELPONHELP: S := ' - HELP_HELPONHELP (Display help on using help)';
      HELP_SETINDEX: S := ' - HELP_SETINDEX/HELP_SETCONTENTS (Set current Index for multi index help)';
      HELP_CONTEXTPOPUP: S := ' - HELP_CONTEXTPOPUP';
      HELP_FORCEFILE: S := ' - HELP_FORCEFILE';
      HELP_CONTEXTMENU: S := ' - HELP_CONTEXTMENU';
      HELP_FINDER: S := ' - HELP_FINDER';
      HELP_WM_HELP: S := ' - HELP_WM_HELP';
      HELP_SETPOPUP_POS: S := ' - HELP_SETPOPUP_POS';
      HELP_KEY: S := ' - HELP_KEY (Display topic for keyword in offabData)';
      HELP_COMMAND: S := ' - HELP_COMMAND';
      HELP_PARTIALKEY: S := ' - HELP_PARTIALKEY';
      HELP_MULTIKEY: S := ' - HELP_MULTIKEY';
      HELP_SETWINPOS: S := ' - HELP_SETWINPOS';
      else S := '';
    end;
    Log := Log + Format('CallHelp: Command=%d%s Data=%d'#10, [Command, S, Data]);
    if Command = HELP_COMMAND then
      Log := Log + ' Keyword/JumpID="' + PChar(Data) + '"'#10
    else if (Command = HELP_CONTEXT) or (Command = HELP_CONTEXTPOPUP) then
      Log := Log + ' ContextID=' + IntToStr(THelpContext(Data)) + #10
    else
      Log := Log + ' Keyword/ContextID/JumpID nicht erkannt'#10;
    {$ENDREGION}

    {$REGION 'nicht alle Komandos verarbeiten (z.B. wird beim F1 ein HELP_SETPOPUP_POS vor dem HELP_COMMAND aufgerufen)'}
    //if not (Command in [HELP_INDEX, HELP_CONTEXT, HELP_COMMAND, HELP_WM_HELP, HELP_QUIT]) then
    // Exit(True);
    case Command of
      HELP_INDEX, HELP_CONTEXT, HELP_CONTEXTPOPUP, HELP_COMMAND, HELP_WM_HELP, HELP_QUIT: ; // mit CASE, da IN einen zu kleinen Wertebereich zur Verfügung stellt
      else Exit(True);
    end;
    {$ENDREGION}

    {$REGION 'HELP_QUIT: das Hilfefenster soll geschlossen werden'}
    if Command = HELP_QUIT then begin
      FreeAndNil(HauptFormAbstract.FormWebBrowser);
      Exit(True);
    end;
    {$ENDREGION}

    ...
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (16. Jul 2018 um 15:53 Uhr)
  Mit Zitat antworten Zitat
Delbor

Registriert seit: 8. Okt 2006
Ort: St.Gallen/Schweiz
1.196 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Hilfe erstellen

  Alt 17. Jul 2018, 16:40
Hi himitsu
Vielen Dank für deinen Code! Allerdings habe ich etliche Verständnisprobleme, mir die Funktionsweise der in Delphi integrierten Hilfe-Objekte und deren Zuammenarbeit vorzustellen. Ausgehend von dem Codeschnipsel in meinem Eingangspost:
Delphi-Quellcode:
procedure TSQLiteTestMain.TLBWhatsThisClick(Sender: TObject);
begin
  FToolHelp := True; //FToolHelp wurde von mir eingefügt. Damit soll bei OnmouseDown &Co zwischen Hilfeanforderung und 'normaler' Behandlung unterschieden werden.
  DefWindowProc(handle, WM_SYSCOMMAND, SC_CONTEXTHELP, 0);
end;
Wenn das ausgeführt wird, verwandelt sich der Mauszeiger bis zum nächsten Mausereignis in ein Fragezeichen, danach wird AppHelp aufgerufen. Mit deinem Code könnte ich also den Wert des Parameters auswerten und den String S belegen. Soweit, so gut - oder aber auch nicht, je nach Verständnis. und meines ist trotz OH immer noch unter aller...
Zitat:
Command gibt an was es für eine Hilfe ist. (Context oder Keyword)
und in Data ist dann entweder der Context (Integer) oder das Keyword (PString) drin.
Also die Werte der Propertys HelpKeyword und HelpContext der angeklickten Komponente? Und wie weiss ich (kann ich auslesen/erkennen), wo sich die angeklickte Komponente befindet? Befindet sie sich auf einer Toolbox der Mainform oder auf einem Frame? Das ist entscheidend, um zu erkennen, zu welchem Aufgabenbereich/Funktionsumfang sie gehört und damit entscheidend für den Aufruf einer bestimmten Hilfeseite. Es sei denn, ich setze Helpkeywords/HelpContexts ein, die zusammen einen dicken Schmöker füllen würden.

Aber wahrscheinlich denke ich einfach zu verquer oder in die falsche Richtung - oder beides.

Ich hab jetzt mal ausprobiert, wie ich an verdeckte/dynamische Komponente per OnmouseDown herankomme, im folgenden an einem Memo, das auf einem Frame liegt:
Delphi-Quellcode:
procedure TSettingsFrame.Memo1MouseDown(Sender: TObject; Button: TMouseButton;
  Shift: TShiftState; X, Y: Integer);
    var i : integer; S: String; T : TComponent;
begin
  for i := 0 to Self.Componentcount - 1 do
  begin
// S := S + Components[i].Name + sLinebreak;
    T := Components[i];
    if T is TFrame then
    begin
      S := (T as TFrame).Name;
      S := S + '.HelpKeyword' + (T as TFrame).HelpKeyword;
    end;
  end;
  Showmessage(s);
end;
Die auskommentierte Zeile listet mir alle auf dem Frame befindlichen Komponenten auf, inklusive der auf der Mainform erstellten Frameinstanz.

Soweit ich das bislang überschauen kann, müsste ich also etwa so vorgehen:
Statt in meinem Anfangs gezeigten 'TLBWhatsThisClick' DefWindowProc aufzurufen, müsste ich da nur FToolhelp setzen, den Cursor in ein Fragezeichen umwandeln, um per Klick(...) obige Prozedur aufzurufen, in dieser am Ende DefWindowProc aufrufen, um so dass Hilfesystem und damit AppHelp zu aktivieren.
Und in Apphelp kann ich schliesslich alles machen, was mir lustig ist - eine eigene HelpApplikation aufrufen, zum Bleistift...

Gruss
Delbor
Roger
Man muss und kann nicht alles wissen - man muss nur wissen, wo es steht.
Frei nach Albert Einstein
http://roase.ch
  Mit Zitat antworten Zitat
ManfredG

Registriert seit: 12. Feb 2007
Ort: Berlin
34 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#3

AW: Hilfe erstellen

  Alt 20. Jul 2018, 15:22
"Meine bisherigen Versuche mit dem Helpworkshop sind sehr unbefriedigend..."

Nur so als Tip: Habe mir gerade HelpNDoc installiert, um chm-Hilfe zu schreiben. Programm ist sehr hübsch zu bedienen, ich würde es kaufen, hat aber noch nicht alles, was ich suche.
Es setzt auch aus Help-Workshop auf, man muß sich aber nicht um die Innereien kümmern.

Gruß Manfred
Manfred Götze
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.781 Beiträge
 
Delphi 12 Athens
 
#4

AW: Hilfe erstellen

  Alt 20. Jul 2018, 15:38
Eigentlich sollte die ganze Hilfeanzeige automatisch geschehen. Je nach Typ der Hilfedatei muss man die passende HelpViewer Unit einbinden. Für hlp ist das Vcl.WinHelpViewer und für chm wäre das Vcl.HtmlHelpViewer. Für eine kontextsensitive Hilfe müssen dann natürlich die Properties HelpType und HelpContext bzw. HelpKeyword passend gesetzt sein.

Zur Erstellung der Hilfe verwende ich persönlich Help & Manual. Das geht super einfach und ich bin sehr zufrieden damit.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Harry Stahl
Harry Stahl

Registriert seit: 2. Apr 2004
Ort: Bonn
2.561 Beiträge
 
Delphi 12 Athens
 
#5

AW: Hilfe erstellen

  Alt 21. Jul 2018, 17:10
@ ManfredG + @ Uwe : Ich denke beide Programme bieten aber keine Cross-compile Lösung für alle Plattformen (Windows, MACOS und Linux) an, oder?

Deswegen habe ich mir ein eigenes Tool entwickelt, das erstellt z.B. aus den Daten des HTML-Workshops eine Hilfedatei im eigenen Format (*.cHelp für CrossHelp), die ein FMX-Programm dann sowohl unter Windows als auch unter MAC OS und Linux zur Anzeige der Hilfe-Texte verwenden kann (incl. Volltextsuche). Diese Hilfe-Datei ist komprimiert und noch kleiner als die vergleichbare .chm-Datei.

Bislang hatte ich für MAC und Linux die einzelnen html-Dateien in den Resourcen-Ordner gepackt und die HTML-Dateien vom lokalen Browser anzeigen lassen. Das war immer ein ziemlicher Aufwand für die Bereitstellung in Delphi und auch ziemlich unübersichtlich.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.781 Beiträge
 
Delphi 12 Athens
 
#6

AW: Hilfe erstellen

  Alt 21. Jul 2018, 17:32
Ich denke beide Programme bieten aber keine Cross-compile Lösung für alle Plattformen (Windows, MACOS und Linux) an, oder?
Nun, FMX kennt das Konzept von Hilfe zur Zeit gar nicht. So gibt es weder ein Application.HelpFile, noch Eigenschaften wie HelpContext oder HelpKeyword. Insofern sind sowohl die Problemstellung als auch die Antworten und erwähnten Hilfsmittel ausschließlich auf VCL ausgerichtet. Lösungen auf Basis von FMX müssen mangels vorhandener Standards im Framework zwangsläufig Eigenentwicklungen sein. (im Übrigen kann H&M auch HTML erstellen)
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von Harry Stahl
Harry Stahl

Registriert seit: 2. Apr 2004
Ort: Bonn
2.561 Beiträge
 
Delphi 12 Athens
 
#7

AW: Hilfe erstellen

  Alt 21. Jul 2018, 18:23
Es existieren auch unter FMX die Properties HelpContext, HelpKeyword und Helptype und inzwischen (jedenfalls im aktuellen Delphi 10.2) werden die Daten sogar in der Form gespeichert und wieder geladen. Klick dazu doch einfach mal auf einen TButton und versuch es selbst.

Allerdings stimmt es schon, es gibt kein fertiges System, welches damit etwas anfangen kann.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:23 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz