GTK GUI :

Added fullscreen support (toggle with F11)


git-svn-id: https://svn.code.sf.net/p/vbam/code/trunk@500 a31d4220-a93d-0410-bf67-fe4944624d44
This commit is contained in:
bgk 2008-04-29 19:08:47 +00:00
parent 8b9962839a
commit 2866b9818b
4 changed files with 65 additions and 1 deletions

View File

@ -598,6 +598,20 @@
<property name="use_underline">True</property>
<child>
<widget class="GtkMenu" id="VideoMenu_menu">
<child>
<widget class="GtkImageMenuItem" id="VideoFullscreen">
<property name="visible">True</property>
<property name="label" translatable="yes">gtk-fullscreen</property>
<property name="use_underline">True</property>
<property name="use_stock">True</property>
<accelerator key="F11" signal="activate"/>
</widget>
</child>
<child>
<widget class="GtkSeparatorMenuItem" id="separatormenuitem1">
<property name="visible">True</property>
</widget>
</child>
<child>
<widget class="GtkRadioMenuItem" id="VideoOpenGL">
<property name="visible">True</property>

View File

@ -90,7 +90,8 @@ Window::Window(GtkWindow * _pstWindow, const Glib::RefPtr<Xml> & _poXml) :
m_iJoypadMin (1),
m_iJoypadMax (4),
m_iVideoOutputMin (OutputCairo),
m_iVideoOutputMax (OutputXvideo)
m_iVideoOutputMax (OutputXvideo),
m_bFullscreen (false)
{
m_poXml = _poXml;
m_poFileOpenDialog = NULL;
@ -131,6 +132,9 @@ Window::Window(GtkWindow * _pstWindow, const Glib::RefPtr<Xml> & _poXml) :
Gtk::MenuItem * poMI;
Gtk::CheckMenuItem * poCMI;
// Menu bar
m_poMenuBar = dynamic_cast<Gtk::MenuBar *>(_poXml->get_widget("MenuBar"));
// Video output menu
//
struct
@ -828,6 +832,11 @@ Window::Window(GtkWindow * _pstWindow, const Glib::RefPtr<Xml> & _poXml) :
poCMI, astAutofire[i].m_eKeyFlag));
}
// Fullscreen menu
//
poMI = dynamic_cast<Gtk::MenuItem *>(_poXml->get_widget("VideoFullscreen"));
poMI->signal_activate().connect(sigc::mem_fun(*this, &Window::vOnVideoFullscreen));
// GDB menu
//
poMI = dynamic_cast<Gtk::MenuItem *>(_poXml->get_widget("GdbWait"));
@ -1953,4 +1962,18 @@ void Window::vUpdateGameSlots()
}
}
void Window::vToggleFullscreen()
{
if(!m_bFullscreen)
{
fullscreen();
m_poMenuBar->hide();
}
else
{
unfullscreen();
m_poMenuBar->show();
}
}
} // VBA namespace

View File

@ -159,6 +159,7 @@ protected:
virtual void vOnFrameskipToggled(Gtk::CheckMenuItem * _poCMI, int _iValue);
virtual void vOnThrottleToggled(Gtk::CheckMenuItem * _poCMI, int _iPercent);
virtual void vOnThrottleOther(Gtk::CheckMenuItem * _poCMI);
virtual void vOnVideoFullscreen();
virtual void vOnVideoOutputToggled(Gtk::CheckMenuItem * _poCMI, int _iOutput);
virtual void vOnVideoScaleToggled(Gtk::CheckMenuItem * _poCMI, int _iScale);
virtual void vOnLayerToggled(Gtk::CheckMenuItem * _poCMI, int _iLayer);
@ -198,6 +199,7 @@ protected:
virtual bool on_focus_out_event(GdkEventFocus * _pstEvent);
virtual bool on_key_press_event(GdkEventKey * _pstEvent);
virtual bool on_key_release_event(GdkEventKey * _pstEvent);
virtual bool on_window_state_event(GdkEventWindowState* _pstEvent);
private:
// Config limits
@ -248,6 +250,7 @@ private:
Gtk::CheckMenuItem * m_poFilePauseItem;
Gtk::CheckMenuItem * m_poUseBiosItem;
Gtk::CheckMenuItem * m_poSoundOffItem;
Gtk::MenuBar * m_poMenuBar;
struct SGameSlot
{
@ -269,6 +272,7 @@ private:
std::vector<JoypadConfig> m_oJoypads;
Keymap * m_poKeymap;
int m_bFullscreen;
int m_iScreenWidth;
int m_iScreenHeight;
@ -311,6 +315,7 @@ private:
void vSetThrottle(int _iPercent);
void vSelectBestThrottleItem();
void vUpdateGameSlots();
void vToggleFullscreen();
};
} // namespace VBA

View File

@ -590,6 +590,11 @@ void Window::vOnThrottleOther(Gtk::CheckMenuItem * _poCMI)
vSelectBestThrottleItem();
}
void Window::vOnVideoFullscreen()
{
vToggleFullscreen();
}
void Window::vOnVideoOutputToggled(Gtk::CheckMenuItem * _poCMI, int _iOutput)
{
if (! _poCMI->get_active())
@ -1323,6 +1328,13 @@ bool Window::on_key_press_event(GdkEventKey * _pstEvent)
{
EKey eKey;
// The menu accelerators are disabled when it is hidden
if (_pstEvent->keyval == GDK_F11 && !m_poMenuBar->is_visible())
{
vToggleFullscreen();
return true;
}
if ((_pstEvent->state & Gtk::AccelGroup::get_default_mod_mask())
|| (eKey = m_poKeymap->eGetKey(_pstEvent->hardware_keycode)) == KeyNone)
{
@ -1431,4 +1443,14 @@ bool Window::on_key_release_event(GdkEventKey * _pstEvent)
return true;
}
bool Window::on_window_state_event(GdkEventWindowState* _pstEvent)
{
if (_pstEvent->changed_mask & GDK_WINDOW_STATE_FULLSCREEN)
{
m_bFullscreen = _pstEvent->new_window_state & GDK_WINDOW_STATE_FULLSCREEN;
}
return true;
}
} // namespace VBA