// Name: dcclient.cpp
// Purpose:
// Author: Robert Roebling
-// Created: 01/02/97
// RCS-ID: $Id$
-// Copyright: (c) 1998 Robert Roebling, Julian Smart and Markus Holzem
+// Copyright: (c) 1998 Robert Roebling, Markus Holzem, Chris Breeze
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
m_textGC = (GdkGC *) NULL;
m_bgGC = (GdkGC *) NULL;
m_cmap = (GdkColormap *) NULL;
+ m_isMemDC = FALSE;
}
wxPaintDC::wxPaintDC( wxWindow *window )
else
m_cmap = gtk_widget_get_colormap( window->m_widget );
- m_isDrawable = TRUE;
+ m_isMemDC = FALSE;
SetUpDC();
}
{
if (!Ok()) return;
- // FIXME: is this right? Causes a segfault on my system and doesn't
- // seem right: wxPaintDC does not inherit from wxMemoryDC
- // if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (m_pen.GetStyle() != wxTRANSPARENT)
{
gdk_draw_line( m_window, m_penGC,
{
if (!Ok()) return;
- // FIXME: is this right? Causes a segfault on my system and doesn't
- // seem right: wxPaintDC does not inherit from wxMemoryDC
- // if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (m_pen.GetStyle() != wxTRANSPARENT)
{
int w = 0;
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
long xx1 = XLOG2DEV(x1);
long yy1 = YLOG2DEV(y1);
long xx2 = XLOG2DEV(x2);
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
long xx = XLOG2DEV(x);
long yy = YLOG2DEV(y);
long ww = m_signX * XLOG2DEVREL(width);
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (m_pen.GetStyle() != wxTRANSPARENT)
gdk_draw_point( m_window, m_penGC, XLOG2DEV(x), YLOG2DEV(y) );
}
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (m_pen.GetStyle() == wxTRANSPARENT) return;
for (int i = 0; i < n-1; i++)
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (m_pen.GetStyle() == wxTRANSPARENT) return;
wxNode *node = points->First();
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (!n) return; // Nothing to draw
GdkPoint *gdkpoints = new GdkPoint[n+1];
int i;
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
int n = lines->Number();
GdkPoint *gdkpoints = new GdkPoint[n];
wxNode *node = lines->First();
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
long xx = XLOG2DEV(x);
long yy = YLOG2DEV(y);
long ww = m_signX * XLOG2DEVREL(width);
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
if (radius < 0.0) radius = - radius * ((width < height) ? width : height);
long xx = XLOG2DEV(x);
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
long xx = XLOG2DEV(x);
long yy = YLOG2DEV(y);
long ww = m_signX * XLOG2DEVREL(width);
if (!icon.Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
int xx = XLOG2DEV(x);
int yy = YLOG2DEV(y);
{
if (!Ok()) return FALSE;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
- // CMB 20/5/98: add blitting of bitmaps
- if (source->IsKindOf(CLASSINFO(wxMemoryDC)))
+ if (m_isMemDC)
{
wxMemoryDC* srcDC = (wxMemoryDC*)source;
GdkBitmap* bmap = srcDC->m_selected.GetBitmap();
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
GdkFont *font = m_font.GetInternalFont( m_scaleY );
x = XLOG2DEV(x);
{
if (!Ok()) return;
- if (!m_isDrawable) ((wxMemoryDC*)this)->m_selected.DestroyImage();
-
- if (m_isDrawable)
+ if (!m_isMemDC)
{
gdk_window_clear( m_window );
}
}
}
-void wxPaintDC::DrawOpenSpline( wxList *points )
+void wxPaintDC::DrawSpline( wxList *points )
{
wxPoint *p;
double cx1, cy1, cx2, cy2, cx3, cy3, cx4, cy4;