libxputty 0.1
Loading...
Searching...
No Matches
Data Structures | Functions
xlistview.h File Reference

Go to the source code of this file.

Data Structures

struct  ViewList_t
 ViewList_t - struct to hold information for the listview. More...
 

Functions

void listview_set_active_entry (Widget_t *w, int active)
 listview_set_active_entry - set the active listview entry
 
void listview_unset_active_entry (Widget_t *w)
 listview_unset_active_entry - unset the active listview entry
 
Widget_tcreate_listview_viewport (Widget_t *parent, int elem, int width, int height)
 create_listview_viewport - create a viewport on a listview to a Widget_t
 
Widget_tadd_listview (Widget_t *parent, const char *label, int x, int y, int width, int height)
 add_label - add a listview to a Widget_t
 
void listview_mem_free (void *w_, void *user_data)
 listview_mem_free - release additional used memory when destroy the Widget_t
 
void listview_remove_list (Widget_t *listview)
 listview_remove_list - remove the list from a listview Widget_t
 
void listview_set_list (Widget_t *listview, char **list, int list_size)
 listview_set_list - set a list to a listview Widget_t
 
void listview_set_check_dir (Widget_t *listview, int set)
 listview_set_check_dir - set optional check if list item is a directory
 

Function Documentation

◆ add_listview()

Widget_t * add_listview ( Widget_t parent,
const char *  label,
int  x,
int  y,
int  width,
int  height 
)

add_label - add a listview to a Widget_t

Parameters
*parent- pointer to the Widget_t request the label
*label- Label to show on the button
x,y,width,height- the position/geometry to create the label
Returns
Widget_t* - pointer to the Widget_t label struct

Definition at line 72 of file xlistview.c.

73 {
74
75 Widget_t *wid = create_widget(parent->app, parent, x, y, width, height);
76 wid->label = label;
77 wid->scale.gravity = CENTER;
78 wid->flags &= ~USE_TRANSPARENCY;
80 int elem = height/25;
81 wid->adj_y = add_adjustment(wid,0.0, 0.0, 0.0, -1.0,1.0, CL_NONE);
82 wid->adj = wid->adj_y;
83 Widget_t *viewport = create_listview_viewport(wid, elem, width-10, height);
84
85 ViewList_t *filelist = (ViewList_t*)viewport->parent_struct;
86 filelist->folder = surface_get_png(wid, filelist->folder, LDVAR(directory_png));
87 filelist->file = surface_get_png(wid, filelist->file, LDVAR(file_png));
88 filelist->slider = add_vslider(wid, "", width-10, 0, 10, height);
89 filelist->slider->func.expose_callback = _draw_listviewslider;
90 filelist->slider->adj_y = add_adjustment(filelist->slider,0.0, 0.0, 0.0, 1.0,0.0085, CL_VIEWPORTSLIDER);
91 filelist->slider->adj = filelist->slider->adj_y;
92 filelist->slider->func.value_changed_callback = _set_listviewport;
93 filelist->slider->scale.gravity = WESTSOUTH;
94 filelist->slider->flags &= ~USE_TRANSPARENCY;
95 filelist->slider->flags |= NO_AUTOREPEAT | NO_PROPAGATE;
96 filelist->slider->parent_struct = viewport;
97
98 return wid;
99}
xevfunc expose_callback
Definition xwidget.h:85
Gravity gravity
Definition xwidget.h:347
ViewList_t - struct to hold information for the listview.
Definition xlistview.h:42
Widget_t - struct to hold the basic Widget_t info.
Definition xwidget.h:457
Resize_t scale
Definition xwidget.h:525
Adjustment_t * adj_y
Definition xwidget.h:495
Adjustment_t * adj
Definition xwidget.h:497
long long flags
Definition xwidget.h:461
const char * label
Definition xwidget.h:463
void * parent_struct
Definition xwidget.h:473
Func_t func
Definition xwidget.h:481
Xputty * app
Definition xwidget.h:465
Adjustment_t * add_adjustment(Widget_t *w, float std_value, float value, float min_value, float max_value, float step, CL_type type)
*add_adjustment - adding a adjustment to a Widget_t
Definition xadjustment.c:25
@ CL_NONE
Definition xadjustment.h:47
@ CL_VIEWPORTSLIDER
Definition xadjustment.h:65
Widget_t * create_listview_viewport(Widget_t *parent, int elem, int width, int height)
create_listview_viewport - create a viewport on a listview to a Widget_t
Definition xlistview.c:46
void _draw_listviewslider(void *w_, void *user_data)
_draw_listviewslider - draw a slider on the viewport to indicate the view point
void _set_listviewport(void *w_, void *user_data)
_set_listviewport - move the view_port to position by listviewslider state
void _draw_listview(void *w_, void *user_data)
_draw_listview - draw listview on expose call
cairo_surface_t * surface_get_png(Widget_t *w, cairo_surface_t *sf, const unsigned char *name)
surface_get_png - read png into Widget_t xlib surface
Definition xpngloader.c:104
Widget_t * add_vslider(Widget_t *parent, const char *label, int x, int y, int width, int height)
add_vslider - add a vertical slider to a Widget_t connect to func.value_changed_callback to implement...
Definition xslider.c:30
Widget_t * create_widget(Xputty *app, Widget_t *win, int x, int y, int width, int height)
*create_widget - create a widget A Widget_t could only be created as child of a other Widget_t To...
Definition xwidget.c:265
@ CENTER
Definition xwidget.h:320
@ WESTSOUTH
Definition xwidget.h:318
@ NO_AUTOREPEAT
Definition xwidget.h:408
@ NO_PROPAGATE
Definition xwidget.h:416

References _draw_listview(), _draw_listviewslider(), _set_listviewport(), add_adjustment(), add_vslider(), Widget_t::adj, Widget_t::adj_y, Widget_t::app, CENTER, CL_NONE, CL_VIEWPORTSLIDER, create_listview_viewport(), create_widget(), Func_t::expose_callback, ViewList_t::file, Widget_t::flags, ViewList_t::folder, Widget_t::func, Resize_t::gravity, Widget_t::label, NO_AUTOREPEAT, NO_PROPAGATE, Widget_t::parent_struct, Widget_t::scale, ViewList_t::slider, surface_get_png(), Func_t::value_changed_callback, and WESTSOUTH.

Referenced by open_directory_dialog(), and save_file_dialog().

◆ create_listview_viewport()

Widget_t * create_listview_viewport ( Widget_t parent,
int  elem,
int  width,
int  height 
)

create_listview_viewport - create a viewport on a listview to a Widget_t

Parameters
*parent- pointer to the Widget_t the listview should pop over
elem- how many entries to show (max value)
width- define the width of the viewport
height- define the height of the viewport
Returns
Widget_t* - pointer to the Widget_t viewport

Definition at line 46 of file xlistview.c.

46 {
47 Widget_t *wid = create_widget(parent->app, parent, 0, 0, width, height);
49 wid->scale.gravity = NORTHWEST;
50 ViewList_t *filelist;
51 filelist = (ViewList_t*)malloc(sizeof(ViewList_t));
52 filelist->show_items = elem;
53 filelist->check_dir = 0;
54 wid->flags |= HAS_MEM;
55 wid->parent_struct = filelist;
56 float max_value = -elem;
57 wid->adj_y = add_adjustment(wid,0.0, 0.0, 0.0, max_value,1.0, CL_VIEWPORT);
58 wid->adj = wid->adj_y;
69 return wid;
70}
xevfunc configure_notify_callback
Definition xwidget.h:93
evfunc button_release_callback
Definition xwidget.h:101
xevfunc map_notify_callback
Definition xwidget.h:94
evfunc key_press_callback
Definition xwidget.h:104
evfunc double_click_callback
Definition xwidget.h:102
xevfunc leave_callback
Definition xwidget.h:88
xevfunc adj_callback
Definition xwidget.h:89
xevfunc mem_free_callback
Definition xwidget.h:92
evfunc motion_callback
Definition xwidget.h:103
int check_dir
Definition xlistview.h:53
int show_items
Definition xlistview.h:51
@ CL_VIEWPORT
Definition xadjustment.h:57
void listview_mem_free(void *w_, void *user_data)
listview_mem_free - release additional used memory when destroy the Widget_t
Definition xlistview.c:101
void _leave_list(void *w_, void *user_data)
_leave_list - draw list on pointer leave
void _list_key_pressed(void *w_, void *xkey_, void *user_data)
_list_key_pressed - move listview or set active entry
void _reconfigure_listview_viewport(void *w_, void *user_data)
_reconfigure_listview_viewport - reconfigure the viewport adjustment on size changes
void _list_entry_double_clicked(void *w_, void *button_, void *user_data)
_list_entry_double_clicke - forward double click from list entry to list view
void _configure_listview(void *w_, void *user_data)
_configure_listview - configure the viewport on mapping
void _list_motion(void *w_, void *xmotion_, void *user_data)
_list_motion - follow mouse pointer to set prelight item
void _draw_list(void *w_, void *user_data)
_draw_list - draw list on expose call
void _set_listview_viewpoint(void *w_, void *user_data)
_set_listview_viewpoint - move the view_port to position
void _list_entry_released(void *w_, void *button_, void *user_data)
_list_entry_released - move listview or set active entry
void os_set_input_mask(Widget_t *w)
os_set_input_mask - set the Event mask to a Widget_t only work on linux, stub on Windows
@ NORTHWEST
Definition xwidget.h:300
@ HAS_MEM
Definition xwidget.h:406

