Réponse acceptée !
Salut,
Bacterius -> Remarque sur ton premier post la "première instruction" sert à récupérer un handle sur la fenêtre "Text". Ce handle est ensuite passé en paramètre à FindWindowEx. Donc la première ligne sert effectivement à quelque chose.
DelphiTurbo -> Sous Windows, les fenêtres sont des objets avec lesquels on peut interragir en les désignant par un handle (Un numéro codé sur 32 bits). De plus, tous les composants (Boutons, zones de texts) sont composés de une ou plusieurs fenêtres (En fait certaines librairies ne se servent plus de ce système de fenêtres, mais bon restons simples.)
Ton application peut récupérer un handle sur une autre fenêtre, puis s'en utiliser des fonctions de Windows en leurs passant ce handle en paramètre pour dire à Windows que tu veux interagir avec cette fenêtre et pas une autre. Les handles sont valide dans une instance d'application qui seulement (Exception exceptées... restons encore une fois simple).
Ca c'était pour la théorie que tu connaissais peut être déjà.
Ici :
Windows.ShowWindow(FindWindow(
nil,PChar('
Texteinstellungen')),SW_HIDE);
tu récupères un handle sur la fenêtre principal de l'application. Tu peux effectivement afficher/cacher cette fenêtre, modifier le titre de cette fenêtre...
Mais ce qui t'intéresse, ce n'est pas cette fenêtre, mais celle qui s'occupe de la zone de texte un peu plus bas.
Il faut donc que tu récupères un handle sur cette fenêtre.
Sous Windows, les fenêtres forment une arborescence qu'il faut que tu parcours pour parvenir à la bonne fenêtre.
C'est un peu ce que tu fais dans ton premier post dans lequel tu récupère d'abord un handle de fenêtre principale pour ensuite chercher une autre fenêtre fille de celle-ci avec FindWindowEx.
Il faut que tu procède de la même manière. Tu auras peut être à réaliser plusieurs FindWindowEx en fonction de la profondeur de l'arboresence des fenêtres. A la place de FindWindowEx, tu peux aussi passer par
GetWindow ou encore
EnumChildWindows.
Dans tout les cas, il va falloire que tu récupère un maximum d'informations sur l'architecture de l'application cible : par exemple le nom et la classe de toutes les fenêtres parentes de la zone de texte. On voit que la zone de text est dans l'équivalent d'une TabSheet de Delphi. Peut être que la fenêtre de TabSheet est parente de celle de la zone de fenêtre. Peut être pas.
Pour le savoir facilement, il faudrait que tu utilise un logiciel capable de t'afficher ce type de données.
Si tu as Visual Studio, tu as Spy++.
Sinon, tu peux utiliser
ce logiciel.
Tu peux aussi coder ton propre logiciel en Delphi pour afficher toute l'arbo dans un TreeView.

A la fin, ton code risque de ressembler à ça :
wnd :
= FindWindow(nil,'
Texteinstellungen');
if wnd = 0
thenTraitement erreur
wnd :
= FindWindowEx(wnd, 0, '
PageControl',
nil);
if wnd = 0
thenTraitement erreurwnd :
= FindWindowEx(wnd, 0, '
TabSheet',
'Text');
if wnd = 0
thenTraitement erreurwnd :
= FindWindowEx(wnd, 0, '
TextBox',
nil);
if wnd = 0
thenTraitement erreur
SendMessage(wnd, WM_SetText, 0, LongInt(PChar(Edit1.Text)));
Ah vi, comme le dit Bacterius, il se peut que la fenêtre soit "portégée", ou que modifier son contenu ne donne pas le résultat escompté. Ces problèmes, bien que peu probables dans ton cas, serait contournable en simulant un utilisateur plutôt qu'en utilisant un message WM_SETTEXT. Dans tous les cas, tu devrais pouvoir afficher/cacher cette fenêtre (Cette text box...) comme tu l'as fait avec la fenêtre principale, pour vérifier que tu disposes bien du bon handle.
Bonne chance.