mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-25 16:37:00 +00:00
filedialog and infix moved from mapeditor.cpp to dialogs.cpp
This commit is contained in:
parent
635d1f911c
commit
4fa764c175
157
dialogs.cpp
157
dialogs.cpp
@ -838,4 +838,161 @@ namespace dialog {
|
|||||||
editNumber(x, vmin, vmax, step, dft, title, help);
|
editNumber(x, vmin, vmax, step, dft, title, help);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-- choose file dialog--
|
||||||
|
|
||||||
|
bool filecmp(const pair<string,int> &f1, const pair<string,int> &f2) {
|
||||||
|
if(f1.first == "../") return true;
|
||||||
|
if(f2.first == "../") return false;
|
||||||
|
if(f1.second != f2.second)
|
||||||
|
return f1.second == CDIR;
|
||||||
|
return f1.first < f2.first;
|
||||||
|
}
|
||||||
|
|
||||||
|
string filecaption, cfileext;
|
||||||
|
string *cfileptr;
|
||||||
|
bool editext = false;
|
||||||
|
|
||||||
|
bool handleKeyFile(int sym, int uni);
|
||||||
|
|
||||||
|
void drawFileDialog() {
|
||||||
|
displayfr(vid.xres/2, 30 + vid.fsize, 2, vid.fsize,
|
||||||
|
filecaption, forecolor, 8);
|
||||||
|
|
||||||
|
string& cfile = *cfileptr;
|
||||||
|
|
||||||
|
displayfr(vid.xres/2, 34 + vid.fsize * 2, 2, vid.fsize,
|
||||||
|
cfile, editext ? 0xFF00FF : 0xFFFF00, 8);
|
||||||
|
|
||||||
|
displayButton(vid.xres*1/5, 38+vid.fsize * 3,
|
||||||
|
"F2 = save", 2000+SDLK_F2, 8);
|
||||||
|
displayButton(vid.xres*2/5, 38+vid.fsize * 3,
|
||||||
|
"F3 = load", 2000+SDLK_F3, 8);
|
||||||
|
displayButton(vid.xres*3/5, 38+vid.fsize * 3,
|
||||||
|
"F4 = extension", 2000+SDLK_F4, 8);
|
||||||
|
displayButton(vid.xres*4/5, 38+vid.fsize * 3,
|
||||||
|
"Enter = back", 2000+SDLK_RETURN, 8);
|
||||||
|
|
||||||
|
v.clear();
|
||||||
|
|
||||||
|
DIR *d;
|
||||||
|
struct dirent *dir;
|
||||||
|
|
||||||
|
string where = ".";
|
||||||
|
for(int i=0; i<size(cfile); i++)
|
||||||
|
if(cfile[i] == '/' || cfile[i] == '\\')
|
||||||
|
where = cfile.substr(0, i+1);
|
||||||
|
|
||||||
|
d = opendir(where.c_str());
|
||||||
|
if (d) {
|
||||||
|
while ((dir = readdir(d)) != NULL) {
|
||||||
|
string s = dir->d_name;
|
||||||
|
if(s != ".." && s[0] == '.') ;
|
||||||
|
else if(size(s) > 4 && s.substr(size(s)-4) == cfileext)
|
||||||
|
v.push_back(make_pair(s, CFILE));
|
||||||
|
else if(dir->d_type & DT_DIR)
|
||||||
|
v.push_back(make_pair(s+"/", CDIR));
|
||||||
|
}
|
||||||
|
closedir(d);
|
||||||
|
}
|
||||||
|
sort(v.begin(), v.end(), filecmp);
|
||||||
|
|
||||||
|
int q = v.size();
|
||||||
|
int percolumn = (vid.yres-38) / (vid.fsize+5) - 4;
|
||||||
|
int columns = 1 + (q-1) / percolumn;
|
||||||
|
|
||||||
|
for(int i=0; i<q; i++) {
|
||||||
|
int x = 16 + (vid.xres * (i/percolumn)) / columns;
|
||||||
|
int y = 42 + vid.fsize * 4 + (vid.fsize+5) * (i % percolumn);
|
||||||
|
|
||||||
|
displayColorButton(x, y, v[i].first, 1000 + i, 0, 0, v[i].second, 0xFFFF00);
|
||||||
|
}
|
||||||
|
|
||||||
|
keyhandler = handleKeyFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool handleKeyFile(int uni, int sym) {
|
||||||
|
string& s(*cfileptr);
|
||||||
|
int i = size(s) - (editext?0:4);
|
||||||
|
if(uni > 2000) sym = uni - 2000;
|
||||||
|
if(sym == SDLK_RETURN || sym == SDLK_KP_ENTER || sym == SDLK_ESCAPE) {
|
||||||
|
popScreen();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
/* else if(sym == SDLK_F2 || sym == SDLK_F3) {
|
||||||
|
popScreen();
|
||||||
|
return false;
|
||||||
|
} */
|
||||||
|
else if(sym == SDLK_F4) {
|
||||||
|
editext = !editext;
|
||||||
|
}
|
||||||
|
else if(sym == SDLK_BACKSPACE && i) {
|
||||||
|
s.erase(i-1, 1);
|
||||||
|
}
|
||||||
|
else if(uni >= 32 && uni < 127) {
|
||||||
|
s.insert(i, s0 + char(uni));
|
||||||
|
}
|
||||||
|
else if(uni >= 1000 && uni <= 1000+size(v)) {
|
||||||
|
string where = "", what = s, whereparent = "../";
|
||||||
|
for(int i=0; i<size(s); i++)
|
||||||
|
if(s[i] == '/') {
|
||||||
|
if(i >= 2 && s.substr(i-2,3) == "../")
|
||||||
|
whereparent = s.substr(0, i+1) + "../";
|
||||||
|
else
|
||||||
|
whereparent = where;
|
||||||
|
where = s.substr(0, i+1), what = s.substr(i+1);
|
||||||
|
}
|
||||||
|
int i = uni - 1000;
|
||||||
|
if(v[i].first == "../") {
|
||||||
|
s = whereparent + what;
|
||||||
|
}
|
||||||
|
else if(v[i].second == CDIR)
|
||||||
|
s = where + v[i].first + what;
|
||||||
|
else
|
||||||
|
s = where + v[i].first;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void openFileDialog(string& filename, string fcap, string ext) {
|
||||||
|
cfileptr = &filename;
|
||||||
|
filecaption = fcap;
|
||||||
|
cfileext = ext;
|
||||||
|
pushScreen(dialog::drawFileDialog);
|
||||||
|
}
|
||||||
|
|
||||||
|
// infix/v/vpush
|
||||||
|
|
||||||
|
string infix;
|
||||||
|
|
||||||
|
bool hasInfix(const string &s) {
|
||||||
|
if(infix == "") return true;
|
||||||
|
string t = "";
|
||||||
|
for(int i=0; i<size(s); i++) {
|
||||||
|
char c = s[i];
|
||||||
|
char tt = 0;
|
||||||
|
if(c >= 'a' && c <= 'z') tt += c - 32;
|
||||||
|
else if(c >= 'A' && c <= 'Z') tt += c;
|
||||||
|
else if(c == '@') tt += c;
|
||||||
|
if(tt) t += tt;
|
||||||
|
}
|
||||||
|
return t.find(infix) != string::npos;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool editInfix(int uni) {
|
||||||
|
if(uni >= 'A' && uni <= 'Z') infix += uni;
|
||||||
|
else if(uni >= 'a' && uni <= 'z') infix += uni-32;
|
||||||
|
else if(infix != "" && uni == 8) infix = infix.substr(0, size(infix)-1);
|
||||||
|
else if(infix != "" && uni != 0) infix = "";
|
||||||
|
else return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
vector<pair<string, int> > v;
|
||||||
|
|
||||||
|
void vpush(int i, const char *name) {
|
||||||
|
string s = XLATN(name);
|
||||||
|
if(!hasInfix(s)) return;
|
||||||
|
dialog::v.push_back(make_pair(s, i));
|
||||||
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
9
hyper.h
9
hyper.h
@ -1133,6 +1133,15 @@ namespace dialog {
|
|||||||
extern bool sidedialog;
|
extern bool sidedialog;
|
||||||
extern int dialogflags;
|
extern int dialogflags;
|
||||||
extern int dcenter;
|
extern int dcenter;
|
||||||
|
|
||||||
|
void openFileDialog(string& filename, string fcap, string ext);
|
||||||
|
|
||||||
|
extern string infix;
|
||||||
|
bool hasInfix(const string &s);
|
||||||
|
bool editInfix(int uni);
|
||||||
|
|
||||||
|
void vpush(int i, const char *name);
|
||||||
|
extern vector<pair<string, int> > v;
|
||||||
}
|
}
|
||||||
|
|
||||||
void checkStunKill(cell *dest);
|
void checkStunKill(cell *dest);
|
||||||
|
198
mapeditor.cpp
198
mapeditor.cpp
@ -25,7 +25,6 @@ namespace mapeditor {
|
|||||||
map<int, cell*> modelcell;
|
map<int, cell*> modelcell;
|
||||||
|
|
||||||
void handleKeyMap(int sym, int uni);
|
void handleKeyMap(int sym, int uni);
|
||||||
bool handleKeyFile(int sym, int uni);
|
|
||||||
|
|
||||||
void applyModelcell(cell *c) {
|
void applyModelcell(cell *c) {
|
||||||
if(patterns::whichPattern == 'H') return;
|
if(patterns::whichPattern == 'H') return;
|
||||||
@ -309,31 +308,6 @@ namespace mapeditor {
|
|||||||
|
|
||||||
bool drawplayer = true;
|
bool drawplayer = true;
|
||||||
|
|
||||||
string infix;
|
|
||||||
|
|
||||||
bool hasInfix(const string &s) {
|
|
||||||
if(infix == "") return true;
|
|
||||||
string t = "";
|
|
||||||
for(int i=0; i<size(s); i++) {
|
|
||||||
char c = s[i];
|
|
||||||
char tt = 0;
|
|
||||||
if(c >= 'a' && c <= 'z') tt += c - 32;
|
|
||||||
else if(c >= 'A' && c <= 'Z') tt += c;
|
|
||||||
else if(c == '@') tt += c;
|
|
||||||
if(tt) t += tt;
|
|
||||||
}
|
|
||||||
return t.find(infix) != string::npos;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool editInfix(int uni) {
|
|
||||||
if(uni >= 'A' && uni <= 'Z') infix += uni;
|
|
||||||
else if(uni >= 'a' && uni <= 'z') infix += uni-32;
|
|
||||||
else if(infix != "" && uni == 8) infix = infix.substr(0, size(infix)-1);
|
|
||||||
else if(infix != "" && uni != 0) infix = "";
|
|
||||||
else return false;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
cell *drawcell;
|
cell *drawcell;
|
||||||
|
|
||||||
#if CAP_EDIT
|
#if CAP_EDIT
|
||||||
@ -387,8 +361,6 @@ namespace mapeditor {
|
|||||||
return XLAT(mapeditorhelp) + XLAT(patthelp);
|
return XLAT(mapeditorhelp) + XLAT(patthelp);
|
||||||
}
|
}
|
||||||
|
|
||||||
vector<pair<string, int> > v;
|
|
||||||
|
|
||||||
struct undo_info {
|
struct undo_info {
|
||||||
cell *c;
|
cell *c;
|
||||||
eWall w;
|
eWall w;
|
||||||
@ -451,78 +423,10 @@ namespace mapeditor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool choosefile = false;
|
bool choosefile = false;
|
||||||
bool editext = false;
|
|
||||||
|
|
||||||
#define CDIR 0xC0C0C0
|
#define CDIR 0xC0C0C0
|
||||||
#define CFILE forecolor
|
#define CFILE forecolor
|
||||||
|
|
||||||
bool filecmp(const pair<string,int> &f1, const pair<string,int> &f2) {
|
|
||||||
if(f1.first == "../") return true;
|
|
||||||
if(f2.first == "../") return false;
|
|
||||||
if(f1.second != f2.second)
|
|
||||||
return f1.second == CDIR;
|
|
||||||
return f1.first < f2.first;
|
|
||||||
}
|
|
||||||
|
|
||||||
string filecaption, cfileext;
|
|
||||||
string *cfileptr;
|
|
||||||
|
|
||||||
void drawFileDialog() {
|
|
||||||
displayfr(vid.xres/2, 30 + vid.fsize, 2, vid.fsize,
|
|
||||||
filecaption, forecolor, 8);
|
|
||||||
|
|
||||||
string& cfile = *cfileptr;
|
|
||||||
|
|
||||||
displayfr(vid.xres/2, 34 + vid.fsize * 2, 2, vid.fsize,
|
|
||||||
cfile, editext ? 0xFF00FF : 0xFFFF00, 8);
|
|
||||||
|
|
||||||
displayButton(vid.xres*1/5, 38+vid.fsize * 3,
|
|
||||||
"F2 = save", 2000+SDLK_F2, 8);
|
|
||||||
displayButton(vid.xres*2/5, 38+vid.fsize * 3,
|
|
||||||
"F3 = load", 2000+SDLK_F3, 8);
|
|
||||||
displayButton(vid.xres*3/5, 38+vid.fsize * 3,
|
|
||||||
"F4 = extension", 2000+SDLK_F4, 8);
|
|
||||||
displayButton(vid.xres*4/5, 38+vid.fsize * 3,
|
|
||||||
"Enter = back", 2000+SDLK_RETURN, 8);
|
|
||||||
|
|
||||||
v.clear();
|
|
||||||
|
|
||||||
DIR *d;
|
|
||||||
struct dirent *dir;
|
|
||||||
|
|
||||||
string where = ".";
|
|
||||||
for(int i=0; i<size(cfile); i++)
|
|
||||||
if(cfile[i] == '/' || cfile[i] == '\\')
|
|
||||||
where = cfile.substr(0, i+1);
|
|
||||||
|
|
||||||
d = opendir(where.c_str());
|
|
||||||
if (d) {
|
|
||||||
while ((dir = readdir(d)) != NULL) {
|
|
||||||
string s = dir->d_name;
|
|
||||||
if(s != ".." && s[0] == '.') ;
|
|
||||||
else if(size(s) > 4 && s.substr(size(s)-4) == cfileext)
|
|
||||||
v.push_back(make_pair(s, CFILE));
|
|
||||||
else if(dir->d_type & DT_DIR)
|
|
||||||
v.push_back(make_pair(s+"/", CDIR));
|
|
||||||
}
|
|
||||||
closedir(d);
|
|
||||||
}
|
|
||||||
sort(v.begin(), v.end(), filecmp);
|
|
||||||
|
|
||||||
int q = v.size();
|
|
||||||
int percolumn = (vid.yres-38) / (vid.fsize+5) - 4;
|
|
||||||
int columns = 1 + (q-1) / percolumn;
|
|
||||||
|
|
||||||
for(int i=0; i<q; i++) {
|
|
||||||
int x = 16 + (vid.xres * (i/percolumn)) / columns;
|
|
||||||
int y = 42 + vid.fsize * 4 + (vid.fsize+5) * (i % percolumn);
|
|
||||||
|
|
||||||
displayColorButton(x, y, v[i].first, 1000 + i, 0, 0, v[i].second, 0xFFFF00);
|
|
||||||
}
|
|
||||||
|
|
||||||
keyhandler = handleKeyFile;
|
|
||||||
}
|
|
||||||
|
|
||||||
void displayFunctionKeys() {
|
void displayFunctionKeys() {
|
||||||
int fs = min(vid.fsize + 5, vid.yres/26);
|
int fs = min(vid.fsize + 5, vid.yres/26);
|
||||||
displayButton(8, vid.yres-8-fs*11, XLAT("F1 = help"), SDLK_F1, 0);
|
displayButton(8, vid.yres-8-fs*11, XLAT("F1 = help"), SDLK_F1, 0);
|
||||||
@ -539,12 +443,6 @@ namespace mapeditor {
|
|||||||
displayButton(8, vid.yres-8-fs*2, XLAT("ESC = return to the game"), SDLK_ESCAPE, 0);
|
displayButton(8, vid.yres-8-fs*2, XLAT("ESC = return to the game"), SDLK_ESCAPE, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void vpush(int i, const char *name) {
|
|
||||||
string s = XLATN(name);
|
|
||||||
if(!hasInfix(s)) return;
|
|
||||||
v.push_back(make_pair(s, i));
|
|
||||||
}
|
|
||||||
|
|
||||||
void showMapEditor() {
|
void showMapEditor() {
|
||||||
cmode = sm::MAP;
|
cmode = sm::MAP;
|
||||||
gamescreen(0);
|
gamescreen(0);
|
||||||
@ -763,49 +661,6 @@ namespace mapeditor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool handleKeyFile(int uni, int sym) {
|
|
||||||
string& s(*cfileptr);
|
|
||||||
int i = size(s) - (editext?0:4);
|
|
||||||
if(uni > 2000) sym = uni - 2000;
|
|
||||||
if(sym == SDLK_RETURN || sym == SDLK_KP_ENTER || sym == SDLK_ESCAPE) {
|
|
||||||
popScreen();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
else if(sym == SDLK_F2 || sym == SDLK_F3) {
|
|
||||||
popScreen();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else if(sym == SDLK_F4) {
|
|
||||||
editext = !editext;
|
|
||||||
}
|
|
||||||
else if(sym == SDLK_BACKSPACE && i) {
|
|
||||||
s.erase(i-1, 1);
|
|
||||||
}
|
|
||||||
else if(uni >= 32 && uni < 127) {
|
|
||||||
s.insert(i, s0 + char(uni));
|
|
||||||
}
|
|
||||||
else if(uni >= 1000 && uni <= 1000+size(v)) {
|
|
||||||
string where = "", what = s, whereparent = "../";
|
|
||||||
for(int i=0; i<size(s); i++)
|
|
||||||
if(s[i] == '/') {
|
|
||||||
if(i >= 2 && s.substr(i-2,3) == "../")
|
|
||||||
whereparent = s.substr(0, i+1) + "../";
|
|
||||||
else
|
|
||||||
whereparent = where;
|
|
||||||
where = s.substr(0, i+1), what = s.substr(i+1);
|
|
||||||
}
|
|
||||||
int i = uni - 1000;
|
|
||||||
if(v[i].first == "../") {
|
|
||||||
s = whereparent + what;
|
|
||||||
}
|
|
||||||
else if(v[i].second == CDIR)
|
|
||||||
s = where + v[i].first + what;
|
|
||||||
else
|
|
||||||
s = where + v[i].first;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
cellwalker mouseover_cw(bool fix) {
|
cellwalker mouseover_cw(bool fix) {
|
||||||
int d = neighborId(mouseover, mouseover2);
|
int d = neighborId(mouseover, mouseover2);
|
||||||
if(d == -1 && fix) d = hrand(mouseover->type);
|
if(d == -1 && fix) d = hrand(mouseover->type);
|
||||||
@ -813,7 +668,7 @@ namespace mapeditor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void showList() {
|
void showList() {
|
||||||
v.clear();
|
dialog::v.clear();
|
||||||
if(painttype == 4) painttype = 0;
|
if(painttype == 4) painttype = 0;
|
||||||
switch(painttype) {
|
switch(painttype) {
|
||||||
case 0:
|
case 0:
|
||||||
@ -826,25 +681,25 @@ namespace mapeditor {
|
|||||||
m == moTameBomberbirdMoved || m == moKnightMoved ||
|
m == moTameBomberbirdMoved || m == moKnightMoved ||
|
||||||
m == moDeadBug || m == moLightningBolt || m == moDeadBird ||
|
m == moDeadBug || m == moLightningBolt || m == moDeadBird ||
|
||||||
m == moMouseMoved || m == moPrincessMoved || m == moPrincessArmedMoved) ;
|
m == moMouseMoved || m == moPrincessMoved || m == moPrincessArmedMoved) ;
|
||||||
else if(m == moDragonHead) vpush(i, "Dragon Head");
|
else if(m == moDragonHead) dialog::vpush(i, "Dragon Head");
|
||||||
else vpush(i, minf[i].name);
|
else dialog::vpush(i, minf[i].name);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
for(int i=0; i<ittypes; i++) vpush(i, iinf[i].name);
|
for(int i=0; i<ittypes; i++) dialog::vpush(i, iinf[i].name);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
for(int i=0; i<landtypes; i++) vpush(i, linf[i].name);
|
for(int i=0; i<landtypes; i++) dialog::vpush(i, linf[i].name);
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
for(int i=0; i<walltypes; i++) if(i != waChasmD) vpush(i, winf[i].name);
|
for(int i=0; i<walltypes; i++) if(i != waChasmD) dialog::vpush(i, winf[i].name);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// sort(v.begin(), v.end());
|
// sort(v.begin(), v.end());
|
||||||
|
|
||||||
if(infix != "") mouseovers = infix;
|
if(dialog::infix != "") mouseovers = dialog::infix;
|
||||||
|
|
||||||
int q = v.size();
|
int q = dialog::v.size();
|
||||||
int percolumn = vid.yres / (vid.fsize+5) - 4;
|
int percolumn = vid.yres / (vid.fsize+5) - 4;
|
||||||
int columns = 1 + (q-1) / percolumn;
|
int columns = 1 + (q-1) / percolumn;
|
||||||
|
|
||||||
@ -853,7 +708,7 @@ namespace mapeditor {
|
|||||||
int y = (vid.fsize+5) * (i % percolumn) + vid.fsize*2;
|
int y = (vid.fsize+5) * (i % percolumn) + vid.fsize*2;
|
||||||
|
|
||||||
int actkey = 1000 + i;
|
int actkey = 1000 + i;
|
||||||
string vv = v[i].first;
|
string vv = dialog::v[i].first;
|
||||||
if(i < 9) { vv += ": "; vv += ('1' + i); }
|
if(i < 9) { vv += ": "; vv += ('1' + i); }
|
||||||
|
|
||||||
displayButton(x, y, vv, actkey, 0);
|
displayButton(x, y, vv, actkey, 0);
|
||||||
@ -861,14 +716,14 @@ namespace mapeditor {
|
|||||||
keyhandler = [] (int sym, int uni) {
|
keyhandler = [] (int sym, int uni) {
|
||||||
if(uni >= '1' && uni <= '9') uni = 1000 + uni - '1';
|
if(uni >= '1' && uni <= '9') uni = 1000 + uni - '1';
|
||||||
if(sym == SDLK_RETURN || sym == SDLK_KP_ENTER || sym == '-' || sym == SDLK_KP_MINUS) uni = 1000;
|
if(sym == SDLK_RETURN || sym == SDLK_KP_ENTER || sym == '-' || sym == SDLK_KP_MINUS) uni = 1000;
|
||||||
for(int z=0; z<size(v); z++) if(1000 + z == uni) {
|
for(int z=0; z<size(dialog::v); z++) if(1000 + z == uni) {
|
||||||
paintwhat = v[z].second;
|
paintwhat = dialog::v[z].second;
|
||||||
paintwhat_str = v[z].first;
|
paintwhat_str = dialog::v[z].first;
|
||||||
mousepressed = false;
|
mousepressed = false;
|
||||||
popScreen();
|
popScreen();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if(editInfix(uni)) ;
|
if(dialog::editInfix(uni)) ;
|
||||||
else if(doexiton(sym, uni)) popScreen();
|
else if(doexiton(sym, uni)) popScreen();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -887,10 +742,10 @@ namespace mapeditor {
|
|||||||
if(uni == 'u') applyUndo();
|
if(uni == 'u') applyUndo();
|
||||||
else if(uni == 'v' || sym == SDLK_F10 || sym == SDLK_ESCAPE) popScreen();
|
else if(uni == 'v' || sym == SDLK_F10 || sym == SDLK_ESCAPE) popScreen();
|
||||||
else if(uni >= '0' && uni <= '9') radius = uni - '0';
|
else if(uni >= '0' && uni <= '9') radius = uni - '0';
|
||||||
else if(uni == 'm') pushScreen(showList), painttype = 0, infix = "";
|
else if(uni == 'm') pushScreen(showList), painttype = 0, dialog::infix = "";
|
||||||
else if(uni == 'i') pushScreen(showList), painttype = 1, infix = "";
|
else if(uni == 'i') pushScreen(showList), painttype = 1, dialog::infix = "";
|
||||||
else if(uni == 'l') pushScreen(showList), painttype = 2, infix = "";
|
else if(uni == 'l') pushScreen(showList), painttype = 2, dialog::infix = "";
|
||||||
else if(uni == 'w') pushScreen(showList), painttype = 3, infix = "";
|
else if(uni == 'w') pushScreen(showList), painttype = 3, dialog::infix = "";
|
||||||
else if(uni == 'r') pushScreen(patterns::showPattern);
|
else if(uni == 'r') pushScreen(patterns::showPattern);
|
||||||
else if(uni == 't' && mouseover) {
|
else if(uni == 't' && mouseover) {
|
||||||
playermoved = true;
|
playermoved = true;
|
||||||
@ -917,13 +772,9 @@ namespace mapeditor {
|
|||||||
else
|
else
|
||||||
addMessage(XLAT("Failed to load map from %1", levelfile));
|
addMessage(XLAT("Failed to load map from %1", levelfile));
|
||||||
}
|
}
|
||||||
else if(sym == SDLK_F4) {
|
else if(sym == SDLK_F4)
|
||||||
cfileptr = &levelfile;
|
dialog::openFileDialog(levelfile, XLAT("level to save/load:"), ".lev");
|
||||||
filecaption = XLAT("level to save/load:");
|
#if CAP_SDL
|
||||||
cfileext = ".lev";
|
|
||||||
pushScreen(drawFileDialog);
|
|
||||||
}
|
|
||||||
#if CAP_SDL
|
|
||||||
else if(sym == SDLK_F6) {
|
else if(sym == SDLK_F6) {
|
||||||
saveHighQualityShot();
|
saveHighQualityShot();
|
||||||
}
|
}
|
||||||
@ -1446,13 +1297,8 @@ namespace mapeditor {
|
|||||||
colorkey = true;
|
colorkey = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(sym == SDLK_F4) {
|
if(sym == SDLK_F4)
|
||||||
filecaption = XLAT("pics to save/load:");
|
dialog::openFileDialog(picfile, XLAT("pics to save/load:"), ".pic");
|
||||||
cfileptr = &picfile;
|
|
||||||
cfileext = ".pic";
|
|
||||||
pushScreen(drawFileDialog);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(sym == SDLK_F2)
|
if(sym == SDLK_F2)
|
||||||
savePicFile(picfile);
|
savePicFile(picfile);
|
||||||
|
12
menus.cpp
12
menus.cpp
@ -20,8 +20,8 @@ void showOverview() {
|
|||||||
cmode = sm::ZOOMABLE | sm::OVERVIEW;
|
cmode = sm::ZOOMABLE | sm::OVERVIEW;
|
||||||
DEBB(DF_GRAPH, (debugfile,"show overview\n"));
|
DEBB(DF_GRAPH, (debugfile,"show overview\n"));
|
||||||
|
|
||||||
if(mapeditor::infix != "")
|
if(dialog::infix != "")
|
||||||
mouseovers = mapeditor::infix;
|
mouseovers = dialog::infix;
|
||||||
else {
|
else {
|
||||||
mouseovers = XLAT("world overview");
|
mouseovers = XLAT("world overview");
|
||||||
mouseovers += " ";
|
mouseovers += " ";
|
||||||
@ -39,7 +39,7 @@ void showOverview() {
|
|||||||
|
|
||||||
generateLandList(isLandValid);
|
generateLandList(isLandValid);
|
||||||
|
|
||||||
if(mapeditor::infix != "") {
|
if(dialog::infix != "") {
|
||||||
vector<eLand> filtered;
|
vector<eLand> filtered;
|
||||||
for(eLand l: landlist) {
|
for(eLand l: landlist) {
|
||||||
string s = dnameof(l);
|
string s = dnameof(l);
|
||||||
@ -47,7 +47,7 @@ void showOverview() {
|
|||||||
s += dnameof(treasureType(l));
|
s += dnameof(treasureType(l));
|
||||||
s += "@";
|
s += "@";
|
||||||
s += dnameof(nativeOrbType(l));
|
s += dnameof(nativeOrbType(l));
|
||||||
if(mapeditor::hasInfix(s))
|
if(dialog::hasInfix(s))
|
||||||
filtered.push_back(l);
|
filtered.push_back(l);
|
||||||
}
|
}
|
||||||
if(filtered.size())
|
if(filtered.size())
|
||||||
@ -183,7 +183,7 @@ void showOverview() {
|
|||||||
"mousewheel to gain or lose treasures and orbs quickly (Ctrl = precise, Shift = reverse)."
|
"mousewheel to gain or lose treasures and orbs quickly (Ctrl = precise, Shift = reverse)."
|
||||||
);
|
);
|
||||||
else if(dialog::handlePageButtons(uni)) ;
|
else if(dialog::handlePageButtons(uni)) ;
|
||||||
else if(mapeditor::editInfix(uni)) ;
|
else if(dialog::editInfix(uni)) ;
|
||||||
else if(doexiton(sym, uni)) popScreen();
|
else if(doexiton(sym, uni)) popScreen();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -709,7 +709,7 @@ void setAppropriateOverview() {
|
|||||||
runGeometryExperiments();
|
runGeometryExperiments();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
mapeditor::infix = "";
|
dialog::infix = "";
|
||||||
pushScreen(showOverview);
|
pushScreen(showOverview);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
10
scores.cpp
10
scores.cpp
@ -133,7 +133,7 @@ void showPickScores() {
|
|||||||
scoredisplay = i;
|
scoredisplay = i;
|
||||||
if(!fakescore()) {
|
if(!fakescore()) {
|
||||||
string s = displayfor(NULL);
|
string s = displayfor(NULL);
|
||||||
if(mapeditor::hasInfix(s))
|
if(dialog::hasInfix(s))
|
||||||
if(monsbox[scoredisplay] == monsterpage)
|
if(monsbox[scoredisplay] == monsterpage)
|
||||||
pickscore_options.push_back(make_pair(s, i));
|
pickscore_options.push_back(make_pair(s, i));
|
||||||
}
|
}
|
||||||
@ -159,9 +159,9 @@ void showPickScores() {
|
|||||||
|
|
||||||
scoredisplay = d;
|
scoredisplay = d;
|
||||||
|
|
||||||
mouseovers = mapeditor::infix;
|
mouseovers = dialog::infix;
|
||||||
keyhandler = [] (int sym, int uni) {
|
keyhandler = [] (int sym, int uni) {
|
||||||
if(uni == '/' && mapeditor::infix == "") monsterpage = !monsterpage; else
|
if(uni == '/' && dialog::infix == "") monsterpage = !monsterpage; else
|
||||||
if(uni >= '1' && uni <= '9') uni = uni + 1000 - '1';
|
if(uni >= '1' && uni <= '9') uni = uni + 1000 - '1';
|
||||||
else if(uni >= 1000 && uni < 1000 + size(pickscore_options)) {
|
else if(uni >= 1000 && uni < 1000 + size(pickscore_options)) {
|
||||||
scoredisplay = pickscore_options[uni - 1000].second;
|
scoredisplay = pickscore_options[uni - 1000].second;
|
||||||
@ -169,7 +169,7 @@ void showPickScores() {
|
|||||||
if(columns[i] == scoredisplay) swap(columns[i], columns[curcol]);
|
if(columns[i] == scoredisplay) swap(columns[i], columns[curcol]);
|
||||||
popScreen();
|
popScreen();
|
||||||
}
|
}
|
||||||
else if(mapeditor::editInfix(uni)) ;
|
else if(dialog::editInfix(uni)) ;
|
||||||
else if(doexiton(sym, uni)) popScreen();
|
else if(doexiton(sym, uni)) popScreen();
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -249,7 +249,7 @@ void show() {
|
|||||||
}
|
}
|
||||||
else if(sym >= 1000 && sym <= 1000+POSSCORE)
|
else if(sym >= 1000 && sym <= 1000+POSSCORE)
|
||||||
curcol = sym - 1000;
|
curcol = sym - 1000;
|
||||||
else if(sym == 't') { mapeditor::infix = ""; pushScreen(showPickScores); }
|
else if(sym == 't') { dialog::infix = ""; pushScreen(showPickScores); }
|
||||||
else if(sym == SDLK_UP || sym == 'k' || sym == 'w')
|
else if(sym == SDLK_UP || sym == 'k' || sym == 'w')
|
||||||
scorefrom -= 5;
|
scorefrom -= 5;
|
||||||
else if(sym == SDLK_DOWN || sym == 'j' || sym == 'x')
|
else if(sym == SDLK_DOWN || sym == 'j' || sym == 'x')
|
||||||
|
@ -252,12 +252,8 @@ void showTextureMenu() {
|
|||||||
dialog::handleNavigation(sym, uni);
|
dialog::handleNavigation(sym, uni);
|
||||||
if(uni == 'r')
|
if(uni == 'r')
|
||||||
pushScreen(patterns::showPattern);
|
pushScreen(patterns::showPattern);
|
||||||
else if(uni == 'f') {
|
else if(uni == 'f')
|
||||||
mapeditor::cfileptr = &texturename;
|
dialog::openFileDialog(texturename, XLAT("texture to load:"), ".png");
|
||||||
mapeditor::filecaption = XLAT("texture to load:");
|
|
||||||
mapeditor::cfileext = ".png";
|
|
||||||
pushScreen(mapeditor::drawFileDialog);
|
|
||||||
}
|
|
||||||
else if(uni == 'm') {
|
else if(uni == 'm') {
|
||||||
texture_on = !texture_on;
|
texture_on = !texture_on;
|
||||||
if(texture_on) perform_mapping();
|
if(texture_on) perform_mapping();
|
||||||
|
Loading…
Reference in New Issue
Block a user