// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_UI_GTK_ROUNDED_WINDOW_H_
#define CHROME_BROWSER_UI_GTK_ROUNDED_WINDOW_H_
#pragma once
#include <gtk/gtk.h>
namespace gtk_util {
// Symbolic names for arguments to |rounded_edges| in ActAsRoundedWindow().
enum RoundedBorders {
ROUNDED_NONE = 0,
ROUNDED_BOTTOM_LEFT = 1 << 0,
ROUNDED_TOP_LEFT = 1 << 1,
ROUNDED_TOP_RIGHT = 1 << 2,
ROUNDED_TOP = (1 << 1) | (1 << 2),
ROUNDED_BOTTOM_RIGHT = 1 << 3,
ROUNDED_ALL = 0xF
};
// Symbolic names for arguments to |drawn_borders| in ActAsRoundedWindow().
enum BorderEdge {
BORDER_NONE = 0,
BORDER_LEFT = 1 << 0,
BORDER_TOP = 1 << 1,
BORDER_RIGHT = 1 << 2,
BORDER_BOTTOM = 1 << 3,
BORDER_ALL = 0xF
};
// Sets up the passed in widget that has its own GdkWindow with an expose
// handler that forces the window shape into roundness. Caller should not set
// an "expose-event" handler on |widget|; if caller needs to do custom
// rendering, use SetRoundedWindowExposeFunction() instead. |rounded_edges|
// control which corners are rounded. |drawn_borders| border control which
// sides have a visible border drawn in |color|.
void ActAsRoundedWindow(
GtkWidget* widget, const GdkColor& color, int corner_size,
int rounded_edges, int drawn_borders);
// Undoes most of the actions of ActAsRoundedWindow().
void StopActingAsRoundedWindow(GtkWidget* widget);
// Returns true if the window is rounded.
bool IsActingAsRoundedWindow(GtkWidget* widget);
// Sets edge and border properties on a widget that has already been configured
// with ActAsRoundedWindow().
void SetRoundedWindowEdgesAndBorders(GtkWidget* widget,
int corner_size,
int rounded_edges,
int drawn_borders);
// Sets the color of the border on a widget that has already been configured
// with ActAsRoundedWindow().
void SetRoundedWindowBorderColor(GtkWidget* widget, GdkColor color);
} // namespace gtk_util
#endif // CHROME_BROWSER_UI_GTK_ROUNDED_WINDOW_H_