]> git.lyx.org Git - lyx.git/blob - src/frontends/controllers/ControlGraphics.C
Rob's beauty treatment to the graphics dialog.
[lyx.git] / src / frontends / controllers / ControlGraphics.C
1 /**
2  * \file ControlGraphics.C
3  * This file is part of LyX, the document processor.
4  * Licence details can be found in the file COPYING.
5  *
6  * \author Angus Leeming
7  * \author Herbert Voss
8  *
9  * Full author contact details are available in file CREDITS
10  */
11
12 #include <config.h>
13
14 #ifdef __GNUG__
15 #pragma implementation
16 #endif
17
18 #include "ControlGraphics.h"
19
20 #include "helper_funcs.h"
21
22 #include "buffer.h"
23 #include "BufferView.h"
24 #include "converter.h"
25 #include "gettext.h"
26 #include "lyxrc.h"
27
28 #include "graphics/GraphicsCache.h"
29 #include "graphics/GraphicsCacheItem.h"
30 #include "graphics/GraphicsImage.h"
31
32 #include "insets/insetgraphics.h"
33 #include "insets/insetgraphicsParams.h"
34
35 #include "support/lstrings.h"
36 #include "support/filetools.h"
37 #include "support/FileInfo.h"
38
39 using std::pair;
40 using std::make_pair;
41 using std::vector;
42
43 ControlGraphics::ControlGraphics(LyXView & lv, Dialogs & d)
44         : ControlInset<InsetGraphics, InsetGraphicsParams>(lv, d)
45 {}
46
47
48 InsetGraphicsParams const ControlGraphics::getParams(string const &)
49 {
50         return InsetGraphicsParams();
51 }
52
53
54 InsetGraphicsParams const
55 ControlGraphics::getParams(InsetGraphics const & inset)
56 {
57         return inset.params();
58 }
59
60
61 void ControlGraphics::applyParamsToInset()
62 {
63         // Set the parameters in the inset, it also returns true if the new
64         // parameters are different from what was in the inset already.
65         bool changed = inset()->setParams(params(), buffer()->filePath());
66
67         // Tell LyX we've got a change, and mark the document dirty,
68         // if it changed.
69         bufferview()->updateInset(inset(), changed);
70 }
71
72
73 void ControlGraphics::applyParamsNoInset()
74 {}
75
76
77 // We need these in the file browser.
78 extern string system_lyxdir;
79 extern string user_lyxdir;
80
81
82 string const ControlGraphics::Browse(string const & in_name)
83 {
84         string const title = _("Select graphics file");
85
86         // Does user clipart directory exist?
87         string clipdir = AddName (user_lyxdir, "clipart");
88         FileInfo fileInfo(clipdir);
89         if (!(fileInfo.isOK() && fileInfo.isDir()))
90                 // No - bail out to system clipart directory
91                 clipdir = AddName (system_lyxdir, "clipart");
92         pair<string, string> dir1(_("Clipart|#C#c"), clipdir);
93         pair<string, string> dir2(_("Documents|#o#O"), string(lyxrc.document_path));
94         // Show the file browser dialog
95         return browseRelFile(&lv_, in_name, buffer()->filePath(),
96                              title, "*.*", dir1, dir2);
97 }
98
99
100 string const ControlGraphics::readBB(string const & file)
101 {
102         string const abs_file = MakeAbsPath(file, buffer()->filePath());
103
104         // try to get it from the file, if possible. Zipped files are
105         // unzipped in the readBB_from_PSFile-Function
106         string const bb = readBB_from_PSFile(abs_file);
107         if (!bb.empty())
108                 return bb;
109
110         // we don't, so ask the Graphics Cache if it has loaded the file
111         int width = 0;
112         int height = 0;
113
114         grfx::Cache & gc = grfx::Cache::get();
115         if (gc.inCache(abs_file)) {
116                 grfx::Image const * image = gc.item(abs_file)->image();
117
118                 if (image) {
119                         width  = image->getWidth();
120                         height = image->getHeight();
121                 }
122         }
123
124         return ("0 0 " + tostr(width) + ' ' + tostr(height));
125 }
126
127
128 bool ControlGraphics::isFilenameValid(string const & fname) const
129 {
130         // It may be that the filename is relative.
131         string const name = MakeAbsPath(fname, buffer()->filePath());
132         return IsFileReadable(name);
133 }
134
135
136 namespace frnt {
137
138 namespace {
139
140 // These are the strings that are stored in the LyX file and which
141 // correspond to the LaTeX identifiers shown in the comments at the
142 // end of each line.
143 char const * const rorigin_lyx_strs[] = {
144         // the LaTeX default is leftBaseline
145         "leftTop",  "leftBottom", "leftBaseline", // lt lb lB
146         "center", "centerTop", "centerBottom", "centerBaseline", // c ct cb cB
147         "rightTop", "rightBottom", "rightBaseline" }; // rt rb rB
148
149 // These are the strings, corresponding to the above, that the GUI should
150 // use. Note that they can/should be translated.
151 char const * const rorigin_gui_strs[] = {
152         N_("Top left"), N_("Bottom left"), N_("Left baseline"),
153         N_("Center"), N_("Top center"), N_("Bottom center"), N_("Center baseline"),
154         N_("Top right"), N_("Bottom right"), N_("Right baseline") };
155
156 size_t const rorigin_size = sizeof(rorigin_lyx_strs) / sizeof(char *);
157
158 } // namespace anon
159
160
161 vector<RotationOriginPair> getRotationOriginData()
162 {
163         static vector<RotationOriginPair> data;
164         if (!data.empty())
165                 return data;
166
167         data.resize(rorigin_size);
168         for (lyx::size_type i = 0; i < rorigin_size; ++i) {
169                 data[i] = make_pair(_(rorigin_gui_strs[i]),
170                                     rorigin_lyx_strs[i]);
171         }
172
173         return data;
174 }
175
176 } // namespace frnt