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.
5 #ifndef UI_GFX_GTK_UTIL_H_
6 #define UI_GFX_GTK_UTIL_H_
10 #include "base/time.h"
11 #include "ui/base/ui_export.h"
13 typedef struct _GdkPixbuf GdkPixbuf
;
14 typedef struct _GdkRegion GdkRegion
;
15 typedef struct _GdkCursor GdkCursor
;
24 // Call gtk_init() / gdk_init() using the argc and argv from command_line.
25 // These init functions want an argc and argv that they can mutate; we provide
26 // those, but leave the original CommandLine unaltered.
27 UI_EXPORT
void GtkInitFromCommandLine(const CommandLine
& command_line
);
28 UI_EXPORT
void GdkInitFromCommandLine(const CommandLine
& command_line
);
30 // Convert and copy a SkBitmap to a GdkPixbuf. NOTE: this uses BGRAToRGBA, so
31 // it is an expensive operation. The returned GdkPixbuf will have a refcount of
32 // 1, and the caller is responsible for unrefing it when done.
33 UI_EXPORT GdkPixbuf
* GdkPixbufFromSkBitmap(const SkBitmap
& bitmap
);
35 // Modify the given region by subtracting the given rectangles.
36 UI_EXPORT
void SubtractRectanglesFromRegion(GdkRegion
* region
,
37 const std::vector
<Rect
>& cutouts
);
39 // Returns a static instance of a GdkCursor* object, sharable across the
40 // process. Caller must gdk_cursor_ref() it if they want to assume ownership.
41 UI_EXPORT GdkCursor
* GetCursor(int type
);
43 // Initialize some GTK settings so that our dialogs are consistent.
44 UI_EXPORT
void InitRCStyles();
46 // Queries GtkSettings for the cursor blink cycle time. Returns a 0 duration if
47 // blinking is disabled.
48 UI_EXPORT
base::TimeDelta
GetCursorBlinkCycle();
52 #endif // UI_GFX_GTK_UTIL_H_