diff options
author | brettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-12-03 21:28:33 +0000 |
---|---|---|
committer | brettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-12-03 21:28:33 +0000 |
commit | 05b7f994c66470750905eabb12acf1643099f9b7 (patch) | |
tree | d9411a629dfb1e8dc4885374d5f788bcff47ea86 | |
parent | 9ed68c36cad4f5d70a378be96d303710053eed65 (diff) | |
download | chromium_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.cc | 2 | ||||
-rw-r--r-- | chrome/browser/views/bookmark_manager_view.cc | 2 | ||||
-rw-r--r-- | chrome/browser/views/sad_tab_view.cc | 16 | ||||
-rw-r--r-- | skia/SConscript | 1 | ||||
-rw-r--r-- | skia/ext/skia_utils.cc | 25 | ||||
-rw-r--r-- | skia/ext/skia_utils.h | 27 | ||||
-rw-r--r-- | skia/ext/skia_utils_win.cc | 14 | ||||
-rw-r--r-- | skia/ext/skia_utils_win.h | 7 | ||||
-rw-r--r-- | skia/skia.vcproj | 8 |
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> |