Use util_clip_triangle() in pan_item_tri_new()
[geeqie.git] / src / layout.h
index 61f68c3..a40638c 100644 (file)
 #ifndef LAYOUT_H
 #define LAYOUT_H
 
+#include <glib.h>
+#include <gtk/gtk.h>
+
+#include "options.h"
+#include "typedefs.h"
+
+struct AnimationData;
+struct FileData;
+struct FullScreenData;
+struct ImageWindow;
+struct SlideShowData;
+struct ViewDir;
+struct ViewFile;
+
 #define LAYOUT_ID_CURRENT "_current_"
+#define MAX_SPLIT_IMAGES 4
 
 extern GList *layout_window_list;
 
 
+enum LayoutLocation {
+       LAYOUT_HIDE   = 0,
+       LAYOUT_LEFT   = 1 << 0,
+       LAYOUT_RIGHT  = 1 << 1,
+       LAYOUT_TOP    = 1 << 2,
+       LAYOUT_BOTTOM = 1 << 3
+};
+
+struct LayoutWindow
+{
+       LayoutOptions options;
+
+       FileData *dir_fd;
+
+       /* base */
+
+       GtkWidget *window;
+
+       GtkWidget *main_box;
+
+       GtkWidget *group_box;
+       GtkWidget *h_pane;
+       GtkWidget *v_pane;
+
+       /* menus, path selector */
+
+       GtkActionGroup *action_group;
+       GtkActionGroup *action_group_editors;
+       guint ui_editors_id;
+       GtkUIManager *ui_manager;
+       guint toolbar_merge_id[TOOLBAR_COUNT];
+       GList *toolbar_actions[TOOLBAR_COUNT];
+
+       GtkWidget *path_entry;
+
+       /* image */
+
+       LayoutLocation image_location;
+
+       ImageWindow *image;
+
+       ImageWindow *split_images[MAX_SPLIT_IMAGES];
+       ImageSplitMode split_mode;
+       gint active_split_image;
+
+       GtkWidget *split_image_widget;
+       GtkSizeGroup *split_image_sizegroup;
+
+       /* tools window (float) */
+
+       GtkWidget *tools;
+       GtkWidget *tools_pane;
+
+       GtkWidget *menu_tool_bar; /**< Combined menu and toolbar box */
+       GtkWidget *menu_bar; /**< referenced by lw, exist during whole lw lifetime */
+       /* toolbar */
+
+       GtkWidget *toolbar[TOOLBAR_COUNT]; /**< referenced by lw, exist during whole lw lifetime */
+
+       GtkWidget *back_button;
+
+       /* dir view */
+
+       LayoutLocation dir_location;
+
+       ViewDir *vd;
+       GtkWidget *dir_view;
+
+       /* file view */
+
+       LayoutLocation file_location;
+
+       ViewFile *vf;
+
+       GtkWidget *file_view;
+
+       GtkWidget *info_box; /**< status bar */
+       GtkWidget *info_progress_bar; /**< status bar */
+       GtkWidget *info_sort; /**< status bar */
+       GtkWidget *info_status; /**< status bar */
+       GtkWidget *info_details; /**< status bar */
+       GtkWidget *info_zoom; /**< status bar */
+       GtkWidget *info_pixel; /**< status bar */
+
+       /* slide show */
+
+       SlideShowData *slideshow;
+
+       /* full screen */
+
+       FullScreenData *full_screen;
+
+       /* misc */
+
+       GtkWidget *utility_box; /**< referenced by lw, exist during whole lw lifetime */
+       GtkWidget *utility_paned; /**< between image and bar */
+       GtkWidget *bar_sort;
+       GtkWidget *bar;
+
+       gboolean bar_sort_enabled; /**< Set during start-up, and checked when the editors have loaded */
+
+       GtkWidget *exif_window;
+       GtkWidget *sar_window; /**< Search and Run window */
+
+       AnimationData *animation;
+
+       GtkWidget *log_window;
+};
+
 LayoutWindow *layout_new(FileData *dir_fd, LayoutOptions *lop);
 LayoutWindow *layout_new_with_geometry(FileData *dir_fd, LayoutOptions *lop,
                                       const gchar *geometry);
 LayoutWindow *layout_new_from_config(const gchar **attribute_names, const gchar **attribute_values, gboolean use_commandline);
 void layout_update_from_config(LayoutWindow *lw, const gchar **attribute_names, const gchar **attribute_values);
