// Created: 04/01/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows license
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
// For compilers that support precompilation, includes "wx/wx.h".
#include "joytest.h"
+// the application icon (under Windows and OS/2 it is in resources and even
+// though we could still include the XPM here it would be unused)
+#if !defined(__WXMSW__) && !defined(__WXPM__)
+ #include "../sample.xpm"
+#endif
+
MyFrame *frame = NULL;
IMPLEMENT_APP(MyApp)
frame = new MyFrame(NULL, wxT("Joystick Demo"), wxDefaultPosition,
wxSize(500, 400), wxDEFAULT_FRAME_STYLE | wxHSCROLL | wxVSCROLL);
- // Give it an icon (this is ignored in MDI mode: uses resources)
-#ifdef __WXMSW__
- frame->SetIcon(wxIcon(wxT("joyicon")));
-#endif
-#ifdef __X__
- frame->SetIcon(wxIcon(wxT("joyicon.xbm")));
-#endif
+ frame->SetIcon(wxICON(sample));
// Make a menubar
wxMenu *file_menu = new wxMenu;
frame->CenterOnScreen();
frame->Show(true);
- SetTopWindow(frame);
-
return true;
}
void MyCanvas::OnJoystickEvent(wxJoystickEvent& event)
{
- wxClientDC dc(this);
-
- wxPoint pt(event.GetPosition());
-
- // if negative positions are possible then shift everything up
- int xmin = wxGetApp().m_minX;
- int xmax = wxGetApp().m_maxX;
- int ymin = wxGetApp().m_minY;
- int ymax = wxGetApp().m_maxY;
- if (xmin < 0) {
- xmax += abs(xmin);
- pt.x += abs(xmin);
- }
- if (ymin < 0) {
- ymax += abs(ymin);
- pt.y += abs(ymin);
- }
-
- // Scale to canvas size
- int cw, ch;
- GetSize(&cw, &ch);
-
- pt.x = (long) (((double)pt.x/(double)xmax) * cw);
- pt.y = (long) (((double)pt.y/(double)ymax) * ch);
-
- if (xpos > -1 && ypos > -1 && event.IsMove() && event.ButtonIsDown())
+ // We don't have valid (x, y) coordinates for z-move events.
+ if ( !event.IsZMove() )
{
- dc.SetPen(*wxBLACK_PEN);
- dc.DrawLine(xpos, ypos, pt.x, pt.y);
+ wxClientDC dc(this);
+
+ wxPoint pt(event.GetPosition());
+
+ // if negative positions are possible then shift everything up
+ int xmin = wxGetApp().m_minX;
+ int xmax = wxGetApp().m_maxX;
+ int ymin = wxGetApp().m_minY;
+ int ymax = wxGetApp().m_maxY;
+ if (xmin < 0) {
+ xmax += abs(xmin);
+ pt.x += abs(xmin);
+ }
+ if (ymin < 0) {
+ ymax += abs(ymin);
+ pt.y += abs(ymin);
+ }
+
+ // Scale to canvas size
+ int cw, ch;
+ GetSize(&cw, &ch);
+
+ pt.x = (long) (((double)pt.x/(double)xmax) * cw);
+ pt.y = (long) (((double)pt.y/(double)ymax) * ch);
+
+ if (xpos > -1 && ypos > -1 && event.IsMove() && event.ButtonIsDown())
+ {
+ dc.SetPen(*wxBLACK_PEN);
+ dc.DrawLine(xpos, ypos, pt.x, pt.y);
+ }
+
+ xpos = pt.x;
+ ypos = pt.y;
}
- xpos = pt.x;
- ypos = pt.y;
-
#if wxUSE_STATUSBAR
wxString buf;
if (event.ButtonDown())
- buf.Printf(wxT("Joystick (%d, %d) #%i Fire!"), pt.x, pt.y, event.GetButtonChange());
+ buf.Printf(wxT("Joystick (%d, %d) #%i Fire!"), xpos, ypos, event.GetButtonChange());
else
- buf.Printf(wxT("Joystick (%d, %d) "), pt.x, pt.y);
+ buf.Printf(wxT("Joystick (%d, %d) "), xpos, ypos);
/*
for(int i = 0; i < nButtons; ++i)