References _configure_listview(), _draw_list(), _leave_list(), _list_entry_double_clicked(), _list_entry_released(), _list_key_pressed(), _list_motion(), _reconfigure_listview_viewport(), _set_listview_viewpoint(), add_adjustment(), Widget_t::adj, Func_t::adj_callback, Widget_t::adj_y, Widget_t::app, Func_t::button_release_callback, ViewList_t::check_dir, CL_VIEWPORT, Func_t::configure_notify_callback, create_widget(), Func_t::double_click_callback, Func_t::expose_callback, Widget_t::flags, Widget_t::func, Resize_t::gravity, HAS_MEM, Func_t::key_press_callback, Func_t::leave_callback, listview_mem_free(), Func_t::map_notify_callback, Func_t::mem_free_callback, Func_t::motion_callback, NORTHWEST, os_set_input_mask(), Widget_t::parent_struct, Widget_t::scale, and ViewList_t::show_items.

Referenced by add_listview().

◆ listview_mem_free()

void listview_mem_free ( void *  w_,
void *  user_data 
)

listview_mem_free - release additional used memory when destroy the Widget_t

Parameters
*w_- void pointer to the Widget_t
*user_data- void pointer to attached user_data

Definition at line 101 of file xlistview.c.

101 {
102 Widget_t *w = (Widget_t*)w_;
103 ViewList_t *filelist = (ViewList_t*)w->parent_struct;
104 cairo_surface_destroy(filelist->folder);
105 cairo_surface_destroy(filelist->file);
106 free(filelist);
107}

References ViewList_t::file, ViewList_t::folder, and Widget_t::parent_struct.

Referenced by create_listview_viewport().

◆ listview_remove_list()

void listview_remove_list ( Widget_t listview)

listview_remove_list - remove the list from a listview Widget_t

Parameters
*listview- pointer to the Widget_t listview which should show the list

Definition at line 109 of file xlistview.c.

109 {
110 Widget_t* view_port = listview->childlist->childs[0];
111 ViewList_t *filelist = (ViewList_t*)view_port->parent_struct;
112 filelist->list_names = NULL;
113 filelist->list_size = 0;
114 Metrics_t metrics;
115 os_get_window_metrics(listview, &metrics);
116 int height = metrics.height;
117 float elem = height/25;
118 set_adjustment(listview->adj,0.0, 0.0, 0.0, -1.0,1.0, CL_NONE);
119 set_adjustment(view_port->adj,0.0, 0.0, 0.0, -elem,1.0, CL_VIEWPORT);
120 adj_set_value(filelist->slider->adj,0.0);
121}
Widget_t ** childs
Definition xchildlist.h:51
Metrics_t - struct to receive window size, position & visibility Pass this struct to os_get_window_...
Childlist_t * childlist
Definition xwidget.h:499
void adj_set_value(Adjustment_t *adj, float value)
adj_set_value - set the current value to the Adjustment_t
void set_adjustment(Adjustment_t *adj, float std_value, float value, float min_value, float max_value, float step, CL_type type)
*set_adjustment - set a new range to a existing Adjustment_t or create if it not exists yet
Definition xadjustment.c:80
void os_get_window_metrics(Widget_t *w, Metrics_t *metrics)
os_get_window_metrics - Get the Merics_t struct related to a Widget_t

