lsnes/include/platform/wxwidgets/window_mainwindow.hpp
Ilari Liusvaara 1ae101ab44 Merge commit '2cc7666398bf05d2bc702efe99338a5bba75b21c' into rr1-maint
Merge most of the devbranch work (up until splitting the core starts)
into rr1-maint.

This is mostly to make maintenance easier, even if it introduces some
changes that could be bit big into maint branch.

Conflicts:
	src/platform/wxwidgets/mainwindow.cpp
2012-04-05 10:48:29 +03:00

58 lines
1.5 KiB
C++

#ifndef _plat_wxwidgets__window_mainwindow__hpp__included__
#define _plat_wxwidgets__window_mainwindow__hpp__included__
#include "platform/wxwidgets/window_status.hpp"
#include <stack>
#include <wx/string.h>
#include <wx/wx.h>
class wxwin_mainwindow : public wxFrame
{
public:
class panel : public wxPanel
{
public:
panel(wxWindow* win);
void on_paint(wxPaintEvent& e);
void request_paint();
void on_erase(wxEraseEvent& e);
void on_keyboard_down(wxKeyEvent& e);
void on_keyboard_up(wxKeyEvent& e);
void on_mouse(wxMouseEvent& e);
};
wxwin_mainwindow();
void request_paint();
void notify_update() throw();
void notify_update_status() throw();
void notify_resized() throw();
void notify_exit() throw();
void on_close(wxCloseEvent& e);
void menu_start(wxString name);
void menu_special(wxString name, wxMenu* menu);
void menu_special_sub(wxString name, wxMenu* menu);
void menu_entry(int id, wxString name);
void menu_entry_check(int id, wxString name);
void menu_start_sub(wxString name);
void menu_end_sub();
bool menu_ischecked(int id);
void menu_check(int id, bool newstate);
void menu_separator();
void handle_menu_click(wxCommandEvent& e);
private:
void handle_menu_click_cancelable(wxCommandEvent& e);
panel* gpanel;
wxMenu* current_menu;
wxMenuBar* menubar;
wxwin_status::panel* spanel;
bool spanel_shown;
wxFlexGridSizer* toplevel;
std::map<int, wxMenuItem*> checkitems;
std::stack<wxMenu*> upper;
void* ahmenu;
void* sounddev;
void* dmenu;
};
#endif