+LayoutWindow *layout_new_from_default();
 
 void layout_close(LayoutWindow *lw);
 void layout_free(LayoutWindow *lw);
@@ -51,7 +176,7 @@ void layout_write_config(LayoutWindow *lw, GString *outstr, gint indent);
 LayoutWindow *layout_find_by_image(ImageWindow *imd);
 LayoutWindow *layout_find_by_image_fd(ImageWindow *imd);
 LayoutWindow *layout_find_by_layout_id(const gchar *id);
-
+gint layout_compare_options_id(const LayoutWindow *lw, const gchar *id);
 
 const gchar *layout_get_path(LayoutWindow *lw);
 gboolean layout_set_path(LayoutWindow *lw, const gchar *path);
@@ -67,6 +192,7 @@ guint layout_list_count(LayoutWindow *lw, gint64 *bytes);
 FileData *layout_list_get_fd(LayoutWindow *lw, gint index);
 gint layout_list_get_index(LayoutWindow *lw, FileData *fd);
 void layout_list_sync_fd(LayoutWindow *lw, FileData *fd);
+GString *layout_get_window_list();
 
 GList *layout_selection_list(LayoutWindow *lw);
 /* return list of pointers to int for selection */
@@ -75,6 +201,7 @@ guint layout_selection_count(LayoutWindow *lw, gint64 *bytes);
 void layout_select_all(LayoutWindow *lw);
 void layout_select_none(LayoutWindow *lw);
 void layout_select_invert(LayoutWindow *lw);
+void layout_select_list(LayoutWindow *lw, GList *list);
 
 void layout_mark_to_selection(LayoutWindow *lw, gint mark, MarkToSelectionMode mode);
 void layout_selection_to_mark(LayoutWindow *lw, gint mark, SelectionToMarkMode mode);
@@ -84,27 +211,28 @@ void layout_mark_filter_toggle(LayoutWindow *lw, gint mark);
 void layout_refresh(LayoutWindow *lw);
 
 void layout_thumb_set(LayoutWindow *lw, gboolean enable);
-gboolean layout_thumb_get(LayoutWindow *lw);
 
 void layout_marks_set(LayoutWindow *lw, gboolean enable);
-gboolean layout_marks_get(LayoutWindow *lw);
 
-void layout_sort_set(LayoutWindow *lw, SortType type, gboolean ascend);
-gboolean layout_sort_get(LayoutWindow *lw, SortType *type, gboolean *ascend);
+void layout_file_filter_set(LayoutWindow *lw, gboolean enable);
+
+void layout_sort_set_files(LayoutWindow *lw, SortType type, gboolean ascend, gboolean case_sensitive);
+gboolean layout_sort_get(LayoutWindow *lw, SortType *type, gboolean *ascend, gboolean *case_sensitive);
 
 gboolean layout_geometry_get(LayoutWindow *lw, gint *x, gint *y, gint *w, gint *h);
 gboolean layout_geometry_get_dividers(LayoutWindow *lw, gint *h, gint *v);
 
 void layout_views_set(LayoutWindow *lw, DirViewType dir_view_type, FileViewType file_view_type);
-gboolean layout_views_get(LayoutWindow *lw, DirViewType *dir_view_type, FileViewType *file_view_type);
+
+void layout_views_set_sort_dir(LayoutWindow *lw, SortType method, gboolean ascend, gboolean case_sensitive);
 
 void layout_status_update(LayoutWindow *lw, const gchar *text);
 
 void layout_style_set(LayoutWindow *lw, gint style, const gchar *order);
 
-void layout_menu_update_edit(void);
-void layout_styles_update(void);
-void layout_colors_update(void);
+void layout_menu_update_edit();
+void layout_styles_update();
+void layout_colors_update();
 
 
 gboolean layout_geometry_get_tools(LayoutWindow *lw, gint *x, gint *y, gint *w, gint *h, gint *divider_pos);
@@ -115,10 +243,14 @@ void layout_tools_float_toggle(LayoutWindow *lw);
 void layout_tools_hide_toggle(LayoutWindow *lw);
 
 
-void layout_toolbar_toggle(LayoutWindow *lw);
+void layout_selectable_toolbars_toggle(LayoutWindow *lw);
 void layout_info_pixel_set(LayoutWindow *lw, gboolean show);
 
 void layout_split_change(LayoutWindow *lw, ImageSplitMode mode);
 
+void save_layout(LayoutWindow *lw);
+gchar *layout_get_unique_id();
+guint layout_window_count();
+
 #endif
 /* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */