1
0
Fork 0

Nicolas: make screenshot target dir configurable (idea and first draft)

--prop:sim/paths/screenshot-dir=/tmp
This commit is contained in:
mfranz 2008-04-26 22:34:46 +00:00
parent 8f509ba82a
commit c8f2013c77
3 changed files with 30 additions and 33 deletions

View file

@ -46,7 +46,7 @@ extern void mkDialog(const char *txt);
extern void guiErrorMessage(const char *txt); extern void guiErrorMessage(const char *txt);
extern void guiErrorMessage(const char *txt, const sg_throwable &throwable); extern void guiErrorMessage(const char *txt, const sg_throwable &throwable);
extern void fgDumpSnapShot(); extern bool fgDumpSnapShot();
extern void fgDumpSceneGraph(); extern void fgDumpSceneGraph();
extern void fgDumpTerrainBranch(); extern void fgDumpTerrainBranch();

View file

@ -102,14 +102,6 @@ extern void fgUpdateHUD( GLfloat x_start, GLfloat y_start,
#endif #endif
// TODO: remove after the last hardcoded dialog has died
const char *gui_msg_OK = "OK";
const char *gui_msg_NO = "NO";
const char *gui_msg_YES = "YES";
const char *gui_msg_CANCEL = "CANCEL";
const char *gui_msg_RESET = "RESET";
const __fg_gui_fn_t __fg_gui_fn[] = { const __fg_gui_fn_t __fg_gui_fn[] = {
// File // File
@ -531,13 +523,9 @@ void fgHiResDumpWrapper ( puObject *obj ) {
// do a screen snap shot // do a screen snap shot
void fgDumpSnapShot () { bool fgDumpSnapShot () {
bool show_pu_cursor = false; bool show_pu_cursor = false;
char *filename = new char [24]; static SGConstPropertyNode_ptr master_freeze = fgGetNode("/sim/freeze/master");
static int count = 1;
static const SGPropertyNode *master_freeze
= fgGetNode("/sim/freeze/master");
bool freeze = master_freeze->getBoolValue(); bool freeze = master_freeze->getBoolValue();
if ( !freeze ) { if ( !freeze ) {
@ -546,15 +534,14 @@ void fgDumpSnapShot () {
TurnCursorOff(); TurnCursorOff();
if ( !puCursorIsHidden() ) { if ( !puCursorIsHidden() ) {
show_pu_cursor = true; show_pu_cursor = true;
puHideCursor(); puHideCursor();
} }
fgSetBool("/sim/signals/screenshot", true); fgSetBool("/sim/signals/screenshot", true);
FGRenderer *renderer = globals->get_renderer(); FGRenderer *renderer = globals->get_renderer();
// renderer->init();
renderer->resize( fgGetInt("/sim/startup/xsize"), renderer->resize( fgGetInt("/sim/startup/xsize"),
fgGetInt("/sim/startup/ysize") ); fgGetInt("/sim/startup/ysize") );
// we need two render frames here to clear the menu and cursor // we need two render frames here to clear the menu and cursor
// ... not sure why but doing an extra fgRenderFrame() shouldn't // ... not sure why but doing an extra fgRenderFrame() shouldn't
@ -562,26 +549,36 @@ void fgDumpSnapShot () {
renderer->update( true ); renderer->update( true );
renderer->update( true ); renderer->update( true );
while (count < 1000) { string dir = fgGetString("/sim/paths/screenshot-dir", fgGetString("/sim/fg-current"));
FILE *fp; SGPath path(dir + '/');
snprintf(filename, 24, "fgfs-screen-%03d.ppm", count++); if (path.create_dir( 0755 )) {
if ( (fp = fopen(filename, "r")) == NULL ) SG_LOG(SG_GENERAL, SG_ALERT, "Cannot create screenshot directory '"
break; << dir << "'. Trying home directory.");
fclose(fp); dir = fgGetString("/sim/fg-home");
} }
int result = sg_glDumpWindow(filename, char filename[24];
static int count = 1;
while (count < 1000) {
snprintf(filename, 24, "fgfs-screen-%03d.ppm", count++);
SGPath p(dir);
p.append(filename);
if (!p.exists()) {
path.set(p.str());
break;
}
}
int result = sg_glDumpWindow(path.c_str(),
fgGetInt("/sim/startup/xsize"), fgGetInt("/sim/startup/xsize"),
fgGetInt("/sim/startup/ysize")); fgGetInt("/sim/startup/ysize"));
fgSetString("/sim/last-screenshot", result ? filename : "");
fgSetString("/sim/paths/screenshot-last", path.c_str());
fgSetBool("/sim/signals/screenshot", false); fgSetBool("/sim/signals/screenshot", false);
//mkDialog (message.c_str());
delete [] filename;
if ( show_pu_cursor ) { if ( show_pu_cursor ) {
puShowCursor(); puShowCursor();
} }
TurnCursorOn(); TurnCursorOn();
@ -589,6 +586,7 @@ void fgDumpSnapShot () {
if ( !freeze ) { if ( !freeze ) {
fgSetBool("/sim/freeze/master", false); fgSetBool("/sim/freeze/master", false);
} }
return result != 0;
} }
// do an entire scenegraph dump // do an entire scenegraph dump

View file

@ -463,8 +463,7 @@ do_view_cycle (const SGPropertyNode * arg)
static bool static bool
do_screen_capture (const SGPropertyNode * arg) do_screen_capture (const SGPropertyNode * arg)
{ {
fgDumpSnapShot(); return fgDumpSnapShot();
return true;
} }
static bool static bool