summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbrettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-12-03 21:28:33 +0000
committerbrettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-12-03 21:28:33 +0000
commit05b7f994c66470750905eabb12acf1643099f9b7 (patch)
treed9411a629dfb1e8dc4885374d5f788bcff47ea86
parent9ed68c36cad4f5d70a378be96d303710053eed65 (diff)
downloadchromium_src-05b7f994c66470750905eabb12acf1643099f9b7.zip
chromium_src-05b7f994c66470750905eabb12acf1643099f9b7.tar.gz
chromium_src-05b7f994c66470750905eabb12acf1643099f9b7.tar.bz2
Split the cross-platform part of skia_utils_win into skia_utils. Use this new
function when possible. Add a little documentation. This does not change the Mac build, I'll do that in a separate pass, and the function moved is never used on the mac). Review URL: http://codereview.chromium.org/12917 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@6312 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--chrome/browser/views/bookmark_bar_view.cc2
-rw-r--r--chrome/browser/views/bookmark_manager_view.cc2
-rw-r--r--chrome/browser/views/sad_tab_view.cc16
-rw-r--r--skia/SConscript1
-rw-r--r--skia/ext/skia_utils.cc25
-rw-r--r--skia/ext/skia_utils.h27
-rw-r--r--skia/ext/skia_utils_win.cc14
-rw-r--r--skia/ext/skia_utils_win.h7
-rw-r--r--skia/skia.vcproj8
9 files changed, 67 insertions, 35 deletions
diff --git a/chrome/browser/views/bookmark_bar_view.cc b/chrome/browser/views/bookmark_bar_view.cc
index 54c3c95..7cacef1 100644
--- a/chrome/browser/views/bookmark_bar_view.cc
+++ b/chrome/browser/views/bookmark_bar_view.cc
@@ -44,7 +44,7 @@
#include "chrome/views/widget.h"
#include "chrome/views/window.h"
#include "generated_resources.h"
-#include "skia/ext/skia_utils_win.h"
+#include "skia/ext/skia_utils.h"
using views::BaseButton;
using views::DropTargetEvent;
diff --git a/chrome/browser/views/bookmark_manager_view.cc b/chrome/browser/views/bookmark_manager_view.cc
index c0c307e..a2071b5 100644
--- a/chrome/browser/views/bookmark_manager_view.cc
+++ b/chrome/browser/views/bookmark_manager_view.cc
@@ -6,7 +6,6 @@
#include <algorithm>
-#include "base/gfx/skia_utils.h"
#include "chrome/app/locales/locale_settings.h"
#include "chrome/browser/bookmarks/bookmark_folder_tree_model.h"
#include "chrome/browser/bookmarks/bookmark_html_writer.h"
@@ -31,6 +30,7 @@
#include "chrome/views/menu_button.h"
#include "chrome/views/single_split_view.h"
#include "chrome/views/window.h"
+#include "skia/ext/skia_utils.h"
#include "generated_resources.h"
diff --git a/chrome/browser/views/sad_tab_view.cc b/chrome/browser/views/sad_tab_view.cc
index 7b34bcb..26d7f5f 100644
--- a/chrome/browser/views/sad_tab_view.cc
+++ b/chrome/browser/views/sad_tab_view.cc
@@ -10,6 +10,7 @@
#include "chrome/common/l10n_util.h"
#include "chrome/common/resource_bundle.h"
#include "generated_resources.h"
+#include "skia/ext/skia_utils.h"
#include "skia/include/SkGradientShader.h"
static const int kSadTabOffset = -64;
@@ -34,20 +35,11 @@ SadTabView::SadTabView() {
InitClass();
}
-static SkShader* CreateGradientShader(int end_point) {
- SkColor grad_colors[2] = { kBackgroundColor, kBackgroundEndColor };
- SkPoint grad_points[2];
- grad_points[0].set(SkIntToScalar(0), SkIntToScalar(0));
- grad_points[1].set(SkIntToScalar(0), SkIntToScalar(end_point));
- return SkGradientShader::CreateLinear(
- grad_points, grad_colors, NULL, 2, SkShader::kRepeat_TileMode);
-}
-
void SadTabView::Paint(ChromeCanvas* canvas) {
- SkShader* background_shader = CreateGradientShader(height());
SkPaint paint;
- paint.setShader(background_shader);
- background_shader->unref();
+ paint.setShader(gfx::CreateGradientShader(0, height(),
+ kBackgroundColor,
+ kBackgroundEndColor))->safeUnref();
paint.setStyle(SkPaint::kFill_Style);
canvas->drawRectCoords(0, 0,
SkIntToScalar(width()), SkIntToScalar(height()),
diff --git a/skia/SConscript b/skia/SConscript
index 5c17f5b..eb1f265 100644
--- a/skia/SConscript
+++ b/skia/SConscript
@@ -82,6 +82,7 @@ input_files = [
'effects/SkUnitMappers.cpp',
'ext/image_operations.cc',
'ext/convolver.cc',
+ 'ext/skia_utils.cc',
'images/SkImageDecoder.cpp',
'images/SkImageRef.cpp',
'images/SkStream.cpp',
diff --git a/skia/ext/skia_utils.cc b/skia/ext/skia_utils.cc
new file mode 100644
index 0000000..b2ea44f
--- /dev/null
+++ b/skia/ext/skia_utils.cc
@@ -0,0 +1,25 @@
+// Copyright (c) 2006-2008 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.
+
+#include "skia/ext/skia_utils.h"
+
+#include "SkGradientShader.h"
+
+namespace gfx {
+
+SkShader* CreateGradientShader(int start_point,
+ int end_point,
+ SkColor start_color,
+ SkColor end_color) {
+ SkColor grad_colors[2] = { start_color, end_color};
+ SkPoint grad_points[2];
+ grad_points[0].set(SkIntToScalar(0), SkIntToScalar(start_point));
+ grad_points[1].set(SkIntToScalar(0), SkIntToScalar(end_point));
+
+ return SkGradientShader::CreateLinear(
+ grad_points, grad_colors, NULL, 2, SkShader::kRepeat_TileMode);
+}
+
+} // namespace gfx
+
diff --git a/skia/ext/skia_utils.h b/skia/ext/skia_utils.h
new file mode 100644
index 0000000..d2ed5db
--- /dev/null
+++ b/skia/ext/skia_utils.h
@@ -0,0 +1,27 @@
+// Copyright (c) 2006-2008 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 BASE_GFX_SKIA_UTILS_H_
+#define BASE_GFX_SKIA_UTILS_H_
+
+#include "SkColor.h"
+#include "SkShader.h"
+
+namespace gfx {
+
+// Creates a vertical gradient shader. The caller owns the shader.
+// Example usage to avoid leaks:
+// paint.setShader(gfx::CreateGradientShader(0, 10, red, blue))->safeUnref();
+//
+// (The old shader in the paint, if any, needs to be freed, and safeUnref will
+// handle the NULL case.)
+SkShader* CreateGradientShader(int start_point,
+ int end_point,
+ SkColor start_color,
+ SkColor end_color);
+
+} // namespace gfx
+
+#endif // SKIA_EXT_SKIA_UTILS_H_
+
diff --git a/skia/ext/skia_utils_win.cc b/skia/ext/skia_utils_win.cc
index dcac26f..05f0692 100644
--- a/skia/ext/skia_utils_win.cc
+++ b/skia/ext/skia_utils_win.cc
@@ -35,20 +35,6 @@ SkRect RECTToSkRect(const RECT& rect) {
return sk_rect;
}
-SkShader* CreateGradientShader(int start_point,
- int end_point,
- SkColor start_color,
- SkColor end_color) {
- SkColor grad_colors[2] = { start_color, end_color};
- SkPoint grad_points[2];
- grad_points[0].set(SkIntToScalar(0), SkIntToScalar(start_point));
- grad_points[1].set(SkIntToScalar(0), SkIntToScalar(end_point));
-
- return SkGradientShader::CreateLinear(
- grad_points, grad_colors, NULL, 2, SkShader::kRepeat_TileMode);
-}
-
-
SkColor COLORREFToSkColor(COLORREF color) {
#ifndef _MSC_VER
return SkColorSetRGB(GetRValue(color), GetGValue(color), GetBValue(color));
diff --git a/skia/ext/skia_utils_win.h b/skia/ext/skia_utils_win.h
index 4ad7910..fa94507 100644
--- a/skia/ext/skia_utils_win.h
+++ b/skia/ext/skia_utils_win.h
@@ -6,7 +6,6 @@
#define BASE_GFX_SKIA_UTILS_WIN_H_
#include "SkColor.h"
-#include "SkShader.h"
struct SkIRect;
struct SkPoint;
@@ -38,12 +37,6 @@ inline const RECT& SkIRectToRECT(const SkIRect& rect) {
return reinterpret_cast<const RECT&>(rect);
}
-// Creates a vertical gradient shader. The caller owns the shader.
-SkShader* CreateGradientShader(int start_point,
- int end_point,
- SkColor start_color,
- SkColor end_color);
-
// Converts COLORREFs (0BGR) to the ARGB layout Skia expects.
SkColor COLORREFToSkColor(COLORREF color);
diff --git a/skia/skia.vcproj b/skia/skia.vcproj
index b44b455..bd4c7c3 100644
--- a/skia/skia.vcproj
+++ b/skia/skia.vcproj
@@ -1361,6 +1361,14 @@
>
</File>
<File
+ RelativePath=".\ext\skia_utils.cc"
+ >
+ </File>
+ <File
+ RelativePath=".\ext\skia_utils.h"
+ >
+ </File>
+ <File
RelativePath=".\ext\skia_utils_win.cc"
>
</File>