void InfoBlock::hit(Player& player) { start_bounce(&player); //if (!stopped) { // ringing->remove_me(); // stopped = true; //} if (dest_pct != 1) { // first hide all other InfoBlocks' messages in same sector Sector* parent = Sector::current(); if (!parent) return; for (Sector::GameObjects::iterator i = parent->gameobjects.begin(); i != parent->gameobjects.end(); ++i) { InfoBlock* block = dynamic_cast<InfoBlock*>(i->get()); if (!block) continue; if (block != this) block->hide_message(); } // show our message show_message(); } else { hide_message(); } }
static void _update_metadata (OlOsdModule *module) { ol_log_func (); ol_assert (module != NULL); ol_player_get_metadata (module->player, module->metadata); clear_lyrics (module); hide_message (module); }
void hide_message_tiff(FILE* fp, tiff_info_t* ti, char* out_file, uint8_t* pixel_data, char* msg, uint8_t reverse_bits) { hide_message(msg, pixel_data, get_data_size_tiff(ti), reverse_bits); put_pixel_data_tiff(fp, out_file, ti, pixel_data); }
void window_unload(Window *window) { hide_message(); menu_layer_destroy(menu_layer); #ifdef PBL_PLATFORM_BASALT status_bar_layer_destroy(bar_layer); #endif window_destroy(window); }
/* assumes files are identical. msg must be nul terminated */ void hide_message_bmp(FILE* fp, bmp_info_t* bi, char* out_file, uint8_t* pixel_data, char* msg, uint8_t reverse_bits) { hide_message(msg, pixel_data, bi->data_size, reverse_bits); put_pixel_data_bmp(fp, out_file, bi, pixel_data); }
static void ol_osd_module_clear_message (struct OlDisplayModule *module) { ol_log_func (); ol_assert (module != NULL); OlOsdModule *priv = ol_display_module_get_data (module); ol_assert (priv != NULL); if (priv->message_source != 0) { g_source_remove (priv->message_source); hide_message (priv); } ol_debug (" clear message done"); }
static void validateDialog(GtkWidget *ignored1, gpointer *ignored2) { gtk_widget_set_sensitive(GTK_WIDGET(signButton), (gtk_combo_box_get_active(tokenCombo) != -1)); hide_message(); if (gtk_combo_box_get_active(tokenCombo) != -1) { GtkTreeIter iter = { .stamp = 0 }; Token *token; token = NULL; if (gtk_combo_box_get_active_iter(tokenCombo, &iter)) { gtk_tree_model_get(GTK_TREE_MODEL(tokens), &iter, 1, &token, -1); gtk_widget_set_sensitive (GTK_WIDGET (passwordEntry), token_getStatus(token) != TokenStatus_NeedPIN); if (token_getStatus(token) == TokenStatus_NeedPIN) { show_inline_message (GTK_MESSAGE_INFO, _("Please enter PIN on pinpad")); } } } }
void Gobby::StatusBar::remove_message(const MessageHandle& handle) { hide_message(handle); m_list.erase(handle); }
Gobby::StatusBar::MessageHandle Gobby::StatusBar::add_message(Gobby::StatusBar::MessageType type, const Glib::ustring& message, const Glib::ustring& dialog_message, unsigned int timeout) { if(m_visible_messages >= 12) { for(MessageHandle iter = m_list.begin(); iter != m_list.end(); ++iter) { if(*iter) { if((*iter)->is_error()) remove_message(iter); else // only hide message because whoever // installed it is expecting to be // able to call remove_message on it hide_message(iter); break; } } } Gtk::HBox* bar = Gtk::manage(new Gtk::HBox); Gtk::Image* image = Gtk::manage(new Gtk::Image( message_type_to_stock_id(type), Gtk::ICON_SIZE_MENU)); bar->pack_start(*image, Gtk::PACK_SHRINK); image->show(); Gtk::Label* label = Gtk::manage( new Gtk::Label(message, GtkCompat::ALIGN_LEFT)); label->set_ellipsize(Pango::ELLIPSIZE_END); bar->pack_start(*label, Gtk::PACK_EXPAND_WIDGET); label->show(); GtkShadowType shadow_type; gtk_widget_style_get(GTK_WIDGET(m_bar_position.gobj()), "shadow-type", &shadow_type, NULL); Gtk::Frame* frame = Gtk::manage(new Gtk::Frame); m_list.push_back(0); Gobby::StatusBar::MessageHandle iter(--m_list.end()); sigc::connection timeout_conn; if(timeout) { timeout_conn = Glib::signal_timeout().connect_seconds( sigc::bind( sigc::bind_return( sigc::mem_fun( *this, &StatusBar::remove_message), false), iter), timeout); } *iter = new Message(frame, message, dialog_message, timeout_conn); ++m_visible_messages; if(dialog_message.empty()) { frame->add(*bar); } else { Gtk::EventBox *eventbox = Gtk::manage(new Gtk::EventBox); frame->add(*eventbox); eventbox->add(*bar); eventbox->signal_button_press_event().connect( sigc::bind_return(sigc::bind( sigc::mem_fun( *this, &StatusBar::on_message_clicked), iter), false)); eventbox->show(); } frame->set_shadow_type(static_cast<Gtk::ShadowType>(shadow_type)); bar->show(); pack_start(*frame, Gtk::PACK_EXPAND_WIDGET); reorder_child(*frame, 0); frame->show(); return iter; }
Gobby::StatusBar::MessageHandle Gobby::StatusBar::add_message(Gobby::StatusBar::MessageType type, const Glib::ustring& message, const Glib::ustring& dialog_message, unsigned int timeout) { if(m_visible_messages >= 12) { for(MessageHandle iter = m_list.begin(); iter != m_list.end(); ++iter) { if(*iter) { if((*iter)->is_error()) remove_message(iter); else // only hide message because whoever // installed it is expecting to be // able to call remove_message on it hide_message(iter); break; } } } Gtk::Grid* grid = Gtk::manage(new Gtk::Grid()); grid->set_column_spacing(6); grid->set_margin_start(2); grid->set_margin_end(2); Gtk::Image* image = Gtk::manage(new Gtk::Image); image->set_from_icon_name(message_type_to_icon_name(type), Gtk::ICON_SIZE_MENU); grid->attach(*image, 0, 0, 1, 1); image->show(); Gtk::Label* label = Gtk::manage( new Gtk::Label(message, Gtk::ALIGN_START)); label->set_ellipsize(Pango::ELLIPSIZE_END); // If we set halign instead, the label will not behave correctly // when ellipsized, because then it has always all space around it // allocated, and the alignment "jumps" around whin resizing the // window due to new characters appearing or disappearing as a result // of the ellipsization. #if GTK_CHECK_VERSION(3, 16, 0) gtk_label_set_xalign(label->gobj(), 0.0); #else label->set_alignment(0.0, 0.0); #endif label->show(); grid->attach(*label, 1, 0, 1, 1); Gtk::Frame* frame = Gtk::manage(new Gtk::Frame); m_list.push_back(0); Gobby::StatusBar::MessageHandle iter(--m_list.end()); sigc::connection timeout_conn; if(timeout) { timeout_conn = Glib::signal_timeout().connect_seconds( sigc::bind( sigc::bind_return( sigc::mem_fun( *this, &StatusBar::remove_message), false), iter), timeout); } *iter = new Message(frame, message, dialog_message, timeout_conn); ++m_visible_messages; if(dialog_message.empty()) { frame->add(*grid); } else { Gtk::EventBox *eventbox = Gtk::manage(new Gtk::EventBox); frame->add(*eventbox); eventbox->add(*grid); eventbox->signal_button_press_event().connect( sigc::bind_return(sigc::bind( sigc::mem_fun( *this, &StatusBar::on_message_clicked), iter), false)); eventbox->show(); } grid->show(); // Insert at front gtk_grid_attach_next_to( gobj(), GTK_WIDGET(frame->gobj()), NULL, GTK_POS_LEFT, 1, 1); frame->set_halign(Gtk::ALIGN_START); frame->set_hexpand(false); frame->set_shadow_type(Gtk::SHADOW_NONE); frame->show(); return iter; }