/* $Id$
This file is part of libmspgltk
-Copyright © 2007 Mikko Rasa, Mikkosoft Productions
+Copyright © 2007-2009 Mikko Rasa, Mikkosoft Productions
Distributed under the LGPL
*/
Dropdown::Dropdown(const Resources &r):
Widget(r),
+ Container(r),
list(r),
- dropped(false),
- list_active(false)
+ dropped(false)
{
+ add(list);
list.signal_item_selected.connect(sigc::mem_fun(this, &Dropdown::list_item_selected));
update_style();
}
-Dropdown::~Dropdown()
-{
-}
-
void Dropdown::append(const string &item)
{
list.append(item);
void Dropdown::button_press(int x, int y, unsigned btn)
{
- if(list.get_geometry().is_inside(x, y))
- {
- const Geometry &lgeom=list.get_geometry();
- list.button_press(x-lgeom.x, y-lgeom.y, btn);
- list_active=true;
- }
- else if(dropped)
+ if(dropped)
{
- dropped=false;
- state&=~ACTIVE;
- parent->ungrab_pointer(*this);
+ Container::button_press(x, y, btn);
+ if(!click_focus)
+ {
+ dropped=false;
+ state&=~ACTIVE;
+ signal_ungrab_pointer.emit();
+ }
}
else if(btn==1)
{
dropped=true;
state|=ACTIVE;
-
- if(parent)
- {
- parent->raise(*this);
- parent->grab_pointer(*this);
- }
- }
-}
-
-void Dropdown::button_release(int x, int y, unsigned btn)
-{
- if(list_active)
- {
- const Geometry &lgeom=list.get_geometry();
- list.button_release(x-lgeom.x, y-lgeom.y, btn);
- list_active=false;
- }
-}
-
-void Dropdown::pointer_motion(int x, int y)
-{
- if(list_active)
- {
- const Geometry &lgeom=list.get_geometry();
- list.pointer_motion(x-lgeom.x, y-lgeom.y);
+ signal_grab_pointer.emit();
}
}
unsigned n_items=list.get_n_items();
const Style &stl=list.get_style();
const GL::Font &font=*stl.get_font();
- unsigned h=min(max(n_items, 1U), 20U)*static_cast<unsigned>((font.get_ascent()-font.get_descent())*font.get_default_size());
+ unsigned h=min(max(n_items, 1U), 10U)*static_cast<unsigned>((font.get_ascent()-font.get_descent())*font.get_default_size());
for(std::list<Part>::const_iterator i=stl.get_parts().begin(); i!=stl.get_parts().end(); ++i)
if(i->get_name()=="items")
{
{
if(dropped)
{
- list_active=false;
dropped=false;
state&=~ACTIVE;
- if(parent)
- parent->ungrab_pointer(*this);
+ signal_ungrab_pointer.emit();
}
signal_item_selected.emit(index, item);
void Dropdown::Loader::item(const string &str)
{
- static_cast<Dropdown &>(wdg).append(str);
+ dynamic_cast<Dropdown &>(wdg).append(str);
}
} // namespace GLtk