Coompilation fixes for GTK 1.1.3
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@999 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include "wx/dcclient.h"
|
#include "wx/dcclient.h"
|
||||||
#include "wx/dcmemory.h"
|
#include "wx/dcmemory.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// local data
|
// local data
|
||||||
|
237
src/gtk/dnd.cpp
237
src/gtk/dnd.cpp
@@ -27,6 +27,239 @@
|
|||||||
|
|
||||||
extern bool g_blockEventsOnDrag;
|
extern bool g_blockEventsOnDrag;
|
||||||
|
|
||||||
|
|
||||||
|
#if (GTK_MINOR_VERSION == 1)
|
||||||
|
#if (GTK_MICRO_VERSION >= 3)
|
||||||
|
#define NEW_GTK_DND_CODE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
wxDropTarget::wxDropTarget()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDropTarget::~wxDropTarget()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropTarget::UnregisterWidget( GtkWidget *widget )
|
||||||
|
{
|
||||||
|
if (!widget) return;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropTarget::RegisterWidget( GtkWidget *widget )
|
||||||
|
{
|
||||||
|
if (!widget) return;
|
||||||
|
|
||||||
|
wxString formats;
|
||||||
|
int valid = 0;
|
||||||
|
|
||||||
|
for ( size_t i = 0; i < GetFormatCount(); i++ )
|
||||||
|
{
|
||||||
|
wxDataFormat df = GetFormat( i );
|
||||||
|
switch (df)
|
||||||
|
{
|
||||||
|
case wxDF_TEXT:
|
||||||
|
if (i > 0) formats += ";";
|
||||||
|
formats += "text/plain";
|
||||||
|
valid++;
|
||||||
|
break;
|
||||||
|
case wxDF_FILENAME:
|
||||||
|
if (i > 0) formats += ";";
|
||||||
|
formats += "file:ALL";
|
||||||
|
valid++;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
char *str = WXSTRINGCAST formats;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxTextDropTarget
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxTextDropTarget::OnDrop( long x, long y, const void *data, size_t WXUNUSED(size) )
|
||||||
|
{
|
||||||
|
OnDropText( x, y, (const char*)data );
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxTextDropTarget::OnDropText( long x, long y, const char *psz )
|
||||||
|
{
|
||||||
|
printf( "Got dropped text: %s.\n", psz );
|
||||||
|
printf( "At x: %d, y: %d.\n", (int)x, (int)y );
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t wxTextDropTarget::GetFormatCount() const
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDataFormat wxTextDropTarget::GetFormat(size_t WXUNUSED(n)) const
|
||||||
|
{
|
||||||
|
return wxDF_TEXT;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxFileDropTarget
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxFileDropTarget::OnDropFiles( long x, long y, size_t nFiles, const char * const aszFiles[] )
|
||||||
|
{
|
||||||
|
printf( "Got %d dropped files.\n", (int)nFiles );
|
||||||
|
printf( "At x: %d, y: %d.\n", (int)x, (int)y );
|
||||||
|
for (size_t i = 0; i < nFiles; i++)
|
||||||
|
{
|
||||||
|
printf( aszFiles[i] );
|
||||||
|
printf( "\n" );
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxFileDropTarget::OnDrop(long x, long y, const void *data, size_t size )
|
||||||
|
{
|
||||||
|
size_t number = 0;
|
||||||
|
char *text = (char*) data;
|
||||||
|
for (size_t i = 0; i < size; i++)
|
||||||
|
if (text[i] == 0) number++;
|
||||||
|
|
||||||
|
if (number == 0) return TRUE;
|
||||||
|
|
||||||
|
char **files = new char*[number];
|
||||||
|
|
||||||
|
text = (char*) data;
|
||||||
|
for (size_t i = 0; i < number; i++)
|
||||||
|
{
|
||||||
|
files[i] = text;
|
||||||
|
int len = strlen( text );
|
||||||
|
text += len+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ret = OnDropFiles( x, y, 1, files );
|
||||||
|
|
||||||
|
free( files );
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t wxFileDropTarget::GetFormatCount() const
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDataFormat wxFileDropTarget::GetFormat(size_t WXUNUSED(n)) const
|
||||||
|
{
|
||||||
|
return wxDF_FILENAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
// wxDropSource
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxDropSource::wxDropSource( wxWindow *win )
|
||||||
|
{
|
||||||
|
g_blockEventsOnDrag = TRUE;
|
||||||
|
|
||||||
|
m_window = win;
|
||||||
|
m_widget = win->m_widget;
|
||||||
|
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
||||||
|
|
||||||
|
m_data = (wxDataObject *) NULL;
|
||||||
|
m_retValue = wxDragCancel;
|
||||||
|
|
||||||
|
m_defaultCursor = wxCursor( wxCURSOR_NO_ENTRY );
|
||||||
|
m_goaheadCursor = wxCursor( wxCURSOR_HAND );
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDropSource::wxDropSource( wxDataObject &data, wxWindow *win )
|
||||||
|
{
|
||||||
|
g_blockEventsOnDrag = TRUE;
|
||||||
|
|
||||||
|
m_window = win;
|
||||||
|
m_widget = win->m_widget;
|
||||||
|
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
||||||
|
m_retValue = wxDragCancel;
|
||||||
|
|
||||||
|
m_data = &data;
|
||||||
|
|
||||||
|
m_defaultCursor = wxCursor( wxCURSOR_NO_ENTRY );
|
||||||
|
m_goaheadCursor = wxCursor( wxCURSOR_HAND );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropSource::SetData( wxDataObject &data )
|
||||||
|
{
|
||||||
|
m_data = &data;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDropSource::~wxDropSource(void)
|
||||||
|
{
|
||||||
|
// if (m_data) delete m_data;
|
||||||
|
|
||||||
|
g_blockEventsOnDrag = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDragResult wxDropSource::DoDragDrop( bool WXUNUSED(bAllowMove) )
|
||||||
|
{
|
||||||
|
wxASSERT_MSG( m_data, "wxDragSource: no data" );
|
||||||
|
|
||||||
|
if (!m_data) return (wxDragResult) wxDragNone;
|
||||||
|
if (m_data->GetDataSize() == 0) return (wxDragResult) wxDragNone;
|
||||||
|
|
||||||
|
RegisterWindow();
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
|
||||||
|
UnregisterWindow();
|
||||||
|
|
||||||
|
g_blockEventsOnDrag = FALSE;
|
||||||
|
|
||||||
|
return m_retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropSource::RegisterWindow(void)
|
||||||
|
{
|
||||||
|
if (!m_data) return;
|
||||||
|
|
||||||
|
wxString formats;
|
||||||
|
|
||||||
|
wxDataFormat df = m_data->GetPreferredFormat();
|
||||||
|
|
||||||
|
switch (df)
|
||||||
|
{
|
||||||
|
case wxDF_TEXT:
|
||||||
|
formats += "text/plain";
|
||||||
|
break;
|
||||||
|
case wxDF_FILENAME:
|
||||||
|
formats += "file:ALL";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *str = WXSTRINGCAST formats;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropSource::UnregisterWindow(void)
|
||||||
|
{
|
||||||
|
if (!m_widget) return;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxDropTarget
|
// wxDropTarget
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -322,3 +555,7 @@ void wxDropSource::UnregisterWindow(void)
|
|||||||
|
|
||||||
gtk_signal_disconnect_by_data( GTK_OBJECT(m_widget), (gpointer)this );
|
gtk_signal_disconnect_by_data( GTK_OBJECT(m_widget), (gpointer)this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
// NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
@@ -342,11 +342,16 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
|
|
||||||
m_width = width;
|
m_width = width;
|
||||||
m_height = height;
|
m_height = height;
|
||||||
|
|
||||||
if ((m_minWidth != -1) && (m_width < m_minWidth)) m_width = m_minWidth;
|
if ((m_minWidth != -1) && (m_width < m_minWidth)) m_width = m_minWidth;
|
||||||
if ((m_minHeight != -1) && (m_height < m_minHeight)) m_height = m_minHeight;
|
if ((m_minHeight != -1) && (m_height < m_minHeight)) m_height = m_minHeight;
|
||||||
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
||||||
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
||||||
|
|
||||||
|
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
||||||
|
event.SetEventObject( this );
|
||||||
|
ProcessEvent( event );
|
||||||
|
|
||||||
gtk_widget_set_usize( m_widget, m_width, m_height );
|
gtk_widget_set_usize( m_widget, m_width, m_height );
|
||||||
|
|
||||||
// This emulates the new wxMSW behaviour
|
// This emulates the new wxMSW behaviour
|
||||||
@@ -385,10 +390,6 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_sizeSet = TRUE;
|
m_sizeSet = TRUE;
|
||||||
|
|
||||||
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
|
||||||
event.SetEventObject( this );
|
|
||||||
ProcessEvent( event );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
||||||
@@ -396,11 +397,13 @@ void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
|||||||
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
||||||
|
|
||||||
if (GetAutoLayout())
|
if (GetAutoLayout())
|
||||||
|
{
|
||||||
Layout();
|
Layout();
|
||||||
else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// no child: go out !
|
// no child: go out !
|
||||||
if (!GetChildren()->First())
|
if (!GetChildren()->First()) return;
|
||||||
return;
|
|
||||||
|
|
||||||
// do we have exactly one child?
|
// do we have exactly one child?
|
||||||
wxWindow *child = (wxWindow *) NULL;
|
wxWindow *child = (wxWindow *) NULL;
|
||||||
@@ -415,9 +418,8 @@ void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
|||||||
#endif
|
#endif
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
if ( child ) // it's the second one: do nothing
|
// it's the second one: do nothing
|
||||||
return;
|
if (child) return;
|
||||||
|
|
||||||
child = win;
|
child = win;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#include "wx/scrolbar.h"
|
#include "wx/scrolbar.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
|
@@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include "wx/slider.h"
|
#include "wx/slider.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
|
@@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#include "wx/spinbutt.h"
|
#include "wx/spinbutt.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
|
@@ -84,8 +84,8 @@ bool wxTextCtrl::Create( wxWindow *parent, wxWindowID id, const wxString &value,
|
|||||||
// ... and put into the upper left hand corner of the table
|
// ... and put into the upper left hand corner of the table
|
||||||
m_widget = gtk_table_new(bHasHScrollbar ? 2 : 1, 2, FALSE);
|
m_widget = gtk_table_new(bHasHScrollbar ? 2 : 1, 2, FALSE);
|
||||||
gtk_table_attach( GTK_TABLE(m_widget), m_text, 0, 1, 0, 1,
|
gtk_table_attach( GTK_TABLE(m_widget), m_text, 0, 1, 0, 1,
|
||||||
GTK_FILL | GTK_EXPAND,
|
(GtkAttachOptions)(GTK_FILL | GTK_EXPAND),
|
||||||
GTK_FILL | GTK_EXPAND | GTK_SHRINK,
|
(GtkAttachOptions)(GTK_FILL | GTK_EXPAND | GTK_SHRINK),
|
||||||
0, 0);
|
0, 0);
|
||||||
|
|
||||||
// put the horizontal scrollbar in the lower left hand corner
|
// put the horizontal scrollbar in the lower left hand corner
|
||||||
@@ -93,7 +93,7 @@ bool wxTextCtrl::Create( wxWindow *parent, wxWindowID id, const wxString &value,
|
|||||||
{
|
{
|
||||||
GtkWidget *hscrollbar = gtk_hscrollbar_new(GTK_TEXT(m_text)->hadj);
|
GtkWidget *hscrollbar = gtk_hscrollbar_new(GTK_TEXT(m_text)->hadj);
|
||||||
gtk_table_attach(GTK_TABLE(m_widget), hscrollbar, 0, 1, 1, 2,
|
gtk_table_attach(GTK_TABLE(m_widget), hscrollbar, 0, 1, 1, 2,
|
||||||
GTK_EXPAND | GTK_FILL,
|
(GtkAttachOptions)(GTK_EXPAND | GTK_FILL),
|
||||||
GTK_FILL,
|
GTK_FILL,
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_widget_show(hscrollbar);
|
gtk_widget_show(hscrollbar);
|
||||||
@@ -103,7 +103,7 @@ bool wxTextCtrl::Create( wxWindow *parent, wxWindowID id, const wxString &value,
|
|||||||
GtkWidget *vscrollbar = gtk_vscrollbar_new(GTK_TEXT(m_text)->vadj);
|
GtkWidget *vscrollbar = gtk_vscrollbar_new(GTK_TEXT(m_text)->vadj);
|
||||||
gtk_table_attach(GTK_TABLE(m_widget), vscrollbar, 1, 2, 0, 1,
|
gtk_table_attach(GTK_TABLE(m_widget), vscrollbar, 1, 2, 0, 1,
|
||||||
GTK_FILL,
|
GTK_FILL,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
(GtkAttachOptions)(GTK_EXPAND | GTK_FILL | GTK_SHRINK),
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_widget_show( vscrollbar );
|
gtk_widget_show( vscrollbar );
|
||||||
}
|
}
|
||||||
|
@@ -104,6 +104,10 @@ gtk_myfixed_init (GtkMyFixed *myfixed)
|
|||||||
GTK_WIDGET_UNSET_FLAGS (myfixed, GTK_NO_WINDOW);
|
GTK_WIDGET_UNSET_FLAGS (myfixed, GTK_NO_WINDOW);
|
||||||
GTK_WIDGET_SET_FLAGS (myfixed, GTK_BASIC);
|
GTK_WIDGET_SET_FLAGS (myfixed, GTK_BASIC);
|
||||||
|
|
||||||
|
#if (GTK_MINOR_VERSION == 1)
|
||||||
|
gtk_container_set_resize_mode( GTK_CONTAINER(myfixed), GTK_RESIZE_PARENT );
|
||||||
|
#endif
|
||||||
|
|
||||||
myfixed->children = NULL;
|
myfixed->children = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -108,6 +108,16 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// cond comp
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#if (GTK_MINOR_VERSION == 1)
|
||||||
|
#if (GTK_MICRO_VERSION >= 3)
|
||||||
|
#define NEW_GTK_DND_CODE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -837,6 +847,11 @@ static gint gtk_scrollbar_button_release_callback( GtkRange *widget, GdkEventBut
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// "drop_data_available_event"
|
// "drop_data_available_event"
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -862,6 +877,9 @@ static void gtk_window_drop_callback( GtkWidget *widget, GdkEventDropDataAvailab
|
|||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
// NEW_GTK_DND_CODE
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// InsertChild for wxWindow.
|
// InsertChild for wxWindow.
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -2196,18 +2214,32 @@ void wxWindow::ConnectDnDWidget( GtkWidget *widget )
|
|||||||
|
|
||||||
m_dropTarget->RegisterWidget( widget );
|
m_dropTarget->RegisterWidget( widget );
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "drop_data_available_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "drop_data_available_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::DisconnectDnDWidget( GtkWidget *widget )
|
void wxWindow::DisconnectDnDWidget( GtkWidget *widget )
|
||||||
{
|
{
|
||||||
if (!m_dropTarget) return;
|
if (!m_dropTarget) return;
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
gtk_signal_disconnect_by_func( GTK_OBJECT(widget),
|
gtk_signal_disconnect_by_func( GTK_OBJECT(widget),
|
||||||
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
||||||
|
|
||||||
m_dropTarget->UnregisterWidget( widget );
|
m_dropTarget->UnregisterWidget( widget );
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget* wxWindow::GetConnectWidget()
|
GtkWidget* wxWindow::GetConnectWidget()
|
||||||
|
@@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include "wx/dcclient.h"
|
#include "wx/dcclient.h"
|
||||||
#include "wx/dcmemory.h"
|
#include "wx/dcmemory.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// local data
|
// local data
|
||||||
|
237
src/gtk1/dnd.cpp
237
src/gtk1/dnd.cpp
@@ -27,6 +27,239 @@
|
|||||||
|
|
||||||
extern bool g_blockEventsOnDrag;
|
extern bool g_blockEventsOnDrag;
|
||||||
|
|
||||||
|
|
||||||
|
#if (GTK_MINOR_VERSION == 1)
|
||||||
|
#if (GTK_MICRO_VERSION >= 3)
|
||||||
|
#define NEW_GTK_DND_CODE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
wxDropTarget::wxDropTarget()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDropTarget::~wxDropTarget()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropTarget::UnregisterWidget( GtkWidget *widget )
|
||||||
|
{
|
||||||
|
if (!widget) return;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropTarget::RegisterWidget( GtkWidget *widget )
|
||||||
|
{
|
||||||
|
if (!widget) return;
|
||||||
|
|
||||||
|
wxString formats;
|
||||||
|
int valid = 0;
|
||||||
|
|
||||||
|
for ( size_t i = 0; i < GetFormatCount(); i++ )
|
||||||
|
{
|
||||||
|
wxDataFormat df = GetFormat( i );
|
||||||
|
switch (df)
|
||||||
|
{
|
||||||
|
case wxDF_TEXT:
|
||||||
|
if (i > 0) formats += ";";
|
||||||
|
formats += "text/plain";
|
||||||
|
valid++;
|
||||||
|
break;
|
||||||
|
case wxDF_FILENAME:
|
||||||
|
if (i > 0) formats += ";";
|
||||||
|
formats += "file:ALL";
|
||||||
|
valid++;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
char *str = WXSTRINGCAST formats;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxTextDropTarget
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxTextDropTarget::OnDrop( long x, long y, const void *data, size_t WXUNUSED(size) )
|
||||||
|
{
|
||||||
|
OnDropText( x, y, (const char*)data );
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxTextDropTarget::OnDropText( long x, long y, const char *psz )
|
||||||
|
{
|
||||||
|
printf( "Got dropped text: %s.\n", psz );
|
||||||
|
printf( "At x: %d, y: %d.\n", (int)x, (int)y );
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t wxTextDropTarget::GetFormatCount() const
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDataFormat wxTextDropTarget::GetFormat(size_t WXUNUSED(n)) const
|
||||||
|
{
|
||||||
|
return wxDF_TEXT;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxFileDropTarget
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxFileDropTarget::OnDropFiles( long x, long y, size_t nFiles, const char * const aszFiles[] )
|
||||||
|
{
|
||||||
|
printf( "Got %d dropped files.\n", (int)nFiles );
|
||||||
|
printf( "At x: %d, y: %d.\n", (int)x, (int)y );
|
||||||
|
for (size_t i = 0; i < nFiles; i++)
|
||||||
|
{
|
||||||
|
printf( aszFiles[i] );
|
||||||
|
printf( "\n" );
|
||||||
|
}
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxFileDropTarget::OnDrop(long x, long y, const void *data, size_t size )
|
||||||
|
{
|
||||||
|
size_t number = 0;
|
||||||
|
char *text = (char*) data;
|
||||||
|
for (size_t i = 0; i < size; i++)
|
||||||
|
if (text[i] == 0) number++;
|
||||||
|
|
||||||
|
if (number == 0) return TRUE;
|
||||||
|
|
||||||
|
char **files = new char*[number];
|
||||||
|
|
||||||
|
text = (char*) data;
|
||||||
|
for (size_t i = 0; i < number; i++)
|
||||||
|
{
|
||||||
|
files[i] = text;
|
||||||
|
int len = strlen( text );
|
||||||
|
text += len+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ret = OnDropFiles( x, y, 1, files );
|
||||||
|
|
||||||
|
free( files );
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t wxFileDropTarget::GetFormatCount() const
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDataFormat wxFileDropTarget::GetFormat(size_t WXUNUSED(n)) const
|
||||||
|
{
|
||||||
|
return wxDF_FILENAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
// wxDropSource
|
||||||
|
//-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxDropSource::wxDropSource( wxWindow *win )
|
||||||
|
{
|
||||||
|
g_blockEventsOnDrag = TRUE;
|
||||||
|
|
||||||
|
m_window = win;
|
||||||
|
m_widget = win->m_widget;
|
||||||
|
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
||||||
|
|
||||||
|
m_data = (wxDataObject *) NULL;
|
||||||
|
m_retValue = wxDragCancel;
|
||||||
|
|
||||||
|
m_defaultCursor = wxCursor( wxCURSOR_NO_ENTRY );
|
||||||
|
m_goaheadCursor = wxCursor( wxCURSOR_HAND );
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDropSource::wxDropSource( wxDataObject &data, wxWindow *win )
|
||||||
|
{
|
||||||
|
g_blockEventsOnDrag = TRUE;
|
||||||
|
|
||||||
|
m_window = win;
|
||||||
|
m_widget = win->m_widget;
|
||||||
|
if (win->m_wxwindow) m_widget = win->m_wxwindow;
|
||||||
|
m_retValue = wxDragCancel;
|
||||||
|
|
||||||
|
m_data = &data;
|
||||||
|
|
||||||
|
m_defaultCursor = wxCursor( wxCURSOR_NO_ENTRY );
|
||||||
|
m_goaheadCursor = wxCursor( wxCURSOR_HAND );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropSource::SetData( wxDataObject &data )
|
||||||
|
{
|
||||||
|
m_data = &data;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDropSource::~wxDropSource(void)
|
||||||
|
{
|
||||||
|
// if (m_data) delete m_data;
|
||||||
|
|
||||||
|
g_blockEventsOnDrag = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDragResult wxDropSource::DoDragDrop( bool WXUNUSED(bAllowMove) )
|
||||||
|
{
|
||||||
|
wxASSERT_MSG( m_data, "wxDragSource: no data" );
|
||||||
|
|
||||||
|
if (!m_data) return (wxDragResult) wxDragNone;
|
||||||
|
if (m_data->GetDataSize() == 0) return (wxDragResult) wxDragNone;
|
||||||
|
|
||||||
|
RegisterWindow();
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
|
||||||
|
UnregisterWindow();
|
||||||
|
|
||||||
|
g_blockEventsOnDrag = FALSE;
|
||||||
|
|
||||||
|
return m_retValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropSource::RegisterWindow(void)
|
||||||
|
{
|
||||||
|
if (!m_data) return;
|
||||||
|
|
||||||
|
wxString formats;
|
||||||
|
|
||||||
|
wxDataFormat df = m_data->GetPreferredFormat();
|
||||||
|
|
||||||
|
switch (df)
|
||||||
|
{
|
||||||
|
case wxDF_TEXT:
|
||||||
|
formats += "text/plain";
|
||||||
|
break;
|
||||||
|
case wxDF_FILENAME:
|
||||||
|
formats += "file:ALL";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *str = WXSTRINGCAST formats;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDropSource::UnregisterWindow(void)
|
||||||
|
{
|
||||||
|
if (!m_widget) return;
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxDropTarget
|
// wxDropTarget
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -322,3 +555,7 @@ void wxDropSource::UnregisterWindow(void)
|
|||||||
|
|
||||||
gtk_signal_disconnect_by_data( GTK_OBJECT(m_widget), (gpointer)this );
|
gtk_signal_disconnect_by_data( GTK_OBJECT(m_widget), (gpointer)this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
// NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
@@ -342,11 +342,16 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
|
|
||||||
m_width = width;
|
m_width = width;
|
||||||
m_height = height;
|
m_height = height;
|
||||||
|
|
||||||
if ((m_minWidth != -1) && (m_width < m_minWidth)) m_width = m_minWidth;
|
if ((m_minWidth != -1) && (m_width < m_minWidth)) m_width = m_minWidth;
|
||||||
if ((m_minHeight != -1) && (m_height < m_minHeight)) m_height = m_minHeight;
|
if ((m_minHeight != -1) && (m_height < m_minHeight)) m_height = m_minHeight;
|
||||||
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
if ((m_maxWidth != -1) && (m_width > m_maxWidth)) m_width = m_minWidth;
|
||||||
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
if ((m_maxHeight != -1) && (m_height > m_maxHeight)) m_height = m_minHeight;
|
||||||
|
|
||||||
|
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
||||||
|
event.SetEventObject( this );
|
||||||
|
ProcessEvent( event );
|
||||||
|
|
||||||
gtk_widget_set_usize( m_widget, m_width, m_height );
|
gtk_widget_set_usize( m_widget, m_width, m_height );
|
||||||
|
|
||||||
// This emulates the new wxMSW behaviour
|
// This emulates the new wxMSW behaviour
|
||||||
@@ -385,10 +390,6 @@ void wxFrame::GtkOnSize( int WXUNUSED(x), int WXUNUSED(y), int width, int height
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_sizeSet = TRUE;
|
m_sizeSet = TRUE;
|
||||||
|
|
||||||
wxSizeEvent event( wxSize(m_width,m_height), GetId() );
|
|
||||||
event.SetEventObject( this );
|
|
||||||
ProcessEvent( event );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
||||||
@@ -396,11 +397,13 @@ void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
|||||||
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
wxASSERT_MSG( (m_widget != NULL), "invalid frame" );
|
||||||
|
|
||||||
if (GetAutoLayout())
|
if (GetAutoLayout())
|
||||||
|
{
|
||||||
Layout();
|
Layout();
|
||||||
else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
// no child: go out !
|
// no child: go out !
|
||||||
if (!GetChildren()->First())
|
if (!GetChildren()->First()) return;
|
||||||
return;
|
|
||||||
|
|
||||||
// do we have exactly one child?
|
// do we have exactly one child?
|
||||||
wxWindow *child = (wxWindow *) NULL;
|
wxWindow *child = (wxWindow *) NULL;
|
||||||
@@ -415,9 +418,8 @@ void wxFrame::OnSize( wxSizeEvent &WXUNUSED(event) )
|
|||||||
#endif
|
#endif
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
if ( child ) // it's the second one: do nothing
|
// it's the second one: do nothing
|
||||||
return;
|
if (child) return;
|
||||||
|
|
||||||
child = win;
|
child = win;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#include "wx/scrolbar.h"
|
#include "wx/scrolbar.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
|
@@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include "wx/slider.h"
|
#include "wx/slider.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
|
@@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#include "wx/spinbutt.h"
|
#include "wx/spinbutt.h"
|
||||||
#include "wx/utils.h"
|
#include "wx/utils.h"
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
|
@@ -84,8 +84,8 @@ bool wxTextCtrl::Create( wxWindow *parent, wxWindowID id, const wxString &value,
|
|||||||
// ... and put into the upper left hand corner of the table
|
// ... and put into the upper left hand corner of the table
|
||||||
m_widget = gtk_table_new(bHasHScrollbar ? 2 : 1, 2, FALSE);
|
m_widget = gtk_table_new(bHasHScrollbar ? 2 : 1, 2, FALSE);
|
||||||
gtk_table_attach( GTK_TABLE(m_widget), m_text, 0, 1, 0, 1,
|
gtk_table_attach( GTK_TABLE(m_widget), m_text, 0, 1, 0, 1,
|
||||||
GTK_FILL | GTK_EXPAND,
|
(GtkAttachOptions)(GTK_FILL | GTK_EXPAND),
|
||||||
GTK_FILL | GTK_EXPAND | GTK_SHRINK,
|
(GtkAttachOptions)(GTK_FILL | GTK_EXPAND | GTK_SHRINK),
|
||||||
0, 0);
|
0, 0);
|
||||||
|
|
||||||
// put the horizontal scrollbar in the lower left hand corner
|
// put the horizontal scrollbar in the lower left hand corner
|
||||||
@@ -93,7 +93,7 @@ bool wxTextCtrl::Create( wxWindow *parent, wxWindowID id, const wxString &value,
|
|||||||
{
|
{
|
||||||
GtkWidget *hscrollbar = gtk_hscrollbar_new(GTK_TEXT(m_text)->hadj);
|
GtkWidget *hscrollbar = gtk_hscrollbar_new(GTK_TEXT(m_text)->hadj);
|
||||||
gtk_table_attach(GTK_TABLE(m_widget), hscrollbar, 0, 1, 1, 2,
|
gtk_table_attach(GTK_TABLE(m_widget), hscrollbar, 0, 1, 1, 2,
|
||||||
GTK_EXPAND | GTK_FILL,
|
(GtkAttachOptions)(GTK_EXPAND | GTK_FILL),
|
||||||
GTK_FILL,
|
GTK_FILL,
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_widget_show(hscrollbar);
|
gtk_widget_show(hscrollbar);
|
||||||
@@ -103,7 +103,7 @@ bool wxTextCtrl::Create( wxWindow *parent, wxWindowID id, const wxString &value,
|
|||||||
GtkWidget *vscrollbar = gtk_vscrollbar_new(GTK_TEXT(m_text)->vadj);
|
GtkWidget *vscrollbar = gtk_vscrollbar_new(GTK_TEXT(m_text)->vadj);
|
||||||
gtk_table_attach(GTK_TABLE(m_widget), vscrollbar, 1, 2, 0, 1,
|
gtk_table_attach(GTK_TABLE(m_widget), vscrollbar, 1, 2, 0, 1,
|
||||||
GTK_FILL,
|
GTK_FILL,
|
||||||
GTK_EXPAND | GTK_FILL | GTK_SHRINK,
|
(GtkAttachOptions)(GTK_EXPAND | GTK_FILL | GTK_SHRINK),
|
||||||
0, 0);
|
0, 0);
|
||||||
gtk_widget_show( vscrollbar );
|
gtk_widget_show( vscrollbar );
|
||||||
}
|
}
|
||||||
|
@@ -104,6 +104,10 @@ gtk_myfixed_init (GtkMyFixed *myfixed)
|
|||||||
GTK_WIDGET_UNSET_FLAGS (myfixed, GTK_NO_WINDOW);
|
GTK_WIDGET_UNSET_FLAGS (myfixed, GTK_NO_WINDOW);
|
||||||
GTK_WIDGET_SET_FLAGS (myfixed, GTK_BASIC);
|
GTK_WIDGET_SET_FLAGS (myfixed, GTK_BASIC);
|
||||||
|
|
||||||
|
#if (GTK_MINOR_VERSION == 1)
|
||||||
|
gtk_container_set_resize_mode( GTK_CONTAINER(myfixed), GTK_RESIZE_PARENT );
|
||||||
|
#endif
|
||||||
|
|
||||||
myfixed->children = NULL;
|
myfixed->children = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -108,6 +108,16 @@
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// cond comp
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#if (GTK_MINOR_VERSION == 1)
|
||||||
|
#if (GTK_MICRO_VERSION >= 3)
|
||||||
|
#define NEW_GTK_DND_CODE
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// data
|
// data
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -837,6 +847,11 @@ static gint gtk_scrollbar_button_release_callback( GtkRange *widget, GdkEventBut
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// "drop_data_available_event"
|
// "drop_data_available_event"
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -862,6 +877,9 @@ static void gtk_window_drop_callback( GtkWidget *widget, GdkEventDropDataAvailab
|
|||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
// NEW_GTK_DND_CODE
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// InsertChild for wxWindow.
|
// InsertChild for wxWindow.
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@@ -2196,18 +2214,32 @@ void wxWindow::ConnectDnDWidget( GtkWidget *widget )
|
|||||||
|
|
||||||
m_dropTarget->RegisterWidget( widget );
|
m_dropTarget->RegisterWidget( widget );
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
gtk_signal_connect( GTK_OBJECT(widget), "drop_data_available_event",
|
gtk_signal_connect( GTK_OBJECT(widget), "drop_data_available_event",
|
||||||
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxWindow::DisconnectDnDWidget( GtkWidget *widget )
|
void wxWindow::DisconnectDnDWidget( GtkWidget *widget )
|
||||||
{
|
{
|
||||||
if (!m_dropTarget) return;
|
if (!m_dropTarget) return;
|
||||||
|
|
||||||
|
#ifdef NEW_GTK_DND_CODE
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
gtk_signal_disconnect_by_func( GTK_OBJECT(widget),
|
gtk_signal_disconnect_by_func( GTK_OBJECT(widget),
|
||||||
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
GTK_SIGNAL_FUNC(gtk_window_drop_callback), (gpointer)this );
|
||||||
|
|
||||||
m_dropTarget->UnregisterWidget( widget );
|
m_dropTarget->UnregisterWidget( widget );
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget* wxWindow::GetConnectWidget()
|
GtkWidget* wxWindow::GetConnectWidget()
|
||||||
|
Reference in New Issue
Block a user