FLTK 1.3.8
Fl_Image.H
Go to the documentation of this file.
1//
2// "$Id$"
3//
4// Image header file for the Fast Light Tool Kit (FLTK).
5//
6// Copyright 1998-2016 by Bill Spitzak and others.
7//
8// This library is free software. Distribution and use rights are outlined in
9// the file "COPYING" which should have been included with this file. If this
10// file is missing or damaged, see the license at:
11//
12// http://www.fltk.org/COPYING.php
13//
14// Please report all bugs and problems on the following page:
15//
16// http://www.fltk.org/str.php
17//
18
22#ifndef Fl_Image_H
23# define Fl_Image_H
24
25# include "Enumerations.H"
26#include <stdlib.h>
27
28class Fl_Widget;
29class Fl_Pixmap;
30struct Fl_Menu_Item;
31struct Fl_Label;
32
33
40};
41
42
55class FL_EXPORT Fl_Image {
56
57public:
58 static const int ERR_NO_IMAGE = -1;
59 static const int ERR_FILE_ACCESS = -2;
60 static const int ERR_FORMAT = -3;
61
62private:
63 int w_, h_, d_, ld_, count_;
64 const char * const *data_;
65 static Fl_RGB_Scaling RGB_scaling_;
66
67 // Forbid use of copy constructor and assign operator
68 Fl_Image & operator=(const Fl_Image &);
69 Fl_Image(const Fl_Image &);
70
71protected:
72
76 void w(int W) {w_ = W;}
80 void h(int H) {h_ = H;}
84 void d(int D) {d_ = D;}
96 void ld(int LD) {ld_ = LD;}
100 void data(const char * const *p, int c) {data_ = p; count_ = c;}
101 void draw_empty(int X, int Y);
102
103 static void labeltype(const Fl_Label *lo, int lx, int ly, int lw, int lh, Fl_Align la);
104 static void measure(const Fl_Label *lo, int &lw, int &lh);
105
106public:
107
111 int w() const {return w_;}
115 int h() const {return h_;}
121 int d() const {return d_;}
126 int ld() const {return ld_;}
133 int count() const {return count_;}
138 const char * const *data() const {return data_;}
139 int fail();
140 Fl_Image(int W, int H, int D);
141 virtual ~Fl_Image();
142 virtual Fl_Image *copy(int W, int H);
150 Fl_Image *copy() { return copy(w(), h()); }
151 virtual void color_average(Fl_Color c, float i);
160 void inactive() { color_average(FL_GRAY, .33f); }
161 virtual void desaturate();
162 virtual void label(Fl_Widget*w);
163 virtual void label(Fl_Menu_Item*m);
175 virtual void draw(int X, int Y, int W, int H, int cx=0, int cy=0); // platform dependent
180 void draw(int X, int Y) {draw(X, Y, w(), h(), 0, 0);} // platform dependent
181 virtual void uncache();
182
183 // set RGB image scaling method
184 static void RGB_scaling(Fl_RGB_Scaling);
185
186 // get RGB image scaling method
187 static Fl_RGB_Scaling RGB_scaling();
188};
189
190
202class FL_EXPORT Fl_RGB_Image : public Fl_Image {
203 friend class Fl_Quartz_Graphics_Driver;
204 friend class Fl_GDI_Graphics_Driver;
206 friend class Fl_Xlib_Graphics_Driver;
207 static size_t max_size_;
208public:
209
212 const uchar *array;
216
217 private:
218
219#if defined(__APPLE__) || defined(WIN32)
220 void *id_; // for internal use
221 void *mask_; // for internal use (mask bitmap)
222#else
223 unsigned id_; // for internal use
224 unsigned mask_; // for internal use (mask bitmap)
225#endif // __APPLE__ || WIN32
226
227public:
228
229 Fl_RGB_Image(const uchar *bits, int W, int H, int D=3, int LD=0);
230 Fl_RGB_Image(const Fl_Pixmap *pxm, Fl_Color bg=FL_GRAY);
231 virtual ~Fl_RGB_Image();
232 virtual Fl_Image *copy(int W, int H);
233 Fl_Image *copy() { return copy(w(), h()); }
234 virtual void color_average(Fl_Color c, float i);
235 virtual void desaturate();
236 virtual void draw(int X, int Y, int W, int H, int cx=0, int cy=0);
237 void draw(int X, int Y) {draw(X, Y, w(), h(), 0, 0);}
238 virtual void label(Fl_Widget*w);
239 virtual void label(Fl_Menu_Item*m);
240 virtual void uncache();
250 static void max_size(size_t size) { max_size_ = size;}
255 static size_t max_size() {return max_size_;}
256};
257
258#endif // !Fl_Image_H
259
260//
261// End of "$Id$".
262//
This file contains type definitions and general enumerations.
unsigned Fl_Align
FLTK type for alignment control.
Definition: Enumerations.H:826
unsigned int Fl_Color
An FLTK color value; see also Colors
Definition: Enumerations.H:932
Fl_RGB_Scaling
The scaling algorithm to use for RGB images.
Definition: Fl_Image.H:37
@ FL_RGB_SCALING_NEAREST
default RGB image scaling algorithm
Definition: Fl_Image.H:38
@ FL_RGB_SCALING_BILINEAR
more accurate, but slower RGB image scaling algorithm
Definition: Fl_Image.H:39
The MSWindows-specific graphics class.
Definition: Fl_Device.H:459
The graphics driver used when printing on MSWindows.
Definition: Fl_Device.H:492
Fl_Fontsize size()
see fl_size().
Definition: Fl_Device.H:390
Base class for image caching and drawing.
Definition: Fl_Image.H:55
int count() const
The count() method returns the number of data values associated with the image.
Definition: Fl_Image.H:133
void d(int D)
Sets the current image depth.
Definition: Fl_Image.H:84
void draw(int X, int Y)
Draws the image.
Definition: Fl_Image.H:180
void data(const char *const *p, int c)
Sets the current array pointer and count of pointers in the array.
Definition: Fl_Image.H:100
const char *const * data() const
Returns a pointer to the current image data array.
Definition: Fl_Image.H:138
void h(int H)
Sets the current image height in pixels.
Definition: Fl_Image.H:80
int w() const
Returns the current image width in pixels.
Definition: Fl_Image.H:111
void ld(int LD)
Sets the current line data size in bytes.
Definition: Fl_Image.H:96
Fl_Image * copy()
The copy() method creates a copy of the specified image.
Definition: Fl_Image.H:150
void w(int W)
Sets the current image width in pixels.
Definition: Fl_Image.H:76
int ld() const
Returns the current line data size in bytes.
Definition: Fl_Image.H:126
void inactive()
The inactive() method calls color_average(FL_BACKGROUND_COLOR, 0.33f) to produce an image that appear...
Definition: Fl_Image.H:160
int h() const
Returns the current image height in pixels.
Definition: Fl_Image.H:115
int d() const
Returns the current image depth.
Definition: Fl_Image.H:121
The Fl_Pixmap class supports caching and drawing of colormap (pixmap) images, including transparency.
Definition: Fl_Pixmap.H:41
The Mac OS X-specific graphics class.
Definition: Fl_Device.H:421
The Fl_RGB_Image class supports caching and drawing of full-color images with 1 to 4 channels of colo...
Definition: Fl_Image.H:202
const uchar * array
Points to the start of the object's data array.
Definition: Fl_Image.H:212
static size_t max_size()
Returns the maximum allowed image size in bytes when creating an Fl_RGB_Image object.
Definition: Fl_Image.H:255
int alloc_array
If non-zero, the object's data array is delete[]'d when deleting the object.
Definition: Fl_Image.H:215
static void max_size(size_t size)
Sets the maximum allowed image size in bytes when creating an Fl_RGB_Image object.
Definition: Fl_Image.H:250
Fl_Widget is the base class for all widgets in FLTK.
Definition: Fl_Widget.H:101
The Xlib-specific graphics class.
Definition: Fl_Device.H:507
void draw(const char *str, int n, int x, int y)
see fl_draw(const char *str, int n, int x, int y).
unsigned char uchar
unsigned char
Definition: fl_types.h:30
This struct stores all information for a text or mixed graphics label.
Definition: Fl_Widget.H:65
The Fl_Menu_Item structure defines a single menu item that is used by the Fl_Menu_ class.
Definition: Fl_Menu_Item.H:112