// Created: 12/07/98
// RCS-ID: $Id$
// Copyright: (c) Julian Smart
-// Licence: wxWindows licence
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _OGL_DRAWN_H_
#define _OGL_DRAWN_H_
-#ifdef __GNUG__
-#pragma interface "drawn.h"
-#endif
-
-#include <wx/ogl/basic.h>
#define oglMETAFLAGS_OUTLINE 1
#define oglMETAFLAGS_ATTACHMENTS 2
-class wxDrawnShape;
-class wxPseudoMetaFile: public wxObject
+class WXDLLIMPEXP_OGL wxDrawnShape;
+class WXDLLIMPEXP_OGL wxPseudoMetaFile: public wxObject
{
DECLARE_DYNAMIC_CLASS(wxPseudoMetaFile)
public:
void Draw(wxDC& dc, double xoffset, double yoffset);
-#ifdef PROLOGIO
+#if wxUSE_PROLOGIO
void WriteAttributes(wxExpr *clause, int whichAngle);
void ReadAttributes(wxExpr *clause, int whichAngle);
#endif
// Rotate about the given axis by theta radians from the x axis.
void Rotate(double x, double y, double theta);
- bool LoadFromMetaFile(char *filename, double *width, double *height);
+ bool LoadFromMetaFile(const wxString& filename, double *width, double *height);
void GetBounds(double *minX, double *minY, double *maxX, double *maxY);
inline void SetSize(double w, double h) { m_width = w; m_height = h; }
- inline void SetFillBrush(wxBrush* brush) { m_fillBrush = brush; }
- inline wxBrush* GetFillBrush() const { return m_fillBrush; }
+ inline void SetFillBrush(const wxBrush* brush) { m_fillBrush = brush; }
+ inline wxBrush* GetFillBrush() const { return wx_const_cast(wxBrush*, m_fillBrush); }
- inline void SetOutlinePen(wxPen* pen) { m_outlinePen = pen; }
- inline wxPen* GetOutlinePen() const { return m_outlinePen; }
+ inline void SetOutlinePen(const wxPen* pen) { m_outlinePen = pen; }
+ inline wxPen* GetOutlinePen() const { return wx_const_cast(wxPen*, m_outlinePen); }
inline void SetOutlineOp(int op) { m_outlineOp = op; }
inline int GetOutlineOp() const { return m_outlineOp; }
inline wxList& GetOps() const { return (wxList&) m_ops; }
// Is this a valid (non-empty) metafile?
- inline bool IsValid() const { return (m_ops.Number() > 0); }
+ inline bool IsValid() const { return (m_ops.GetCount() > 0); }
public:
/// Set of functions for drawing into a pseudo metafile.
virtual void SetClippingRect(const wxRect& rect);
virtual void DestroyClippingRect();
- virtual void SetPen(wxPen* pen, bool isOutline = FALSE); // TODO: eventually, just store GDI object attributes, not actual
- virtual void SetBrush(wxBrush* brush, bool isFill = FALSE); // pens/brushes etc.
+ virtual void SetPen(const wxPen* pen, bool isOutline = false); // TODO: eventually, just store GDI object attributes, not actual
+ virtual void SetBrush(const wxBrush* brush, bool isFill = false); // pens/brushes etc.
virtual void SetFont(wxFont* font);
virtual void SetTextColour(const wxColour& colour);
virtual void SetBackgroundColour(const wxColour& colour);
// Pen/brush specifying outline/fill colours
// to override operations.
- wxPen* m_outlinePen;
- wxBrush* m_fillBrush;
+ const wxPen* m_outlinePen;
+ const wxBrush* m_fillBrush;
wxList m_outlineColours; // List of the GDI operations that comprise the outline
wxList m_fillColours; // List of the GDI operations that fill the shape
double m_currentRotation;
#define oglDRAWN_ANGLE_180 2
#define oglDRAWN_ANGLE_270 3
-class wxDrawnShape: public wxRectangleShape
+class WXDLLIMPEXP_OGL wxDrawnShape: public wxRectangleShape
{
DECLARE_DYNAMIC_CLASS(wxDrawnShape)
public:
void OnDraw(wxDC& dc);
-#ifdef PROLOGIO
+#if wxUSE_PROLOGIO
// I/O
void WriteAttributes(wxExpr *clause);
void ReadAttributes(wxExpr *clause);
// Get current rotation
inline double GetRotation() const { return m_rotation; }
- void SetSize(double w, double h, bool recursive = TRUE);
- bool LoadFromMetaFile(char *filename);
+ void SetSize(double w, double h, bool recursive = true);
+ bool LoadFromMetaFile(const wxString& filename);
inline void SetSaveToFile(bool save) { m_saveToFile = save; }
inline wxPseudoMetaFile& GetMetaFile(int which = 0) const { return (wxPseudoMetaFile&) m_metafiles[which]; }
virtual void SetClippingRect(const wxRect& rect);
virtual void DestroyClippingRect();
- virtual void SetDrawnPen(wxPen* pen, bool isOutline = FALSE); // TODO: eventually, just store GDI object attributes, not actual
- virtual void SetDrawnBrush(wxBrush* brush, bool isFill = FALSE); // pens/brushes etc.
+ virtual void SetDrawnPen(const wxPen* pen, bool isOutline = false); // TODO: eventually, just store GDI object attributes, not actual
+ virtual void SetDrawnBrush(const wxBrush* brush, bool isFill = false); // pens/brushes etc.
virtual void SetDrawnFont(wxFont* font);
virtual void SetDrawnTextColour(const wxColour& colour);
virtual void SetDrawnBackgroundColour(const wxColour& colour);
#endif
// _DRAWN_H_
-