{
if(tooltip_timeout && Time::now()>tooltip_timeout)
{
+ std::string tip;
if(Widget *wdg=get_descendant_at(pointer_x, pointer_y))
{
- const std::string &tip=wdg->get_tooltip();
- if(!tip.empty())
+ tip=wdg->get_tooltip();
+ tooltip_target=wdg;
+ }
+ else
+ {
+ tip=signal_tooltip.emit(pointer_x, pointer_y);
+ tooltip_target=this;
+ }
+
+ if(!tip.empty())
+ {
+ if(!lbl_tooltip)
{
- if(!lbl_tooltip)
- {
- lbl_tooltip=new Label(res);
- add(*lbl_tooltip);
- lbl_tooltip->set_style("tooltip");
- }
-
- lbl_tooltip->set_text(tip);
- lbl_tooltip->autosize();
- const Geometry &tip_geom=lbl_tooltip->get_geometry();
- unsigned x=pointer_x+10;
- unsigned y=pointer_y-10-lbl_tooltip->get_geometry().h;
- if(x+tip_geom.w>geom.w)
- {
- if(pointer_x>static_cast<int>(tip_geom.w+2))
- x=pointer_x-2-tip_geom.w;
- else
- x=geom.w-tip_geom.w;
- }
- lbl_tooltip->set_position(x, y);
- raise(*lbl_tooltip);
- lbl_tooltip->set_visible(true);
- tooltip_timeout=Time::TimeStamp();
- tooltip_target=wdg;
+ lbl_tooltip=new Label(res);
+ add(*lbl_tooltip);
+ lbl_tooltip->set_style("tooltip");
}
+
+ lbl_tooltip->set_text(tip);
+ lbl_tooltip->autosize();
+ const Geometry &tip_geom=lbl_tooltip->get_geometry();
+ unsigned x=pointer_x+10;
+ unsigned y=pointer_y-10-lbl_tooltip->get_geometry().h;
+ if(x+tip_geom.w>geom.w)
+ {
+ if(pointer_x>static_cast<int>(tip_geom.w+2))
+ x=pointer_x-2-tip_geom.w;
+ else
+ x=geom.w-tip_geom.w;
+ }
+ lbl_tooltip->set_position(x, y);
+ raise(*lbl_tooltip);
+ lbl_tooltip->set_visible(true);
}
+
+ tooltip_timeout=Time::TimeStamp();
}
}
if(!tooltip_target)
{
- if(pointer_focus)
- {
- pointer_x=x;
- pointer_y=y;
- tooltip_timeout=Time::now()+700*Time::msec;
- }
- else
- tooltip_timeout=Time::TimeStamp();
+ pointer_x=x;
+ pointer_y=y;
+ tooltip_timeout=Time::now()+700*Time::msec;
}
else if(get_descendant_at(x, y)!=tooltip_target)
{
- lbl_tooltip->set_visible(false);
+ if(lbl_tooltip)
+ lbl_tooltip->set_visible(false);
tooltip_target=0;
}
}