diff options
author | Benji Dial <benji6283@gmail.com> | 2021-03-08 18:06:38 -0500 |
---|---|---|
committer | Benji Dial <benji6283@gmail.com> | 2021-03-08 18:06:38 -0500 |
commit | fd4557c4adddf710979a42e9f9d470bc8b3f77bd (patch) | |
tree | 485ff6f0514cc1918f8758927a1e2da2198e7d8a /src/user/include/cxx/raleigh/w/multicontainer.h | |
parent | 920f1f010284d59bad86f78355ed90ac2f3e1d2c (diff) | |
download | portland-os-fd4557c4adddf710979a42e9f9d470bc8b3f77bd.tar.gz |
hbox, better painting logic in raleigh
Diffstat (limited to 'src/user/include/cxx/raleigh/w/multicontainer.h')
-rw-r--r-- | src/user/include/cxx/raleigh/w/multicontainer.h | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/src/user/include/cxx/raleigh/w/multicontainer.h b/src/user/include/cxx/raleigh/w/multicontainer.h new file mode 100644 index 0000000..5ced74f --- /dev/null +++ b/src/user/include/cxx/raleigh/w/multicontainer.h @@ -0,0 +1,29 @@ +#ifndef RALEIGH_W_MULTICONTAINER_H +#define RALEIGH_W_MULTICONTAINER_H + +#include <raleigh/widget.h> +#include <structs/dllist.h> + +namespace raleigh { + class multicontainer : public widget { + public: + void notify_window_change() override; + void paint(_pixel_t *pixbuf, uint32_t pitch) override; + void handle_click(coord window_coords, enum mouse_packet::mouse_button click_type, bool up) override; + void notify_has_opaque_parent(widget *parent) override; + void notify_child_size_change(widget &from, coord old_size) override; + void on_mouse_move(coord window_coords) override; + + protected: + //do not modify this list afterward + //set size to determine_size() in derived constructor + multicontainer(dllist<widget &> widgets); + + virtual coord determine_size() = 0; + virtual void set_child_offsets() = 0; + + dllist<widget &> widgets; + }; +} + +#endif
\ No newline at end of file |