Aggiornato ba0 in base alla moderna gestione dei bottoni delle maschere~aere

git-svn-id: svn://10.65.10.50/trunk@63 c028cbd2-c16b-5b4b-a496-9718f37d4682
This commit is contained in:
guy 1994-08-26 13:04:28 +00:00
parent a5ef1e17c8
commit 86bd8244c4
6 changed files with 253 additions and 245 deletions

View File

@ -20,53 +20,53 @@ extern "C" {
class TPicture_mask : public TMask class TPicture_mask : public TMask
{ {
PICTURE _picture; PICTURE _picture;
virtual void handler(WINDOW win, EVENT* ep); virtual void handler(WINDOW win, EVENT* ep);
public: public:
TPicture_mask(const char* name, int dx, int dy, short picture_id); TPicture_mask(const char* name, int dx, int dy, short picture_id);
~TPicture_mask(); ~TPicture_mask();
}; };
TPicture_mask::TPicture_mask(const char* name, int dx, int dy, TPicture_mask::TPicture_mask(const char* name, int dx, int dy,
short picture_id) short picture_id)
: TMask(name, 1, dx, dy), _picture(0L) : TMask(name, 1, dx, dy), _picture(0L)
{ {
#if XVT_OS == XVT_OS_WIN #if XVT_OS == XVT_OS_WIN
_picture = cpb_picture_load(picture_id); _picture = cpb_picture_load(picture_id);
#endif #endif
} }
TPicture_mask::~TPicture_mask() TPicture_mask::~TPicture_mask()
{ {
#if XVT_OS == XVT_OS_WIN #if XVT_OS == XVT_OS_WIN
if (_picture) if (_picture)
picture_free(_picture); picture_free(_picture);
#endif #endif
} }
void TPicture_mask::handler(WINDOW win, EVENT* ep) void TPicture_mask::handler(WINDOW win, EVENT* ep)
{ {
TMask::handler(win, ep); TMask::handler(win, ep);
if (ep->type == E_UPDATE) if (ep->type == E_UPDATE)
{ {
#if XVT_OS == XVT_OS_WIN #if XVT_OS == XVT_OS_WIN
if (_picture) if (_picture)
cpb_win_picture_draw_at(win, _picture, 1, 1); cpb_win_picture_draw_at(win, _picture, 1, 1);
else else
#endif #endif
{ {
const int max = 16; const int max = 16;
for (int i = 0; i < max; i++) for (int i = 0; i < max; i++)
{ {
TTemp_window w(win); TTemp_window w(win);
w.rect(i*2, i, max-i*2, max-i); w.rect(i*2, i, max-i*2, max-i);
} }
} }
} }
} }
/////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////
@ -75,146 +75,152 @@ void TPicture_mask::handler(WINDOW win, EVENT* ep)
class TMenu_application : public TApplication class TMenu_application : public TApplication
{ {
const char* _name; const char* _name;
enum { MAXLEVEL = 1024 }; enum { MAXLEVEL = 1024 };
int _first[MAXLEVEL]; int _first[MAXLEVEL];
TArray _menu; // TAG|DESCRIPTION|ACTION TArray _menu; // TAG|DESCRIPTION|ACTION
int _level, _max; int _level, _max;
protected: protected:
void load_menu(); void load_menu();
int do_level(); int do_level();
bool create(); bool create();
public: public:
TMenu_application(const char* name) : _name(name) {} TMenu_application(const char* name) : _name(name) {}
}; };
static short last_button = 0;
void TMenu_application::load_menu() void TMenu_application::load_menu()
{ {
TScanner s(_name); TScanner s(_name);
_max = -1; _max = -1;
while (s.line().not_empty()) while (s.line().not_empty())
{ {
TToken_string* ts = new TToken_string(s.token()); TToken_string* ts = new TToken_string(s.token());
int l = ts->get_int(); int l = ts->get_int();
if (l < _max) if (l < _max)
{ {
error_box("Item of level %d while %d was expected)", l, _max); error_box("Item of level %d while %d was expected)", l, _max);
l = _max; l = _max;
} }
if (l > _max) if (l > _max)
{ {
if (l >= MAXLEVEL) if (l >= MAXLEVEL)
{ {
error_box("Too many menu levels: %d", l); error_box("Too many menu levels: %d", l);
l = _max; l = _max;
} }
_first[_max = l] = _menu.items(); _first[_max = l] = _menu.items();
} }
_menu.add(ts); _menu.add(ts);
} }
_first[++_max] = _menu.items(); _first[++_max] = _menu.items();
} }
HIDDEN bool menu_item_handler(TMask_field&f, KEY k) HIDDEN bool menu_item_handler(TMask_field&f, KEY k)
{ {
if (k == K_SPACE) if (k == K_SPACE)
f.mask().stop_run(f.dlg()); {
return TRUE; last_button = f.dlg();
f.mask().stop_run(K_AUTO_ENTER);
}
return TRUE;
} }
int TMenu_application::do_level() int TMenu_application::do_level()
{ {
const int first = _first[_level]; const int first = _first[_level];
const int last = _first[_level+1]; const int last = _first[_level+1];
const char* head = ((TToken_string&)_menu[first]).get(1); const char* head = ((TToken_string&)_menu[first]).get(1);
const int width = 72; const int width = 72;
const int heigth = 18; const int heigth = 18;
const int bwidth = 20; const int bwidth = 20;
const int x = width-bwidth-12; const int x = width-bwidth-12;
TPicture_mask menu(head, width, heigth, BA0_PICTURE); TPicture_mask menu(head, width, heigth, BA0_PICTURE);
int y = 1; int y = 1;
#if XVT_OS == XVT_OS_WIN #if XVT_OS == XVT_OS_WIN
TString t(format("#%d", BMP_STOPREC)); TString t(format("#%d", BMP_STOPREC));
#else #else
TString t; TString t;
#endif #endif
TString item(32); TString item(32);
for (int i = first+1; i < last; i++, y++) for (int i = first+1; i < last; i++, y++)
{ {
TToken_string& row = (TToken_string&)_menu[i]; TToken_string& row = (TToken_string&)_menu[i];
item = row.get(1); item = row.get(1);
menu.add_button(100+y, 0, t, x, y, 1, 1); menu.add_button(100+y, 0, t, x, y, 1, 1);
menu.set_handler(100+y, menu_item_handler); menu.set_handler(100+y, menu_item_handler);
menu.add_static(-1, 0, item, x+4, y); menu.add_static(-1, 0, item, x+4, y);
} }
t = first ? "Menu precedente" : "Fine"; t = first ? "Menu precedente" : "Fine";
const short id = first ? DLG_CANCEL : DLG_QUIT; const short id = first ? DLG_CANCEL : DLG_QUIT;
menu.add_button(id, 0, t, x, heigth-2, bwidth, 2); menu.add_button(id, 0, t, x, heigth-2, bwidth, 2);
menu.run(); menu.run();
int k = menu.last_key(); int k = menu.last_key();
int m =(k == K_QUIT || k == K_ESC) ? -1 : first+k-100; int m =(k == K_QUIT || k == K_ESC) ? -1 : first+last_button-100;
return m; return m;
} }
bool TMenu_application::create() bool TMenu_application::create()
{ {
load_menu(); load_menu();
int refarray[256]; int refarray[256];
int i = 0; int i = 0;
_level = 0; _level = 0;
while (i >= 0) while (i >= 0)
{ {
int m = do_level(); int m = do_level();
if (m >= 0) if (m >= 0)
{ {
const char* option = ((TToken_string&)_menu[m]).get(2); const char* option = ((TToken_string&)_menu[m]).get(2);
if (option && *option) if (option && *option)
{ {
int l = atoi(option); int l = atoi(option);
if (l > 0) if (l > 0)
{ {
const char* flags = ((TToken_string&)_menu[m]).get(3); const char* flags = ((TToken_string&)_menu[m]).get(3);
if (flags && strchr(flags, 'F') != NULL) set_firm(); if (flags && strchr(flags, 'F') != NULL) set_firm();
refarray[i++] = _level; refarray[i++] = _level;
if (l < _max) _level = l; if (l < _max) _level = l;
} }
else else
{ {
TExternal_app a(option); TExternal_app a(option);
a.run(); a.run();
} }
} }
} }
else _level = (--i >= 0) ? refarray[i] : 0; else _level = (--i >= 0) ? refarray[i] : 0;
} }
stop_run(); stop_run();
return TRUE; return TRUE;
} }
int main(int argc, char** argv) int main(int argc, char** argv)
{ {
const char* menu = (argc < 2) ? "prassi.mnu" : argv[1]; const char* menu = (argc < 2) ? "prassi.mnu" : argv[1];
TMenu_application ma(menu); TMenu_application ma(menu);
ma.run(argc, argv, "PRASSI"); ma.run(argc, argv, "PRASSI");
return TRUE; return TRUE;
} }

View File

@ -1,4 +1,4 @@
#include <ba2300.h> #include "ba2300.h"
PAGE "SELECT PRINTER" -1 -1 40 15 PAGE "SELECT PRINTER" -1 -1 40 15

View File

@ -1,4 +1,4 @@
#include <ba2300.h> #include "ba2300.h"
PAGE "ADD/MODIFY PRINTER" -1 -1 64 17 PAGE "ADD/MODIFY PRINTER" -1 -1 64 17

View File

@ -1,4 +1,4 @@
#include <ba2300.h> #include "ba2300.h"
PAGE "VIEW PRINTER" -1 -1 64 17 PAGE "VIEW PRINTER" -1 -1 64 17

View File

@ -1,4 +1,4 @@
#include <ba2300.h> #include "ba2300.h"
PAGE "ADD NEW CODE" -1 -1 76 7 PAGE "ADD NEW CODE" -1 -1 76 7

View File

@ -1,5 +1,4 @@
#include <ba3100.h> #include <ba3100.h>
#include <batb%ban.h>
TOOLBAR "" 0 20 0 2 TOOLBAR "" 0 20 0 2
@ -11,19 +10,20 @@ PAGE "Tabella banche" -1 -1 78 18
NUMBER H_CODICEABI 5 NUMBER H_CODICEABI 5
BEGIN BEGIN
PROMPT 0 0 ""
FLAGS "HRZ" FLAGS "HRZ"
GROUP GR_SEARCH
USE %BAN SELECT CODTAB[6,10]="" USE %BAN SELECT CODTAB[6,10]=""
INPUT CODTAB[1,5] F_CODICEABI INPUT CODTAB[1,5] F_CODICEABI
DISPLAY "Codice ABI" CODTAB[1,5] DISPLAY "Codice ABI" CODTAB[1,5]
DISPLAY "Codice CAB" CODTAB[6,10] DISPLAY "Codice CAB" CODTAB[6,10]
DISPLAY "Istituto@50" S0 DISPLAY "Istituto@50" S0
OUTPUT F_ISTIT S0 OUTPUT F_ISTIT S0
GROUP GR_SEARCH
END END
NUMBER F_CODICEABI 5 NUMBER F_CODICEABI 5 5
BEGIN BEGIN
PROMPT 4 1 "Codice ABI " PROMPT 6 1 "Codice ABI "
FIELD %BAN->CODTAB[1,5] FIELD %BAN->CODTAB[1,5]
FLAGS "RZ" FLAGS "RZ"
KEY 1 KEY 1
@ -39,34 +39,33 @@ BEGIN
MESSAGE COPY,H_CODICEABI MESSAGE COPY,H_CODICEABI
END END
NUMBER F_CODICECAB 5 NUMBER F_CODICECAB 5 5
BEGIN BEGIN
PROMPT 29 1 "Codice CAB " PROMPT 28 1 "Codice CAB "
FIELD %BAN->CODTAB[6,10] FIELD %BAN->CODTAB[6,10]
FLAGS "RZ" FLAGS "RZ"
KEY 1 KEY 1
COPY ALL F_CODICEABI COPY ALL F_CODICEABI
MESSAGE SHOW,F_ISTIT|EMPTY HIDE,F_ISTIT
VALIDATE AUTOEXIT_FUNC 2 F_CODICEABI F_CODICECAB VALIDATE AUTOEXIT_FUNC 2 F_CODICEABI F_CODICECAB
MESSAGE SHOW,F_ISTIT
MESSAGE EMPTY HIDE,F_ISTIT
END END
NUMBER F_CODICEDIP 4 NUMBER F_CODICEDIP 4 4
BEGIN BEGIN
PROMPT 52 1 "Codice Dipendenza " PROMPT 50 1 "Codice Dipendenza "
FIELD %BAN->I0 FIELD %BAN->I0
FLAGS "RZ" FLAGS "RZ"
END END
STRING F_ISTIT 50 STRING F_ISTIT 50
BEGIN BEGIN
PROMPT 4 3 "Istituto " PROMPT 6 3 "Istituto "
FLAGS "D" FLAGS "D"
END END
STRING F_DENOM 50 STRING F_DENOM 50
BEGIN BEGIN
PROMPT 4 5 "Denominazione " PROMPT 6 5 "Denominazione "
FIELD %BAN->S0 FIELD %BAN->S0
KEY 2 KEY 2
USE %BAN KEY 2 USE %BAN KEY 2
@ -79,26 +78,30 @@ BEGIN
CHECKTYPE REQUIRED CHECKTYPE REQUIRED
END END
GROUPBOX DLG_NULL 72 7
BEGIN
PROMPT 4 8 "Sede"
END
STRING F_INDIRIZZO 35 STRING F_INDIRIZZO 35
BEGIN BEGIN
PROMPT 4 7 "Indirizzo " PROMPT 6 9 "Indirizzo "
FIELD %BAN->S2 FIELD %BAN->S2
END END
STRING F_CIV 10 STRING F_CIV 10
BEGIN BEGIN
PROMPT 57 7 "N." PROMPT 60 9 "N. "
FIELD %BAN->S7 FIELD %BAN->S7
END END
STRING F_COMUNE 4 STRING F_COMUNE 4
BEGIN BEGIN
PROMPT 4 9 "Comune " PROMPT 6 11 "Comune "
FIELD %BAN->S5 FIELD %BAN->S5
USE LF_COMUNI USE LF_COMUNI
INPUT STATO "" INPUT STATO ""
INPUT COM F_COMUNE INPUT COM F_COMUNE
#include <comdcod.h>
OUTPUT F_COMUNE COM OUTPUT F_COMUNE COM
OUTPUT F_DENCOM DENCOM OUTPUT F_DENCOM DENCOM
OUTPUT F_PROV PROVCOM OUTPUT F_PROV PROVCOM
@ -110,23 +113,22 @@ END
STRING F_DENCOM 50 STRING F_DENCOM 50
BEGIN BEGIN
PROMPT 4 11 "Denominazione " PROMPT 6 12 "Denominazione "
USE LF_COMUNI KEY 2 USE LF_COMUNI KEY 2
INPUT DENCOM F_DENCOM INPUT DENCOM F_DENCOM
#include <comdden.h>
COPY OUTPUT F_COMUNE COPY OUTPUT F_COMUNE
CHECKTYPE NORMAL CHECKTYPE NORMAL
END END
STRING F_PROV 2 STRING F_PROV 2
BEGIN BEGIN
PROMPT 4 13 "Provincia " PROMPT 6 13 "Provincia "
FLAGS "D" FLAGS "D"
END END
STRING F_CAP 5 STRING F_CAP 5
BEGIN BEGIN
PROMPT 56 13 "C.A.P. " PROMPT 60 13 "C.A.P. "
FIELD %BAN->S3 FIELD %BAN->S3
END END