OLD | NEW |
| (Empty) |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef UI_BASE_LINUX_UI_H_ | |
6 #define UI_BASE_LINUX_UI_H_ | |
7 | |
8 #include "ui/base/ui_export.h" | |
9 #include "third_party/skia/include/core/SkColor.h" | |
10 | |
11 // The main entrypoint into Linux toolkit specific code. GTK code should only | |
12 // be executed behind this interface. | |
13 | |
14 namespace gfx { | |
15 class Image; | |
16 } | |
17 | |
18 namespace ui { | |
19 class SelectFilePolicy; | |
20 | |
21 // Adapter class with targets to render like different toolkits. Set by any | |
22 // project that wants to do linux desktop native rendering. | |
23 // | |
24 // TODO(erg): We're hardcoding GTK2, when we'll need to have backends for (at | |
25 // minimum) GTK2 and GTK3. LinuxUI::instance() should actually be a very | |
26 // complex method that pokes around with dlopen against a libuigtk2.so, a | |
27 // liuigtk3.so, etc. | |
28 class UI_EXPORT LinuxUI { | |
29 public: | |
30 virtual ~LinuxUI() {} | |
31 | |
32 // Sets the dynamically loaded singleton that draws the desktop native UI. | |
33 static void SetInstance(LinuxUI* instance); | |
34 | |
35 // Returns a LinuxUI instance for the toolkit used in the user's desktop | |
36 // environment. | |
37 // | |
38 // Can return NULL, in case no toolkit has been set. (For example, if we're | |
39 // running with the "--ash" flag.) | |
40 static const LinuxUI* instance(); | |
41 | |
42 // Returns an themed image per theme_provider.h | |
43 virtual bool UseNativeTheme() const = 0; | |
44 virtual gfx::Image* GetThemeImageNamed(int id) const = 0; | |
45 virtual bool GetColor(int id, SkColor* color) const = 0; | |
46 }; | |
47 | |
48 } // namespace ui | |
49 | |
50 #endif // UI_BASE_LINUX_UI_H_ | |
OLD | NEW |