mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Merge branch 'freediving-tweaks' of git://github.com/mguentner/subsurface
Merge freediving tweaks (zoom in on short dives etc) from Maximilian Güntner. Trivial conflicts in display.h due to unrelated printing stuff just happening to be added nearby. * 'freediving-tweaks' of git://github.com/mguentner/subsurface: moved zoomed_plot to display.h plot the time with a fixed padding (leading zero) updated/corrected comment added "Zoom" button and improved scaling fixed indentation use increments that make sense for 600 seconds Plot shorter (apnea) dives with a reasonable scale
This commit is contained in:
commit
9d46581913
3 changed files with 52 additions and 15 deletions
|
@ -31,4 +31,6 @@ struct options {
|
||||||
gboolean print_profiles;
|
gboolean print_profiles;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
extern char zoomed_plot;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
11
gtk-gui.c
11
gtk-gui.c
|
@ -729,6 +729,13 @@ static void view_three(GtkWidget *w, gpointer data)
|
||||||
gtk_paned_set_position(GTK_PANED(vpane), requisition.height + 6);
|
gtk_paned_set_position(GTK_PANED(vpane), requisition.height + 6);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void toggle_zoom(GtkWidget *w, gpointer data)
|
||||||
|
{
|
||||||
|
zoomed_plot = (zoomed_plot)?0 : 1;
|
||||||
|
/*Update dive*/
|
||||||
|
repaint_dive();
|
||||||
|
}
|
||||||
|
|
||||||
static GtkActionEntry menu_items[] = {
|
static GtkActionEntry menu_items[] = {
|
||||||
{ "FileMenuAction", NULL, "File", NULL, NULL, NULL},
|
{ "FileMenuAction", NULL, "File", NULL, NULL, NULL},
|
||||||
{ "LogMenuAction", NULL, "Log", NULL, NULL, NULL},
|
{ "LogMenuAction", NULL, "Log", NULL, NULL, NULL},
|
||||||
|
@ -749,7 +756,8 @@ static GtkActionEntry menu_items[] = {
|
||||||
{ "ViewList", NULL, "List", CTRLCHAR "1", NULL, G_CALLBACK(view_list) },
|
{ "ViewList", NULL, "List", CTRLCHAR "1", NULL, G_CALLBACK(view_list) },
|
||||||
{ "ViewProfile", NULL, "Profile", CTRLCHAR "2", NULL, G_CALLBACK(view_profile) },
|
{ "ViewProfile", NULL, "Profile", CTRLCHAR "2", NULL, G_CALLBACK(view_profile) },
|
||||||
{ "ViewInfo", NULL, "Info", CTRLCHAR "3", NULL, G_CALLBACK(view_info) },
|
{ "ViewInfo", NULL, "Info", CTRLCHAR "3", NULL, G_CALLBACK(view_info) },
|
||||||
{ "ViewThree", NULL, "Three", CTRLCHAR "4", NULL, G_CALLBACK(view_three) },
|
{ "ViewThree", NULL, "Three", CTRLCHAR "4", NULL, G_CALLBACK(view_three) },
|
||||||
|
{ "ToggleZoom", NULL, "Toggle Zoom", CTRLCHAR "0", NULL, G_CALLBACK(toggle_zoom) },
|
||||||
};
|
};
|
||||||
static gint nmenu_items = sizeof (menu_items) / sizeof (menu_items[0]);
|
static gint nmenu_items = sizeof (menu_items) / sizeof (menu_items[0]);
|
||||||
|
|
||||||
|
@ -771,6 +779,7 @@ static const gchar* ui_string = " \
|
||||||
<menuitem name=\"Add Dive\" action=\"AddDive\" /> \
|
<menuitem name=\"Add Dive\" action=\"AddDive\" /> \
|
||||||
<separator name=\"Separator\"/> \
|
<separator name=\"Separator\"/> \
|
||||||
<menuitem name=\"Renumber\" action=\"Renumber\" /> \
|
<menuitem name=\"Renumber\" action=\"Renumber\" /> \
|
||||||
|
<menuitem name=\"Toggle Zoom\" action=\"ToggleZoom\" /> \
|
||||||
<menu name=\"View\" action=\"ViewMenuAction\"> \
|
<menu name=\"View\" action=\"ViewMenuAction\"> \
|
||||||
<menuitem name=\"List\" action=\"ViewList\" /> \
|
<menuitem name=\"List\" action=\"ViewList\" /> \
|
||||||
<menuitem name=\"Profile\" action=\"ViewProfile\" /> \
|
<menuitem name=\"Profile\" action=\"ViewProfile\" /> \
|
||||||
|
|
54
profile.c
54
profile.c
|
@ -14,6 +14,7 @@
|
||||||
#include "color.h"
|
#include "color.h"
|
||||||
|
|
||||||
int selected_dive = 0;
|
int selected_dive = 0;
|
||||||
|
char zoomed_plot = 0;
|
||||||
|
|
||||||
typedef enum { STABLE, SLOW, MODERATE, FAST, CRAZY } velocity_t;
|
typedef enum { STABLE, SLOW, MODERATE, FAST, CRAZY } velocity_t;
|
||||||
|
|
||||||
|
@ -180,22 +181,40 @@ static void dump_pi (struct plot_info *pi)
|
||||||
* When showing dive profiles, we scale things to the
|
* When showing dive profiles, we scale things to the
|
||||||
* current dive. However, we don't scale past less than
|
* current dive. However, we don't scale past less than
|
||||||
* 30 minutes or 90 ft, just so that small dives show
|
* 30 minutes or 90 ft, just so that small dives show
|
||||||
* up as such.
|
* up as such unless zoom is enabled.
|
||||||
* we also need to add 180 seconds at the end so the min/max
|
* We also need to add 180 seconds at the end so the min/max
|
||||||
* plots correctly
|
* plots correctly
|
||||||
*/
|
*/
|
||||||
static int get_maxtime(struct plot_info *pi)
|
static int get_maxtime(struct plot_info *pi)
|
||||||
{
|
{
|
||||||
int seconds = pi->maxtime;
|
int seconds = pi->maxtime;
|
||||||
/* min 30 minutes, rounded up to 5 minutes, with at least 2.5 minutes to spare */
|
if (zoomed_plot) {
|
||||||
return MAX(30*60, ROUND_UP(seconds+150, 60*5));
|
/* Rounded up to one minute, with at least 2.5 minutes to
|
||||||
|
* spare.
|
||||||
|
* For dive times shorter than 10 minutes, we use seconds/4 to
|
||||||
|
* calculate the space dynamically.
|
||||||
|
* This is seamless since 600/4 = 150.
|
||||||
|
*/
|
||||||
|
if ( seconds < 600 )
|
||||||
|
return ROUND_UP(seconds+seconds/4, 60);
|
||||||
|
else
|
||||||
|
return ROUND_UP(seconds+150, 60);
|
||||||
|
} else {
|
||||||
|
/* min 30 minutes, rounded up to 5 minutes, with at least 2.5 minutes to spare */
|
||||||
|
return MAX(30*60, ROUND_UP(seconds+150, 60*5));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int get_maxdepth(struct plot_info *pi)
|
static int get_maxdepth(struct plot_info *pi)
|
||||||
{
|
{
|
||||||
unsigned mm = pi->maxdepth;
|
unsigned mm = pi->maxdepth;
|
||||||
/* Minimum 30m, rounded up to 10m, with at least 3m to spare */
|
if (zoomed_plot) {
|
||||||
return MAX(30000, ROUND_UP(mm+3000, 10000));
|
/* Rounded up to 10m, with at least 3m to spare */
|
||||||
|
return ROUND_UP(mm+3000, 10000);
|
||||||
|
} else {
|
||||||
|
/* Minimum 30m, rounded up to 10m, with at least 3m to spare */
|
||||||
|
return MAX(30000, ROUND_UP(mm+3000, 10000));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -443,20 +462,21 @@ static void plot_depth_profile(struct graphics_context *gc, struct plot_info *pi
|
||||||
int sec, depth;
|
int sec, depth;
|
||||||
struct plot_data *entry;
|
struct plot_data *entry;
|
||||||
int maxtime, maxdepth, marker;
|
int maxtime, maxdepth, marker;
|
||||||
int increments[4] = { 5*60, 10*60, 15*60, 30*60 };
|
int increments[8] = { 10, 20, 30, 60, 5*60, 10*60, 15*60, 30*60 };
|
||||||
|
|
||||||
/* Get plot scaling limits */
|
/* Get plot scaling limits */
|
||||||
maxtime = get_maxtime(pi);
|
maxtime = get_maxtime(pi);
|
||||||
maxdepth = get_maxdepth(pi);
|
maxdepth = get_maxdepth(pi);
|
||||||
|
|
||||||
/* Time markers: at most every 5 min, but no more than 12 markers
|
/* Time markers: at most every 10 seconds, but no more than 12 markers.
|
||||||
* and for convenience we do 5, 10, 15 or 30 min intervals.
|
* We start out with 10 seconds and increment up to 30 minutes,
|
||||||
|
* depending on the dive time.
|
||||||
* This allows for 6h dives - enough (I hope) for even the craziest
|
* This allows for 6h dives - enough (I hope) for even the craziest
|
||||||
* divers - but just in case, for those 8h depth-record-breaking dives,
|
* divers - but just in case, for those 8h depth-record-breaking dives,
|
||||||
* we double the interval if this still doesn't get us to 12 or fewer
|
* we double the interval if this still doesn't get us to 12 or fewer
|
||||||
* time markers */
|
* time markers */
|
||||||
i = 0;
|
i = 0;
|
||||||
while (maxtime / increments[i] > 12 && i < 4)
|
while (maxtime / increments[i] > 12 && i < 8)
|
||||||
i++;
|
i++;
|
||||||
incr = increments[i];
|
incr = increments[i];
|
||||||
while (maxtime / incr > 12)
|
while (maxtime / incr > 12)
|
||||||
|
@ -473,11 +493,17 @@ static void plot_depth_profile(struct graphics_context *gc, struct plot_info *pi
|
||||||
}
|
}
|
||||||
cairo_stroke(cr);
|
cairo_stroke(cr);
|
||||||
|
|
||||||
/* now the text on every second time marker */
|
/* now the text on the time markers */
|
||||||
text_render_options_t tro = {10, TIME_TEXT, CENTER, TOP};
|
text_render_options_t tro = {10, TIME_TEXT, CENTER, TOP};
|
||||||
for (i = incr; i < maxtime; i += 2 * incr)
|
if (maxtime < 600) {
|
||||||
plot_text(gc, &tro, i, 1, "%d", i/60);
|
/* Be a bit more verbose with shorter dives */
|
||||||
|
for (i = incr; i < maxtime; i += incr)
|
||||||
|
plot_text(gc, &tro, i, 1, "%02d:%02d", i/60, i%60);
|
||||||
|
} else {
|
||||||
|
/* Only render the time on every second marker for normal dives */
|
||||||
|
for (i = incr; i < maxtime; i += 2 * incr)
|
||||||
|
plot_text(gc, &tro, i, 1, "%d", i/60);
|
||||||
|
}
|
||||||
/* Depth markers: every 30 ft or 10 m*/
|
/* Depth markers: every 30 ft or 10 m*/
|
||||||
gc->leftx = 0; gc->rightx = 1.0;
|
gc->leftx = 0; gc->rightx = 1.0;
|
||||||
gc->topy = 0; gc->bottomy = maxdepth;
|
gc->topy = 0; gc->bottomy = maxdepth;
|
||||||
|
|
Loading…
Add table
Reference in a new issue