Italian community of Lazarus and Free Pascal

Programmazione => Generale => Topic aperto da: bonmario - Aprile 09, 2020, 12:53:10 pm

Titolo: [RISOLTO]Form non visibile e messaggi in primo piano
Inserito da: bonmario - Aprile 09, 2020, 12:53:10 pm
Ciao a tutti,
ho lo stesso problema su alcuni progetti, che hanno in comune la loro "struttura".

La struttura è questo:
- Il programma viene richiamato più volte al giorno tramite le "Operazioni pianificate" del sistema operativo (sia Windows, che Linux)
- Il programma, nella "OnCreate" fa alcune verifiche.
- Se da tali verifiche, NON emergono situazioni particolari, il programma si chiude direttamente.
- Se da tali verifiche si evidenzia un problema, viene segnalato tramite "Application.MessageBox", e poi il programma viene chiuso.
- Se invece è tutto ok, il programma prosegue, caricando i dati nel form ed emettendolo.

Il problema è questo: se, dopo che è stato emesso l'errore, il form di un altro programma gli finisce sopra, l'errore rimane sotto, ma siccome è stato dato durante la "OnCreate", di quel programma non c'è il form, e non c'è nemmeno l'icona della barra delle applicazioni. Quindi, mi accorgo dell'errore,solo se per puro caso iconizzo uno ad uno tutti gli altri programmi.

Ho provato, nel caso di errore, a far partire un timer con cui, ogni 5 secondi facevo "Application.BringToFront", ma non funziona, probabilmente perché il programma non ha ancora il suo form.

Ho anche provato a spostare le verifiche dalla "OnCreate" alla "OnActivate", ma questo crea un problema abbastanza fastidioso: se sto ad esempio scrivendo un documento, ed in quel momento parte il mio programma, per un paio di secondi il controllo passa a lui, ed io mi perdo dei pezzi di quello che stavo scrivendo.

Spero di essere riuscito a spiegarmi ....
Avete qualche consiglio su come risolvere il problema?

Grazie in anticipo, Mario
Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: xinyiman - Aprile 09, 2020, 04:10:15 pm
Scusa non hai pensato a mandarti una mail al posto dello showmessage?

Questo lo avevo scritto anni fa, spero funzioni ancora: http://www.lazaruspascal.it/index.php?page=8
Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: schumi - Aprile 09, 2020, 05:41:41 pm
oppure dividi la questione in 2, un programma fa le verifiche e scrile un log, un secondo programma visualizza i messaggi.

ciao
Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: bonmario - Aprile 09, 2020, 05:49:50 pm
Scusa non hai pensato a mandarti una mail al posto dello showmessage?

Sì, grazie, quando posso già lo faccio. In questi casi, invece, devo risolvere il prima possibile, se mi mando l'email, magari mi rendo conto il giorno dopo !!!


oppure dividi la questione in 2, un programma fa le verifiche e scrile un log, un secondo programma visualizza i messaggi.

ciao

Potrebbe anche starci, ma ho più programmi con lo stesso problema, o lo sdoppio tutti, o devo fare un unico lettore per i vali log ...
Vediamo se arriva qualche altra idea, in caso contrario, potrei farci un pensierino

Ciao, Mario
Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: schumi - Aprile 10, 2020, 01:56:36 pm
solitamente in questi casi io preferisco creare uno schedulatore interno al programma (quindi timer più tabella generalmente) invece di usare quello di windows, poi metto il programma nella tray per non averlo tra i piedi.

senza dover sconvolgere tutti i tuoi programmi mi vien da suggerirti un approccio leggermente diverso, il programma viene lanciato (magari minimizzato), oncreate fa solo partire un timer,  fai i controlli e senza errori chiude il programma oppure mette il messaggio a video.


ciao
Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: xinyiman - Aprile 11, 2020, 11:17:29 am
E far emettere al programma un suono particolare che ti faccia sapere che c'è qualcosa da guardare?!
Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: bonmario - Aprile 11, 2020, 12:38:02 pm
solitamente in questi casi io preferisco creare uno schedulatore interno al programma (quindi timer più tabella generalmente) invece di usare quello di windows, poi metto il programma nella tray per non averlo tra i piedi.

senza dover sconvolgere tutti i tuoi programmi mi vien da suggerirti un approccio leggermente diverso, il programma viene lanciato (magari minimizzato), oncreate fa solo partire un timer,  fai i controlli e senza errori chiude il programma oppure mette il messaggio a video.


ciao
Domani o dopo, approfitto delle feste per farci qualche prova


E far emettere al programma un suono particolare che ti faccia sapere che c'è qualcosa da guardare?!
Su Windows, fa già un beep. Se Linux non ci ho mai fatto caso, perché accendo le casse solo quando mi servono. In ogni caso, andrebbe bene solo se sono lì quando emette l'errore. SE lo emette, e torno un minuto dopo, sarei fregato comunque.

Titolo: Re:Form non visibile e messaggi in primo piano
Inserito da: xinyiman - Aprile 11, 2020, 01:19:42 pm
Se non ricordo male l'oggetto TrayIcon mette a disposizione una proprietà chiamata messageballon (vado a memoria) che potrebbe funzionare al caso tuo
Titolo: [RISOLTO]Form non visibile e messaggi in primo piano
Inserito da: bonmario - Aprile 13, 2020, 11:23:40 am
Alla fine ci sono riuscito !!!!

Purtroppo, mi è toccato fare 2 gestioni, una per Windows, e l'altra per Linux, ma alla fine sembra funzionare tutto.

Descrivo le fasi senza postare codice, perché ho riciclato delle procedure che facevano già qualcosa di simile, se in futuro dovesse servire a qualcuno, cercherò di estrapolare i vari pezzi utili ...

- Il prerequisito principale, è che la finestrella che viene emessa col messaggio, deve avere un titolo. Tanto per capirci, questo metodo con ShowMessage, non funziona ...
- prima di emettere il messaggio, faccio partire un TTimer, che gira ogni 5 secondi
- salvo in una variabile il titolo del messaggio che sto per emettere
- emetto il messaggio
- fermo il timer (naturalmente, questo punto verrà seguito solo dopo che l'utente avrà chiuso il messaggio, o cliccato su uno dei suoi bottoni)

Questo è quello che viene fatto all'interno del TTimer:
- tramite il PID del processo corrente, determino l'elenco di tutte le finestre "figlie" di quel PID
- se la finestra ha come titolo lo stesso che mi ero salvato prima di emettere il messaggio, la riporto in primo piano.


Ciao, Mario