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 :

[Tâche planifiée]Migration d'une appli graphique vers une procédure automatisée


Sujet :

Delphi

  1. #1
    Membre expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2013
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 563
    Points : 3 404
    Points
    3 404
    Par défaut [Tâche planifiée]Migration d'une appli graphique vers une procédure automatisée
    Bonjour !

    Alors pour faire simple : J'ai une application graphique executant une certaine procédure suite au clique sur le bouton 'démarrer'. Mon but maintenant est de lancer cette application dans une tâche planifiée de façon transparente.
    Dit comme ça, ça à l'air simple ! Mais le débutant que je suis s'est vite confronté à plusieurs problèmes.

    J'ai donc pensé à la solution suivante : rendre la fenêtre invisible puis simuler le clique sur le bouton.

    J'avais aussi pensé à modifier mon unit qui est une classe TForm en classe simple, mais mes composants de base de données sont dans la form justement..

    Je voudrais donc savoir si la voie que je choisis est la bonne et, si oui, comment simuler le clique? :O

    Merci d'avance

  2. #2
    Modérateur

    Homme Profil pro
    Ingénieur retraité
    Inscrit en
    Octobre 2005
    Messages
    2 396
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur retraité

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 396
    Points : 3 263
    Points
    3 263
    Par défaut
    Bonjour,

    rendre la fenêtre invisible puis simuler le clique sur le bouton.
    Pour simuler :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    var       p : TPoint;
    begin     p.x:=20; p.y:=20;     // coordonnées locales du bouton sur lequel on simule le click
              p:=ClientToScreen(p); // coordonnées écran du même point
              SetCursorPos(p.x,p.y);
              Mouse_Event(MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0);
              Mouse_Event(MOUSEEVENTF_LEFTUP, 0, 0, 0, 0);
    end;
    Comme la fenêtre est invisible il suffit de détecter l'appui d'une touche-clavier :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    function  ToucheCla(t : integer) : boolean; // Appui Touche
    //        utilisations : if ToucheCla(VK_CONTROL) then
    //                       if ToucheCla(Ord('R')) then
    begin     Result:= ((GetAsyncKeyState(t) and 32768)<> 0)
    end;
    A+.

    EDIT : dans l'exemple p.x:=20; p.y:=20; correspond à un bouton situé situé sous la barre de titre de la form principale
    et avec p.X := 400; p.y := -5; ça ouvre l'item situé en X = 400 d'un MainMenu1
    N'oubliez pas de consulter les FAQ Delphi et les cours et tutoriels Delphi

  3. #3
    Membre expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2013
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 563
    Points : 3 404
    Points
    3 404
    Par défaut
    Merci pour ta réponse mais je ne voudrais pas que l'utilisateur ait a agir sur le programme.

    Dans la finalité, celui-ci s'exécute dans une tâche planifiée et est entièrement autonome. Seul les messages d'erreur s'afficheraient dans des message box.

  4. #4
    Modérateur

    Homme Profil pro
    Ingénieur retraité
    Inscrit en
    Octobre 2005
    Messages
    2 396
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur retraité

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 396
    Points : 3 263
    Points
    3 263
    Par défaut
    Re-bonjour,

    mais je ne voudrais pas que l'utilisateur ait a agir sur le programme.
    Bin, dans ce cas il suffit de déclencher la simulation du click dès le onCreate ou bien via un Timer s'il faut retarder l'action.

    A+.
    N'oubliez pas de consulter les FAQ Delphi et les cours et tutoriels Delphi

  5. #5
    Membre expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2013
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 563
    Points : 3 404
    Points
    3 404
    Par défaut
    Ah mais c'est que c'est pas bête tou ça..

    beaucoup pour ton aide

  6. #6
    Membre expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 552
    Points : 3 920
    Points
    3 920
    Par défaut
    Salut

    Tout dépend de l'objectif, est-ce que tu veux que toute l'application soit automatisée ou seulement une petite partie ? Est-ce que l'application graphique sera toujours utilisée en tant que telle ?

    L'idéal est de commencer par déplacer la procédure dans un DataModule, c'est plus sain et ce sera plus facile à transformer après. Mais attention au couplage (les dépendances) entre ta procédure et la fiche où elle est définie.
    2 axes de solution:

    - tu écris une nouvelle application console qui reprend le code à automatisé en le copiant ou le partageant avec l'application graphique initiale.

    - tu transformes ton application graphique en application console, c'est de la bidouille, il faut savoir que tu peux très bien afficher des fiches depuis une application console, il n'y a pas d'impossibilité, on obtient une forme d'hybride entre les 2 modes. Tu pourras prévoir un paramètre en ligne de commande pour décider si tu passes directement en mode graphique ou en mode automatisé. Tout cela est bien sûr à coder.

    @+

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  7. #7
    Membre expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2013
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 563
    Points : 3 404
    Points
    3 404
    Par défaut
    J'ai vu que l'on pouvait lancer une form depuis une console mais je trouve ça bisarement fait... J'ai suivi ce cours et j'ai regardé les exemples. Le fait est que mon application n'est pas très conséquente et s'occupe juste de vérivier des champs dans une table. Le coup de rendre la fenêtre invisible n'est sûrement pas le plus optimal, j'en conviens, mais ça reste assez pratique dans le cas ou un utilisateur voudrait lancer l'appli manuellement.

    Le petit soucis restant est que la fiche s'ouvre a la fin de l'exe. Mais un appel de méthode genre close() doit bien exister ^^

  8. #8
    Membre expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 552
    Points : 3 920
    Points
    3 920
    Par défaut
    Sans passer par une application console mais en modifiant légèrement le fichier dpr, tu pourrais peut-être éviter cela, en conditionnant l'exécution normal du code du projet (.dpr) à un paramètre du programme.

    Selon la valeur du paramètre, tu exécute normalement le code du projet ou tu exécutes uniquement le code de contrôle. Dans ce cas plus d'affichage bizarre et plus besoin de pirouettes dans le code de la fiche qui ne seront pas faciles à comprendre plus tard.

    Cette solution a l'inconvénient de modifier le fichier dpr, ce qui peut compliquer l'ajout de nouvelles fiches ou de nouveaux datamodules plus tard.

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  9. #9
    Membre expert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2013
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 1 563
    Points : 3 404
    Points
    3 404
    Par défaut
    Hum lors de l'execution de l'appli un mdp utilisateur est demandé. J'ai la propriété login prompt a true c'est donc normal je suppose. Cependant lorsque je décoche la case et met le mot de passe dans les propriétés du TDataBase, l'execution génère un violation de cle.. Comment ça se fait?

  10. #10
    Membre expert
    Avatar de e-ric
    Homme Profil pro
    Apprenti chat, bienfaiteur de tritons et autres bestioles
    Inscrit en
    Mars 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Apprenti chat, bienfaiteur de tritons et autres bestioles

    Informations forums :
    Inscription : Mars 2002
    Messages : 1 552
    Points : 3 920
    Points
    3 920
    Par défaut
    Discussion résolue, vous dites ??

    Question bête (je m'(attend à une réponse idiote) : as-tu défini ll nom de l'utilisateur ?
    Dans le code que tu exécutes, fais-tu des insertions ?

    @+

    M E N S . A G I T A T . M O L E M
    Debian 64bit, Lazarus + FPC -> n'oubliez pas de consulter les FAQ Delphi et Pascal ainsi que les cours et tutoriels Delphi et Pascal

    "La théorie, c'est quand on sait tout, mais que rien ne marche. La pratique, c'est quand tout marche, mais qu'on ne sait pas pourquoi. En informatique, la théorie et la pratique sont réunies: rien ne marche et on ne sait pas pourquoi!".
    Mais Emmanuel Kant disait aussi : "La théorie sans la pratique est inutile, la pratique sans la théorie est aveugle."

  11. #11
    Rédacteur/Modérateur
    Avatar de Andnotor
    Inscrit en
    Septembre 2008
    Messages
    5 691
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Septembre 2008
    Messages : 5 691
    Points : 13 121
    Points
    13 121
    Par défaut
    Citation Envoyé par e-ric Voir le message
    tu transformes ton application graphique en application console, c'est de la bidouille, il faut savoir que tu peux très bien afficher des fiches depuis une application console, il n'y a pas d'impossibilité, on obtient une forme d'hybride entre les 2 modes.
    Ça n'a rien d'hybride, une application se déroule du begin au end, GUI comme console. La différence est qu'une application "GUI" crée implicitement un TApplication intégrant une boucle de messages (dans sa méthode Run) et par conséquent une fenêtre "invisible" (un Handle pour recevoir ces messages). Dans le même temps, elle n'affiche pas la console.
    Pour afficher la console depuis une app "GUI", soit AllocConsole, soit définir Générer une application console dans les options du projet.
    A l'inverse, pour utiliser une fiche dans une application "console", il faudra obligatoirement qu'elle soit modale pour justement créer une boucle de messages. Sinon, le programme quitte immédiatement.

    Citation Envoyé par ZenZiTone Voir le message
    Le coup de rendre la fenêtre invisible n'est sûrement pas le plus optimal, j'en conviens, mais ça reste assez pratique dans le cas ou un utilisateur voudrait lancer l'appli manuellement.
    C'est également la méthode que je privilégierais

  12. #12
    Expert éminent sénior
    Avatar de Paul TOTH
    Homme Profil pro
    Freelance
    Inscrit en
    Novembre 2002
    Messages
    8 964
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Freelance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2002
    Messages : 8 964
    Points : 28 430
    Points
    28 430
    Par défaut
    il suffirait de déporter tout le code utilisable sans GUI dans un DataModule et de créer deux DPR, le premier utilise une fiche et le DataModule, le second (une application CONSOLE) n'utiliserais que le DataModule.

    dans la fiche, Button1Click appellerait une méthode de traitement du DataModule, laquelle méthode serait appelée directement dans le .DPR de l'application console.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    program ModeConsole;
    {$APPTYPE CONSOLE}
    uses
      Unit2;
    begin
      DataModule2 := TDataModule2.Create(nil);
      DataModule2.LancerTraitement;
    end;
    Developpez.com: Mes articles, forum FlashPascal
    Entreprise: Execute SARL
    Le Store Excute Store

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

Discussions similaires

  1. Ouvrir une fenêtre (graphique) depuis une appli console
    Par Captain'Flam dans le forum Windows
    Réponses: 9
    Dernier message: 09/09/2011, 16h34
  2. Réponses: 2
    Dernier message: 31/03/2009, 10h59
  3. Réponses: 0
    Dernier message: 27/03/2009, 11h34
  4. Réponses: 3
    Dernier message: 01/03/2007, 21h26
  5. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24

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