References Widget_t::adj, adj_set_value(), Widget_t::childlist, Childlist_t::childs, CL_NONE, CL_VIEWPORT, Metrics_t::height, ViewList_t::list_names, ViewList_t::list_size, os_get_window_metrics(), Widget_t::parent_struct, set_adjustment(), and ViewList_t::slider.

◆ listview_set_active_entry()

void listview_set_active_entry ( Widget_t w,
int  active 
)

listview_set_active_entry - set the active listview entry

Parameters
*w- void pointer to the Widget_t listview
active- the active entry (int)

Definition at line 28 of file xlistview.c.

28 {
29 if(active<0) return;
30 Widget_t* view_port = w->childlist->childs[0];
31 ViewList_t *filelist = (ViewList_t*)view_port->parent_struct;
32 float value = (float)active;
33 if (value>w->adj->max_value) value = w->adj->max_value;
34 else if (value<w->adj->min_value) value = w->adj->min_value;
35 filelist->active_item = (int)value;
36 adj_set_value(w->adj,filelist->active_item);
37}
float min_value
Definition xadjustment.h:90
float max_value
Definition xadjustment.h:92

References ViewList_t::active_item, Widget_t::adj, adj_set_value(), Widget_t::childlist, Childlist_t::childs, Adjustment_t::max_value, Adjustment_t::min_value, and Widget_t::parent_struct.

Referenced by open_directory_dialog(), and save_file_dialog().

◆ listview_set_check_dir()

void listview_set_check_dir ( Widget_t listview,
int  set 
)

listview_set_check_dir - set optional check if list item is a directory

Parameters
*listview- pointer to the Widget_t listview which should show the list
set- 0 = no check (default); 1 = check

Definition at line 134 of file xlistview.c.

134 {
135 Widget_t* view_port = listview->childlist->childs[0];
136 ViewList_t *filelist = (ViewList_t*)view_port->parent_struct;
137 filelist->check_dir = set;
138}

References ViewList_t::check_dir, Widget_t::childlist, Childlist_t::childs, and Widget_t::parent_struct.

Referenced by save_file_dialog().

◆ listview_set_list()

void listview_set_list ( Widget_t listview,
char **  list,
int  list_size 
)

listview_set_list - set a list to a listview Widget_t

Parameters
*listview- pointer to the Widget_t listview which should show the list
**list- pointer to the list
list_size- how many items contain the list

Definition at line 123 of file xlistview.c.

123 {
124 Widget_t* view_port = listview->childlist->childs[0];
125 ViewList_t *filelist = (ViewList_t*)view_port->parent_struct;
126 filelist->list_names = list;
127 filelist->list_size = list_size;
128 set_adjustment(listview->adj,0.0, 0.0, 0.0, (float)(list_size-1.0),1.0, CL_NONE);
129 float max_value = view_port->adj->max_value+ (float)list_size;
130 set_adjustment(view_port->adj,0.0, 0.0, 0.0, max_value,1.0, CL_VIEWPORT);
131 _configure_listview(view_port, NULL);
132}

References _configure_listview(), Widget_t::adj, Widget_t::childlist, Childlist_t::childs, CL_NONE, CL_VIEWPORT, ViewList_t::list_names, ViewList_t::list_size, Adjustment_t::max_value, Widget_t::parent_struct, and set_adjustment().

◆ listview_unset_active_entry()

void listview_unset_active_entry ( Widget_t w)

listview_unset_active_entry - unset the active listview entry

Parameters
*w- void pointer to the Widget_t listview

Definition at line 39 of file xlistview.c.

39 {
40 Widget_t* view_port = w->childlist->childs[0];
41 ViewList_t *filelist = (ViewList_t*)view_port->parent_struct;
42 filelist->active_item = -1;
43 filelist->prelight_item = -1;
44}

References ViewList_t::active_item, Widget_t::childlist, Childlist_t::childs, Widget_t::parent_struct, and ViewList_t::prelight_item.

Referenced by save_file_dialog().