ffmpeg versioning mods from Andrew
[goodguy/cinelerra.git] / cinelerra-5.1 / cinelerra / picture.h
1
2 /*
3  * CINELERRA
4  * Copyright (C) 2008 Adam Williams <broadcast at earthling dot net>
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  */
21
22 #ifndef PICTURE_H
23 #define PICTURE_H
24
25
26 // Container for picture controls like brightness.
27
28 #include "arraylist.h"
29 #include "bcwindowbase.inc"
30 #include "bchash.inc"
31 #include "mwindow.inc"
32
33 class PictureItem
34 {
35 public:
36         PictureItem();
37         ~PictureItem();
38
39         void copy_from(PictureItem *src);
40         char* get_default_string(char *string);
41         char name[BCTEXTLEN];
42         int device_id;
43         int min;
44         int max;
45         int default_;
46         int step;
47         int type;
48         int value;
49 };
50
51
52 class PictureConfig
53 {
54 public:
55         PictureConfig();
56         ~PictureConfig();
57         void copy_settings(PictureConfig *picture);
58         void copy_usage(PictureConfig *picture);
59         void load_defaults();
60         void save_defaults();
61 // return 1 if it changed
62         int set_item(int device_id, int value);
63         void dump();
64
65         int brightness;
66         int hue;
67         int color;
68         int contrast;
69         int whiteness;
70
71 // Flags for picture settings the device uses
72         int use_brightness;
73         int use_contrast;
74         int use_color;
75         int use_hue;
76         int use_whiteness;
77
78 // For the latest APIs the controls are defined by the driver
79 // Search for existing driver with name.  If none exists, create it.
80         PictureItem* new_item(const char *name);
81         PictureItem* get_item(const char *name, int id);
82         ArrayList<PictureItem*> controls;
83 // Pointer to MWindow::defaults get defaults
84         BC_Hash *defaults;
85 };
86
87
88 #endif