|
Problem In Part 3, I've showed you how to display an image in a tooltip.
In this Part 4, we will display an image as well as a markup text in the tooltip as shown below:
Key method used: GtkTooltip::set_markup(), GtkTooltip::set_icon().

Solution
- We use the technique as outlined in Part 2 to display the markup text in a tooltip.
- To display the image, we use the method
GtkTooltip::set_icon().
Important Note: This only works for PHP-GTK v2.0 (or PHP-GTK2 compliled with gtk+ v2.12 and above. If you are using an older version, for linux, you may follow the step-by-step instructions to recompile php-gtk2 with gtk+ v2.12. For windows, please refer to How to install php gtk2 on windows?
Sample Code The following image files are required by the sample code below. Please save a copy of the image files and put them in the same directory where you store the sample code.
 | ball_blue48.png |
 | ball_green48.png |
 | ball_yellow48.png |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
| <?php $window = new GtkWindow(); $window->set_title($argv[0]); $window->connect_simple('destroy', array( 'Gtk', 'main_quit')); $window->set_size_request(400,150); $window->add($vbox = new GtkVBox());
// display title
$title = new GtkLabel(" Display tooltip on GtkButton using GtkTooltip\n". "Part 4 - display tooltip with markup text and image"); $title->modify_font(new PangoFontDescription("Times New Roman Italic 10")); $title->modify_fg(Gtk::STATE_NORMAL, GdkColor::parse("#0000ff")); $title->set_size_request(-1, 60); $vbox->pack_start($title, 0, 0);
$vbox->pack_start($hbox=new GtkHBox(), 0, 0); create_button($hbox, 'Blue', 'ball_blue48.png'); create_button($hbox, 'Green', 'ball_green48.png'); create_button($hbox, 'Yellow', 'ball_yellow48.png');
$window->show_all(); Gtk::main();
function create_button($hbox, $button_label, $img) { $button = new GtkButton($button_label); $button->set_size_request(80, 32); $hbox->pack_start($button, 1, 0); $button->connect('clicked', "on_button", $button_label);
$button->set_property('has-tooltip', true); // note 1
$button->connect('query-tooltip', 'on_tooltip', $img); // note 2
}
function on_button($button, $button_label) {
|
- Note that this is only 70% of the sample code. You have to be a registered member to see the entire sample code. Please login or register.
- Registration is free and immediate.
- Have some doubt about the registration? Please read this forum article.
Explanation
- Enable tooltip on the widget.
- Connect to the signal
'query-tooltip'.
- Set the markup text in tooltip.
- Set the image in the tooltip.
Related Links
User reviews There are no user reviews yet. Note: You have to be a registered member to leave a comment. Free registration here. |