Changed a few #include <xxx.h> to #include "xxx.h"
Added endl operator to wxTextStream Corrrected a few misbehaviours in wxFileDialog, Corrected tab traversal a bit Corrected wxImage::SetData() to not copy, but take the data and care for ref couting as well git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3436 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
5586805bfa
commit
ed58dbeab6
@ -16,7 +16,7 @@
|
|||||||
#pragma interface "datstrm.h"
|
#pragma interface "datstrm.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/stream.h>
|
#include "wx/stream.h"
|
||||||
|
|
||||||
#if wxUSE_STREAMS
|
#if wxUSE_STREAMS
|
||||||
|
|
||||||
|
@ -16,13 +16,13 @@
|
|||||||
# pragma interface
|
# pragma interface
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/setup.h>
|
#include "wx/setup.h"
|
||||||
|
|
||||||
#if wxUSE_DYNLIB_CLASS
|
#if wxUSE_DYNLIB_CLASS
|
||||||
|
|
||||||
#include <wx/string.h>
|
#include "wx/string.h"
|
||||||
#include <wx/list.h>
|
#include "wx/list.h"
|
||||||
#include <wx/hash.h>
|
#include "wx/hash.h"
|
||||||
|
|
||||||
// this is normally done by configure, but I leave it here for now...
|
// this is normally done by configure, but I leave it here for now...
|
||||||
#if defined(__UNIX__) && !(defined(HAVE_DLOPEN) || defined(HAVE_SHL_LOAD))
|
#if defined(__UNIX__) && !(defined(HAVE_DLOPEN) || defined(HAVE_SHL_LOAD))
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
#pragma interface "filefn.h"
|
#pragma interface "filefn.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/list.h>
|
#include "wx/list.h"
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// constants
|
// constants
|
||||||
|
@ -23,7 +23,7 @@ limitation)
|
|||||||
#pragma implementation
|
#pragma implementation
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/wxprec.h>
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
#ifdef __BORDLANDC__
|
#ifdef __BORDLANDC__
|
||||||
#pragma hdrstop
|
#pragma hdrstop
|
||||||
@ -32,11 +32,10 @@ limitation)
|
|||||||
#if wxUSE_FS_INET && wxUSE_STREAMS && wxUSE_SOCKETS
|
#if wxUSE_FS_INET && wxUSE_STREAMS && wxUSE_SOCKETS
|
||||||
|
|
||||||
#ifndef WXPRECOMP
|
#ifndef WXPRECOMP
|
||||||
#include <wx/wx.h>
|
#include "wx/wx.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/filesys.h>
|
#include "wx/filesys.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#pragma implementation
|
#pragma implementation
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/wxprec.h>
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
#ifdef __BORDLANDC__
|
#ifdef __BORDLANDC__
|
||||||
#pragma hdrstop
|
#pragma hdrstop
|
||||||
@ -21,12 +21,10 @@
|
|||||||
|
|
||||||
|
|
||||||
#ifndef WXPRECOMP
|
#ifndef WXPRECOMP
|
||||||
#include <wx/wx.h>
|
#include "wx/wx.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/filesys.h>
|
#include "wx/filesys.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------
|
//--------------------------------------------------------------------------------
|
||||||
// wxZipFSHandler
|
// wxZipFSHandler
|
||||||
|
@ -130,6 +130,9 @@ public:
|
|||||||
|
|
||||||
void OnNavigationKey(wxNavigationKeyEvent& event);
|
void OnNavigationKey(wxNavigationKeyEvent& event);
|
||||||
|
|
||||||
|
// overridden from wxWindow to make tabbing work
|
||||||
|
void SetFocus();
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
void SetConstraintSizes(bool recurse);
|
void SetConstraintSizes(bool recurse);
|
||||||
|
@ -130,6 +130,9 @@ public:
|
|||||||
|
|
||||||
void OnNavigationKey(wxNavigationKeyEvent& event);
|
void OnNavigationKey(wxNavigationKeyEvent& event);
|
||||||
|
|
||||||
|
// overridden from wxWindow to make tabbing work
|
||||||
|
void SetFocus();
|
||||||
|
|
||||||
// implementation
|
// implementation
|
||||||
|
|
||||||
void SetConstraintSizes(bool recurse);
|
void SetConstraintSizes(bool recurse);
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#ifndef _WX_WXMMSTREAM_H__
|
#ifndef _WX_WXMMSTREAM_H__
|
||||||
#define _WX_WXMMSTREAM_H__
|
#define _WX_WXMMSTREAM_H__
|
||||||
|
|
||||||
#include <wx/stream.h>
|
#include "wx/stream.h"
|
||||||
|
|
||||||
#if wxUSE_STREAMS
|
#if wxUSE_STREAMS
|
||||||
|
|
||||||
|
@ -11,8 +11,8 @@
|
|||||||
#ifndef _WX_WX_SERBASEH_H__
|
#ifndef _WX_WX_SERBASEH_H__
|
||||||
#define _WX_WX_SERBASEH_H__
|
#define _WX_WX_SERBASEH_H__
|
||||||
|
|
||||||
#include <wx/setup.h>
|
#include "wx/setup.h"
|
||||||
#include <wx/dynlib.h>
|
#include "wx/dynlib.h"
|
||||||
|
|
||||||
#define WXSERIAL(classname) classname##_Serialize
|
#define WXSERIAL(classname) classname##_Serialize
|
||||||
|
|
||||||
|
@ -24,13 +24,13 @@
|
|||||||
// wxSocket headers (generic)
|
// wxSocket headers (generic)
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
#ifdef WXPREC
|
#ifdef WXPREC
|
||||||
# include <wx/wxprec.h>
|
# include "wx/wxprec.h"
|
||||||
#else
|
#else
|
||||||
# include <wx/event.h>
|
# include "wx/event.h"
|
||||||
# include <wx/string.h>
|
# include "wx/string.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/sckaddr.h>
|
#include "wx/sckaddr.h"
|
||||||
#include "wx/gsocket.h"
|
#include "wx/gsocket.h"
|
||||||
|
|
||||||
class WXDLLEXPORT wxTimer;
|
class WXDLLEXPORT wxTimer;
|
||||||
|
@ -352,7 +352,7 @@ void WXDLLEXPORT wxMutexGuiLeave();
|
|||||||
|
|
||||||
#else // !wxUSE_THREADS
|
#else // !wxUSE_THREADS
|
||||||
|
|
||||||
#include <wx/defs.h> // for WXDLLEXPORT
|
#include "wx/defs.h" // for WXDLLEXPORT
|
||||||
|
|
||||||
// no thread support
|
// no thread support
|
||||||
inline void WXDLLEXPORT wxMutexGuiEnter() { }
|
inline void WXDLLEXPORT wxMutexGuiEnter() { }
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
#pragma interface "txtstrm.h"
|
#pragma interface "txtstrm.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/stream.h>
|
#include "wx/stream.h"
|
||||||
|
|
||||||
#if wxUSE_STREAMS
|
#if wxUSE_STREAMS
|
||||||
|
|
||||||
@ -73,6 +73,8 @@ class WXDLLEXPORT wxTextOutputStream {
|
|||||||
wxOutputStream *m_output;
|
wxOutputStream *m_output;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
wxTextOutputStream &endl( wxTextOutputStream &stream );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// wxUSE_STREAMS
|
// wxUSE_STREAMS
|
||||||
|
|
||||||
|
@ -20,10 +20,10 @@
|
|||||||
|
|
||||||
#if wxUSE_STREAMS && wxUSE_FILE
|
#if wxUSE_STREAMS && wxUSE_FILE
|
||||||
|
|
||||||
#include <wx/object.h>
|
#include "wx/object.h"
|
||||||
#include <wx/string.h>
|
#include "wx/string.h"
|
||||||
#include <wx/stream.h>
|
#include "wx/stream.h"
|
||||||
#include <wx/file.h>
|
#include "wx/file.h"
|
||||||
|
|
||||||
class wxFileInputStream: public wxInputStream {
|
class wxFileInputStream: public wxInputStream {
|
||||||
public:
|
public:
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#if wxUSE_ZLIB && wxUSE_STREAMS
|
#if wxUSE_ZLIB && wxUSE_STREAMS
|
||||||
|
|
||||||
#include <wx/stream.h>
|
#include "wx/stream.h"
|
||||||
|
|
||||||
class WXDLLEXPORT wxZlibInputStream: public wxFilterInputStream {
|
class WXDLLEXPORT wxZlibInputStream: public wxFilterInputStream {
|
||||||
public:
|
public:
|
||||||
|
@ -384,7 +384,7 @@ MyPanel::MyPanel( wxFrame *frame, int x, int y, int w, int h )
|
|||||||
button->SetToolTip( "Press here to set italic font" );
|
button->SetToolTip( "Press here to set italic font" );
|
||||||
#endif // wxUSE_TOOLTIPS
|
#endif // wxUSE_TOOLTIPS
|
||||||
|
|
||||||
m_checkbox = new wxCheckBox( panel, ID_LISTBOX_ENABLE, "&Disable", wxPoint(20,130), wxSize(-1, -1), wxALIGN_RIGHT );
|
m_checkbox = new wxCheckBox( panel, ID_LISTBOX_ENABLE, "&Disable", wxPoint(20,130) );
|
||||||
m_checkbox->SetValue(FALSE);
|
m_checkbox->SetValue(FALSE);
|
||||||
#if wxUSE_TOOLTIPS
|
#if wxUSE_TOOLTIPS
|
||||||
m_checkbox->SetToolTip( "Click here to disable the listbox" );
|
m_checkbox->SetToolTip( "Click here to disable the listbox" );
|
||||||
|
@ -271,7 +271,7 @@ void MyFrame::FileOpen(wxCommandEvent& WXUNUSED(event) )
|
|||||||
|
|
||||||
void MyFrame::FileSave(wxCommandEvent& WXUNUSED(event) )
|
void MyFrame::FileSave(wxCommandEvent& WXUNUSED(event) )
|
||||||
{
|
{
|
||||||
wxFileDialog dialog(this, "Testing save file dialog", "", "",
|
wxFileDialog dialog(this, "Testing save file dialog", "", "myletter.txt",
|
||||||
"Text files (*.txt)|*.txt|Document files (*.doc)|*.doc",
|
"Text files (*.txt)|*.txt|Document files (*.doc)|*.doc",
|
||||||
wxSAVE|wxOVERWRITE_PROMPT);
|
wxSAVE|wxOVERWRITE_PROMPT);
|
||||||
|
|
||||||
|
@ -300,7 +300,20 @@ void wxImage::SetData( char unsigned *data )
|
|||||||
{
|
{
|
||||||
wxCHECK_RET( Ok(), _T("invalid image") );
|
wxCHECK_RET( Ok(), _T("invalid image") );
|
||||||
|
|
||||||
memcpy(M_IMGDATA->m_data, data, M_IMGDATA->m_width * M_IMGDATA->m_height * 3);
|
wxImageRefData *newRefData = new wxImageRefData();
|
||||||
|
|
||||||
|
newRefData->m_width = M_IMGDATA->m_width;
|
||||||
|
newRefData->m_height = M_IMGDATA->m_height;
|
||||||
|
newRefData->m_data = data;
|
||||||
|
newRefData->m_ok = TRUE;
|
||||||
|
newRefData->m_maskRed = M_IMGDATA->m_maskRed;
|
||||||
|
newRefData->m_maskGreen = M_IMGDATA->m_maskGreen;
|
||||||
|
newRefData->m_maskBlue = M_IMGDATA->m_maskBlue;
|
||||||
|
newRefData->m_hasMask = M_IMGDATA->m_hasMask;
|
||||||
|
|
||||||
|
UnRef();
|
||||||
|
|
||||||
|
m_refData = newRefData;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxImage::SetMaskColour( unsigned char r, unsigned char g, unsigned char b )
|
void wxImage::SetMaskColour( unsigned char r, unsigned char g, unsigned char b )
|
||||||
|
@ -40,6 +40,7 @@
|
|||||||
#include "wx/intl.h"
|
#include "wx/intl.h"
|
||||||
#include "wx/file.h"
|
#include "wx/file.h"
|
||||||
#include "wx/log.h"
|
#include "wx/log.h"
|
||||||
|
#include "wx/debug.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -337,20 +338,22 @@ bool wxMsgCatalog::Load(const wxChar *szDirPrefix, const wxChar *szName0)
|
|||||||
// not yet be loaded (and it's normal)
|
// not yet be loaded (and it's normal)
|
||||||
//
|
//
|
||||||
// (we're using an object because we have several return paths)
|
// (we're using an object because we have several return paths)
|
||||||
|
|
||||||
NoTransErr noTransErr;
|
NoTransErr noTransErr;
|
||||||
|
// Then why do you translate at all? Just use _T() and not _(). RR.
|
||||||
|
|
||||||
wxLogVerbose(_("looking for catalog '%s' in path '%s'."),
|
wxLogVerbose(_("looking for catalog '%s' in path '%s'."),
|
||||||
szName, searchPath.c_str());
|
szName.c_str, searchPath.c_str());
|
||||||
|
|
||||||
wxString strFullName;
|
wxString strFullName;
|
||||||
if ( !wxFindFileInPath(&strFullName, searchPath, strFile) ) {
|
if ( !wxFindFileInPath(&strFullName, searchPath, strFile) ) {
|
||||||
wxLogWarning(_("catalog file for domain '%s' not found."), szName);
|
wxLogWarning(_("catalog file for domain '%s' not found."), szName.c_str());
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// open file
|
// open file
|
||||||
wxLogVerbose(_("using catalog '%s' from '%s'."),
|
wxLogVerbose(_("using catalog '%s' from '%s'."),
|
||||||
szName, strFullName.c_str());
|
szName.c_str(), strFullName.c_str());
|
||||||
|
|
||||||
wxFile fileMsg(strFullName);
|
wxFile fileMsg(strFullName);
|
||||||
if ( !fileMsg.IsOpened() )
|
if ( !fileMsg.IsOpened() )
|
||||||
|
@ -477,5 +477,10 @@ wxTextOutputStream& wxTextOutputStream::operator<<(float f)
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxTextOutputStream &endl( wxTextOutputStream &stream )
|
||||||
|
{
|
||||||
|
return stream << _T('\n');
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// wxUSE_STREAMS
|
// wxUSE_STREAMS
|
||||||
|
@ -670,8 +670,11 @@ wxFileDialog::wxFileDialog(wxWindow *parent,
|
|||||||
mainsizer->SetSizeHints( this );
|
mainsizer->SetSizeHints( this );
|
||||||
|
|
||||||
Centre( wxBOTH );
|
Centre( wxBOTH );
|
||||||
|
|
||||||
m_list->SetFocus();
|
if (m_fileName.IsEmpty())
|
||||||
|
m_list->SetFocus();
|
||||||
|
else
|
||||||
|
m_text->SetFocus();
|
||||||
|
|
||||||
wxEndBusyCursor();
|
wxEndBusyCursor();
|
||||||
}
|
}
|
||||||
@ -723,6 +726,24 @@ void wxFileDialog::OnListOk( wxCommandEvent &event )
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (filename == _T("~"))
|
||||||
|
{
|
||||||
|
m_list->GoToHomeDir();
|
||||||
|
m_list->SetFocus();
|
||||||
|
m_list->GetDir( dir );
|
||||||
|
m_static->SetLabel( dir );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (filename[0] == _T('~'))
|
||||||
|
{
|
||||||
|
filename.Remove( 0, 1 );
|
||||||
|
wxString tmp( wxGetUserHome() );
|
||||||
|
tmp += _T('/');
|
||||||
|
tmp += filename;
|
||||||
|
filename = tmp;
|
||||||
|
}
|
||||||
|
|
||||||
if ((filename.Find(_T('*')) != wxNOT_FOUND) ||
|
if ((filename.Find(_T('*')) != wxNOT_FOUND) ||
|
||||||
(filename.Find(_T('?')) != wxNOT_FOUND))
|
(filename.Find(_T('?')) != wxNOT_FOUND))
|
||||||
{
|
{
|
||||||
@ -736,13 +757,19 @@ void wxFileDialog::OnListOk( wxCommandEvent &event )
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (dir != _T("/")) dir += _T("/");
|
if (dir != _T("/")) dir += _T("/");
|
||||||
dir += filename;
|
if (filename[0] != _T('/'))
|
||||||
filename = dir;
|
{
|
||||||
|
dir += filename;
|
||||||
|
filename = dir;
|
||||||
|
}
|
||||||
|
|
||||||
if (wxDirExists(filename))
|
if (wxDirExists(filename))
|
||||||
{
|
{
|
||||||
m_list->GoToDir( filename );
|
m_list->GoToDir( filename );
|
||||||
m_text->SetValue( _T("..") );
|
if (filename == _T("/"))
|
||||||
|
m_text->SetValue( _T("") );
|
||||||
|
else
|
||||||
|
m_text->SetValue( _T("..") );
|
||||||
m_list->GetDir( dir );
|
m_list->GetDir( dir );
|
||||||
m_static->SetLabel( dir );
|
m_static->SetLabel( dir );
|
||||||
return;
|
return;
|
||||||
|
@ -27,12 +27,12 @@
|
|||||||
#pragma hdrstop
|
#pragma hdrstop
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <wx/string.h>
|
#include "wx/string.h"
|
||||||
#include <wx/log.h>
|
#include "wx/log.h"
|
||||||
#include <wx/settings.h>
|
#include "wx/settings.h"
|
||||||
#include <wx/generic/imaglist.h>
|
#include "wx/generic/imaglist.h"
|
||||||
#include <wx/notebook.h>
|
#include "wx/notebook.h"
|
||||||
#include <wx/dcclient.h>
|
#include "wx/dcclient.h"
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// macros
|
// macros
|
||||||
|
@ -101,7 +101,7 @@ void wxPanel::OnNavigationKey( wxNavigationKeyEvent& event )
|
|||||||
wxWindow *winFocus = event.GetCurrentFocus();
|
wxWindow *winFocus = event.GetCurrentFocus();
|
||||||
if (!winFocus)
|
if (!winFocus)
|
||||||
winFocus = wxWindow::FindFocus();
|
winFocus = wxWindow::FindFocus();
|
||||||
|
|
||||||
if (!winFocus)
|
if (!winFocus)
|
||||||
{
|
{
|
||||||
event.Skip();
|
event.Skip();
|
||||||
@ -126,14 +126,16 @@ void wxPanel::OnNavigationKey( wxNavigationKeyEvent& event )
|
|||||||
// so give them the chance to process it instead of looping inside
|
// so give them the chance to process it instead of looping inside
|
||||||
// this panel (normally, the focus will go to the next/previous
|
// this panel (normally, the focus will go to the next/previous
|
||||||
// item after this panel in the parent panel)
|
// item after this panel in the parent panel)
|
||||||
|
wxWindow *focussed_child_of_p = this;
|
||||||
for ( wxWindow *p = GetParent(); p; p = p->GetParent() )
|
for ( wxWindow *p = GetParent(); p; p = p->GetParent() )
|
||||||
{
|
{
|
||||||
if ( wxDynamicCast(p, wxPanel) )
|
if ( wxDynamicCast(p, wxPanel) )
|
||||||
{
|
{
|
||||||
event.Skip();
|
event.SetCurrentFocus( focussed_child_of_p );
|
||||||
|
if (p->GetEventHandler()->ProcessEvent( event ))
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
focussed_child_of_p = p;
|
||||||
}
|
}
|
||||||
|
|
||||||
// no, we are not inside another panel so process this ourself
|
// no, we are not inside another panel so process this ourself
|
||||||
|
@ -127,43 +127,6 @@ static void gtk_page_size_callback( GtkWidget *WXUNUSED(widget), GtkAllocation*
|
|||||||
if (win->GetAutoLayout()) win->Layout();
|
if (win->GetAutoLayout()) win->Layout();
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// "key_press_event"
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
static gint
|
|
||||||
gtk_notebook_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_event, wxNotebook *notebook )
|
|
||||||
{
|
|
||||||
if (g_isIdle) wxapp_install_idle_handler();
|
|
||||||
|
|
||||||
if (g_blockEventsOnDrag) return FALSE;
|
|
||||||
|
|
||||||
if (!notebook->m_hasVMT) return FALSE;
|
|
||||||
|
|
||||||
/* this code makes jumping down from the handles of the notebooks
|
|
||||||
to the actual items in the visible notebook page possible with
|
|
||||||
the down-arrow key */
|
|
||||||
|
|
||||||
if (gdk_event->keyval != GDK_Down) return FALSE;
|
|
||||||
|
|
||||||
if (notebook != notebook->FindFocus()) return FALSE;
|
|
||||||
|
|
||||||
if (notebook->m_pages.GetCount() == 0) return FALSE;
|
|
||||||
|
|
||||||
wxNode *node = notebook->m_pages.Nth( notebook->GetSelection() );
|
|
||||||
|
|
||||||
if (!node) return FALSE;
|
|
||||||
|
|
||||||
wxNotebookPage *page = (wxNotebookPage*) node->Data();
|
|
||||||
|
|
||||||
// don't let others the key event
|
|
||||||
gtk_signal_emit_stop_by_name( GTK_OBJECT(widget), "key_press_event" );
|
|
||||||
|
|
||||||
page->m_client->SetFocus();
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// InsertChild callback for wxNotebook
|
// InsertChild callback for wxNotebook
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -241,9 +204,6 @@ bool wxNotebook::Create(wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
m_parent->DoAddChild( this );
|
m_parent->DoAddChild( this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(m_widget), "key_press_event",
|
|
||||||
GTK_SIGNAL_FUNC(gtk_notebook_key_press_callback), (gpointer)this );
|
|
||||||
|
|
||||||
PostCreation();
|
PostCreation();
|
||||||
|
|
||||||
Show( TRUE );
|
Show( TRUE );
|
||||||
@ -251,6 +211,19 @@ bool wxNotebook::Create(wxWindow *parent, wxWindowID id,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxNotebook::SetFocus()
|
||||||
|
{
|
||||||
|
if (m_pages.GetCount() == 0) return;
|
||||||
|
|
||||||
|
wxNode *node = m_pages.Nth( GetSelection() );
|
||||||
|
|
||||||
|
if (!node) return;
|
||||||
|
|
||||||
|
wxNotebookPage *page = (wxNotebookPage*) node->Data();
|
||||||
|
|
||||||
|
page->m_client->SetFocus();
|
||||||
|
}
|
||||||
|
|
||||||
int wxNotebook::GetSelection() const
|
int wxNotebook::GetSelection() const
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( m_widget != NULL, -1, _T("invalid notebook") );
|
wxCHECK_MSG( m_widget != NULL, -1, _T("invalid notebook") );
|
||||||
@ -284,7 +257,7 @@ wxString wxNotebook::GetPageText( int page ) const
|
|||||||
if (nb_page)
|
if (nb_page)
|
||||||
return nb_page->m_text;
|
return nb_page->m_text;
|
||||||
else
|
else
|
||||||
return "";
|
return _T("");
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxNotebook::GetPageImage( int page ) const
|
int wxNotebook::GetPageImage( int page ) const
|
||||||
|
@ -98,7 +98,7 @@ bool wxStaticText::Create(wxWindow *parent,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxStaticText::GetLabel(void) const
|
wxString wxStaticText::GetLabel() const
|
||||||
{
|
{
|
||||||
char *str = (char *) NULL;
|
char *str = (char *) NULL;
|
||||||
gtk_label_get( GTK_LABEL(m_widget), &str );
|
gtk_label_get( GTK_LABEL(m_widget), &str );
|
||||||
|
@ -812,7 +812,6 @@ static gint gtk_window_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_e
|
|||||||
ret = (ret || win->GetEventHandler()->ProcessEvent( event2 ));
|
ret = (ret || win->GetEventHandler()->ProcessEvent( event2 ));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* win is a control: tab can be propagated up */
|
/* win is a control: tab can be propagated up */
|
||||||
if ( (!ret) &&
|
if ( (!ret) &&
|
||||||
((gdk_event->keyval == GDK_Tab) || (gdk_event->keyval == GDK_ISO_Left_Tab)) &&
|
((gdk_event->keyval == GDK_Tab) || (gdk_event->keyval == GDK_ISO_Left_Tab)) &&
|
||||||
|
@ -127,43 +127,6 @@ static void gtk_page_size_callback( GtkWidget *WXUNUSED(widget), GtkAllocation*
|
|||||||
if (win->GetAutoLayout()) win->Layout();
|
if (win->GetAutoLayout()) win->Layout();
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// "key_press_event"
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
static gint
|
|
||||||
gtk_notebook_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_event, wxNotebook *notebook )
|
|
||||||
{
|
|
||||||
if (g_isIdle) wxapp_install_idle_handler();
|
|
||||||
|
|
||||||
if (g_blockEventsOnDrag) return FALSE;
|
|
||||||
|
|
||||||
if (!notebook->m_hasVMT) return FALSE;
|
|
||||||
|
|
||||||
/* this code makes jumping down from the handles of the notebooks
|
|
||||||
to the actual items in the visible notebook page possible with
|
|
||||||
the down-arrow key */
|
|
||||||
|
|
||||||
if (gdk_event->keyval != GDK_Down) return FALSE;
|
|
||||||
|
|
||||||
if (notebook != notebook->FindFocus()) return FALSE;
|
|
||||||
|
|
||||||
if (notebook->m_pages.GetCount() == 0) return FALSE;
|
|
||||||
|
|
||||||
wxNode *node = notebook->m_pages.Nth( notebook->GetSelection() );
|
|
||||||
|
|
||||||
if (!node) return FALSE;
|
|
||||||
|
|
||||||
wxNotebookPage *page = (wxNotebookPage*) node->Data();
|
|
||||||
|
|
||||||
// don't let others the key event
|
|
||||||
gtk_signal_emit_stop_by_name( GTK_OBJECT(widget), "key_press_event" );
|
|
||||||
|
|
||||||
page->m_client->SetFocus();
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// InsertChild callback for wxNotebook
|
// InsertChild callback for wxNotebook
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -241,9 +204,6 @@ bool wxNotebook::Create(wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
m_parent->DoAddChild( this );
|
m_parent->DoAddChild( this );
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(m_widget), "key_press_event",
|
|
||||||
GTK_SIGNAL_FUNC(gtk_notebook_key_press_callback), (gpointer)this );
|
|
||||||
|
|
||||||
PostCreation();
|
PostCreation();
|
||||||
|
|
||||||
Show( TRUE );
|
Show( TRUE );
|
||||||
@ -251,6 +211,19 @@ bool wxNotebook::Create(wxWindow *parent, wxWindowID id,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxNotebook::SetFocus()
|
||||||
|
{
|
||||||
|
if (m_pages.GetCount() == 0) return;
|
||||||
|
|
||||||
|
wxNode *node = m_pages.Nth( GetSelection() );
|
||||||
|
|
||||||
|
if (!node) return;
|
||||||
|
|
||||||
|
wxNotebookPage *page = (wxNotebookPage*) node->Data();
|
||||||
|
|
||||||
|
page->m_client->SetFocus();
|
||||||
|
}
|
||||||
|
|
||||||
int wxNotebook::GetSelection() const
|
int wxNotebook::GetSelection() const
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( m_widget != NULL, -1, _T("invalid notebook") );
|
wxCHECK_MSG( m_widget != NULL, -1, _T("invalid notebook") );
|
||||||
@ -284,7 +257,7 @@ wxString wxNotebook::GetPageText( int page ) const
|
|||||||
if (nb_page)
|
if (nb_page)
|
||||||
return nb_page->m_text;
|
return nb_page->m_text;
|
||||||
else
|
else
|
||||||
return "";
|
return _T("");
|
||||||
}
|
}
|
||||||
|
|
||||||
int wxNotebook::GetPageImage( int page ) const
|
int wxNotebook::GetPageImage( int page ) const
|
||||||
|
@ -98,7 +98,7 @@ bool wxStaticText::Create(wxWindow *parent,
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxStaticText::GetLabel(void) const
|
wxString wxStaticText::GetLabel() const
|
||||||
{
|
{
|
||||||
char *str = (char *) NULL;
|
char *str = (char *) NULL;
|
||||||
gtk_label_get( GTK_LABEL(m_widget), &str );
|
gtk_label_get( GTK_LABEL(m_widget), &str );
|
||||||
|
@ -812,7 +812,6 @@ static gint gtk_window_key_press_callback( GtkWidget *widget, GdkEventKey *gdk_e
|
|||||||
ret = (ret || win->GetEventHandler()->ProcessEvent( event2 ));
|
ret = (ret || win->GetEventHandler()->ProcessEvent( event2 ));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* win is a control: tab can be propagated up */
|
/* win is a control: tab can be propagated up */
|
||||||
if ( (!ret) &&
|
if ( (!ret) &&
|
||||||
((gdk_event->keyval == GDK_Tab) || (gdk_event->keyval == GDK_ISO_Left_Tab)) &&
|
((gdk_event->keyval == GDK_Tab) || (gdk_event->keyval == GDK_ISO_Left_Tab)) &&
|
||||||
|
Loading…
Reference in New Issue
Block a user