* Se implementa el menu comandos
12 files changed:
<widget class="GtkMenu" id="mnu_comandos_menu">
<child>
<widget class="GtkMenu" id="mnu_comandos_menu">
<child>
- <widget class="GtkImageMenuItem" id="mnu_detener_servidor">
+ <widget class="GtkImageMenuItem" id="mnu_server_stop">
<property name="visible">True</property>
<property name="label" translatable="yes">Detener Servidor</property>
<property name="use_underline">True</property>
<property name="visible">True</property>
<property name="label" translatable="yes">Detener Servidor</property>
<property name="use_underline">True</property>
// Archivo XML del Padre
Glib::RefPtr<Gnome::Glade::Xml> refXml;
// Archivo XML del Padre
Glib::RefPtr<Gnome::Glade::Xml> refXml;
- Glib::RefPtr<Gdk::Pixbuf> anim_frames[5];
+ Glib::RefPtr<Gdk::Pixbuf> anim_frames[8];
int current_frame;
Gtk::Image *anim;
bool paused;
int current_frame;
Gtk::Image *anim;
bool paused;
virtual bool on_item_clicked(GdkEventButton *, ViewItem *);
virtual bool on_workplace_expose_event(GdkEventExpose *);
virtual bool on_delete_event(GdkEventAny *);
virtual bool on_item_clicked(GdkEventButton *, ViewItem *);
virtual bool on_workplace_expose_event(GdkEventExpose *);
virtual bool on_delete_event(GdkEventAny *);
+ virtual void on_mnu_server_stop_activate();
// Callbacks para las conexiones
void on_conexion_finished();
// Callbacks para las conexiones
void on_conexion_finished();
anim_1.png \
anim_2.png \
anim_3.png \
anim_1.png \
anim_2.png \
anim_3.png \
+anim_4.png \
+anim_5.png \
+anim_6.png \
+anim_7.png
EXTRA_DIST = $(plaqui_DATA)
EXTRA_DIST = $(plaqui_DATA)
Principal::Principal(BaseObjectType *co, const Glib::RefPtr<Gnome::Glade::Xml> &rg):Gtk::Window(co),refXml(rg)
{
Principal::Principal(BaseObjectType *co, const Glib::RefPtr<Gnome::Glade::Xml> &rg):Gtk::Window(co),refXml(rg)
{
- Gtk::MenuItem *conect=0, *exit=0, *about=0, *mnu_prop=0, *mnu_disconnect=0;
+ Gtk::MenuItem *conect=0, *exit=0, *about=0, *mnu_prop=0, *mnu_disconnect=0, *server_stop=0;
Gtk::Button *bar_connect=0;
txt_view = 0;
work_place = 0;
Gtk::Button *bar_connect=0;
txt_view = 0;
work_place = 0;
anim_frames[2] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_2.png");
anim_frames[3] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_3.png");
anim_frames[4] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_4.png");
anim_frames[2] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_2.png");
anim_frames[3] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_3.png");
anim_frames[4] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_4.png");
+ anim_frames[5] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_5.png");
+ anim_frames[6] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_6.png");
+ anim_frames[7] = Gdk::Pixbuf::create_from_file(PACKAGE_DATA_DIR"/plaqui-client/pixmaps/anim_7.png");
current_frame = 0;
anim = 0;
current_frame = 0;
anim = 0;
rg->get_widget("mnu_file_disconnect", mnu_disconnect);
rg->get_widget("mnu_file_exit", exit);
rg->get_widget("mnu_help_about", about);
rg->get_widget("mnu_file_disconnect", mnu_disconnect);
rg->get_widget("mnu_file_exit", exit);
rg->get_widget("mnu_help_about", about);
+ rg->get_widget("mnu_server_stop", server_stop);
rg->get_widget("mnu_prop", mnu_prop);
rg->get_widget_derived("dlg_property", dlg_property);
rg->get_widget_derived("dlgConectar", dlg_conectar);
rg->get_widget("mnu_prop", mnu_prop);
rg->get_widget_derived("dlg_property", dlg_property);
rg->get_widget_derived("dlgConectar", dlg_conectar);
dlg_conectar->get_ok_button()->signal_clicked().connect( SigC::slot(*this, &Principal::on_dlg_connect_ok) );
mnu_prop->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_property));
mnu_disconnect->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_disconnect));
dlg_conectar->get_ok_button()->signal_clicked().connect( SigC::slot(*this, &Principal::on_dlg_connect_ok) );
mnu_prop->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_property));
mnu_disconnect->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_disconnect));
+ server_stop->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_server_stop_activate));
conect->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_connect));
bar_connect->signal_clicked().connect( SigC::slot(*this, &Principal::on_mnu_file_connect));
exit->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_exit));
conect->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_connect));
bar_connect->signal_clicked().connect( SigC::slot(*this, &Principal::on_mnu_file_connect));
exit->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_exit));
Principal::~Principal()
{
Principal::~Principal()
{
- if (conexion) {
- conexion->finish();
- }
- // Espera a que termine realmente.
- while (conexion) {
- Glib::usleep(100000); // 0,1 segundo
- }
}
void Principal::on_realize()
}
void Principal::on_realize()
void Principal::on_mnu_file_exit()
{
on_mnu_file_disconnect();
void Principal::on_mnu_file_exit()
{
on_mnu_file_disconnect();
+ if (conexion) {
+ conexion->finish();
+ }
+ // Espera a que termine realmente.
+ while (conexion) {
+ Glib::usleep(100000); // 0,1 segundo
+ }
+void Principal::on_mnu_server_stop_activate()
+{
+ if (conexion == NULL) return;
+
+ PlaQui::Server::Command c("server", "stop");
+ conexion->send(c);
+}
+
void Principal::on_btn_activar_clicked()
{
if ((conexion == NULL) || (last_selected == NULL)) return;
void Principal::on_btn_activar_clicked()
{
if ((conexion == NULL) || (last_selected == NULL)) return;
c2.add_arg(conexion->get_host());
c2.add_arg(conexion->get_port());
conexion->send(c2);
c2.add_arg(conexion->get_host());
c2.add_arg(conexion->get_port());
conexion->send(c2);
}
void Principal::on_mnu_file_connect()
}
void Principal::on_mnu_file_connect()
if (!paused) {
current_frame++;
if (!paused) {
current_frame++;
- if (current_frame > 4) {
+ if (current_frame > 7) {
current_frame = 0;
}
anim->set(anim_frames[current_frame]);
current_frame = 0;
}
anim->set(anim_frames[current_frame]);
delete i->second;
}
mapItems.clear();
delete i->second;
}
mapItems.clear();
}
void Principal::on_conexion_ok(const std::string &body)
}
void Principal::on_conexion_ok(const std::string &body)