Index: Source/core/platform/chromium/PlatformThemeChromiumDefault.cpp |
diff --git a/Source/core/platform/chromium/PlatformThemeChromiumDefault.cpp b/Source/core/platform/chromium/PlatformThemeChromiumDefault.cpp |
deleted file mode 100644 |
index f257da14b097668cf44bb605a8539b8d26d89f5d..0000000000000000000000000000000000000000 |
--- a/Source/core/platform/chromium/PlatformThemeChromiumDefault.cpp |
+++ /dev/null |
@@ -1,221 +0,0 @@ |
-/* |
- * Copyright (C) 2011 Google Inc. All rights reserved. |
- * |
- * Redistribution and use in source and binary forms, with or without |
- * modification, are permitted provided that the following conditions are |
- * met: |
- * |
- * * Redistributions of source code must retain the above copyright |
- * notice, this list of conditions and the following disclaimer. |
- * * Redistributions in binary form must reproduce the above |
- * copyright notice, this list of conditions and the following disclaimer |
- * in the documentation and/or other materials provided with the |
- * distribution. |
- * * Neither the name of Google Inc. nor the names of its |
- * contributors may be used to endorse or promote products derived from |
- * this software without specific prior written permission. |
- * |
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
- */ |
- |
-#include "config.h" |
-#include "core/platform/chromium/PlatformThemeChromiumDefault.h" |
- |
-namespace WebCore { |
- |
-unsigned PlatformThemeChromiumDefault::s_thumbInactiveColor = 0xeaeaea; |
-unsigned PlatformThemeChromiumDefault::s_thumbActiveColor = 0xf4f4f4; |
-unsigned PlatformThemeChromiumDefault::s_trackColor = 0xd3d3d3; |
- |
-void PlatformThemeChromiumDefault::setScrollbarColors( |
- SkColor inactiveColor, SkColor activeColor, SkColor trackColor) |
-{ |
- s_thumbInactiveColor = inactiveColor; |
- s_thumbActiveColor = activeColor; |
- s_trackColor = trackColor; |
-} |
- |
-static SkScalar clamp(SkScalar value, SkScalar min, SkScalar max) |
-{ |
- return std::min(std::max(value, min), max); |
-} |
- |
-SkColor PlatformThemeChromiumDefault::saturateAndBrighten(const SkScalar hsv[3], SkScalar saturateAmount, SkScalar brightenAmount) |
-{ |
- SkScalar color[3]; |
- color[0] = hsv[0]; |
- color[1] = clamp(hsv[1] + saturateAmount, 0.0, 1.0); |
- color[2] = clamp(hsv[2] + brightenAmount, 0.0, 1.0); |
- return SkHSVToColor(color); |
-} |
- |
-SkColor PlatformThemeChromiumDefault::outlineColor(const SkScalar hsv1[3], const SkScalar hsv2[3]) |
-{ |
- // GTK Theme engines have way too much control over the layout of |
- // the scrollbar. We might be able to more closely approximate its |
- // look-and-feel, if we sent whole images instead of just colors |
- // from the browser to the renderer. But even then, some themes |
- // would just break. |
- // |
- // So, instead, we don't even try to 100% replicate the look of |
- // the native scrollbar. We render our own version, but we make |
- // sure to pick colors that blend in nicely with the system GTK |
- // theme. In most cases, we can just sample a couple of pixels |
- // from the system scrollbar and use those colors to draw our |
- // scrollbar. |
- // |
- // This works fine for the track color and the overall thumb |
- // color. But it fails spectacularly for the outline color used |
- // around the thumb piece. Not all themes have a clearly defined |
- // outline. For some of them it is partially transparent, and for |
- // others the thickness is very unpredictable. |
- // |
- // So, instead of trying to approximate the system theme, we |
- // instead try to compute a reasonable looking choice based on the |
- // known color of the track and the thumb piece. This is difficult |
- // when trying to deal both with high- and low-contrast themes, |
- // and both with positive and inverted themes. |
- // |
- // The following code has been tested to look OK with all of the |
- // default GTK themes. |
- SkScalar minDiff = clamp((hsv1[1] + hsv2[1]) * 1.2, 0.28, 0.5); |
- SkScalar diff = clamp(fabs(hsv1[2] - hsv2[2]) / 2, minDiff, 0.5); |
- |
- if (hsv1[2] + hsv2[2] > 1.0) |
- diff = -diff; |
- |
- return saturateAndBrighten(hsv2, -0.2, diff); |
-} |
- |
-void PlatformThemeChromiumDefault::paintArrowButton(GraphicsContext* gc, const IntRect& rect, ArrowDirection direction, ControlStates states) |
-{ |
- SkCanvas* const canvas = gc->canvas(); |
- int widthMiddle, lengthMiddle; |
- SkPaint paint; |
- if (direction == North || direction == South) { |
- widthMiddle = rect.width() / 2 + 1; |
- lengthMiddle = rect.height() / 2 + 1; |
- } else { |
- lengthMiddle = rect.width() / 2 + 1; |
- widthMiddle = rect.height() / 2 + 1; |
- } |
- |
- // Calculate button color. |
- SkScalar trackHSV[3]; |
- SkColorToHSV(trackColor(), trackHSV); |
- SkColor buttonColor = saturateAndBrighten(trackHSV, 0, 0.2); |
- SkColor backgroundColor = buttonColor; |
- if (states & PressedState) { |
- SkScalar buttonHSV[3]; |
- SkColorToHSV(buttonColor, buttonHSV); |
- buttonColor = saturateAndBrighten(buttonHSV, 0, -0.1); |
- } else if (states & HoverState) { |
- SkScalar buttonHSV[3]; |
- SkColorToHSV(buttonColor, buttonHSV); |
- buttonColor = saturateAndBrighten(buttonHSV, 0, 0.05); |
- } |
- |
- SkIRect skrect; |
- skrect.set(rect.x(), rect.y(), rect.x() + rect.width(), rect.y() + rect.height()); |
- // Paint the background (the area visible behind the rounded corners). |
- paint.setColor(backgroundColor); |
- canvas->drawIRect(skrect, paint); |
- |
- // Paint the button's outline and fill the middle |
- SkPath outline; |
- switch (direction) { |
- case North: |
- outline.moveTo(rect.x() + 0.5, rect.y() + rect.height() + 0.5); |
- outline.rLineTo(0, -(rect.height() - 2)); |
- outline.rLineTo(2, -2); |
- outline.rLineTo(rect.width() - 5, 0); |
- outline.rLineTo(2, 2); |
- outline.rLineTo(0, rect.height() - 2); |
- break; |
- case South: |
- outline.moveTo(rect.x() + 0.5, rect.y() - 0.5); |
- outline.rLineTo(0, rect.height() - 2); |
- outline.rLineTo(2, 2); |
- outline.rLineTo(rect.width() - 5, 0); |
- outline.rLineTo(2, -2); |
- outline.rLineTo(0, -(rect.height() - 2)); |
- break; |
- case East: |
- outline.moveTo(rect.x() - 0.5, rect.y() + 0.5); |
- outline.rLineTo(rect.width() - 2, 0); |
- outline.rLineTo(2, 2); |
- outline.rLineTo(0, rect.height() - 5); |
- outline.rLineTo(-2, 2); |
- outline.rLineTo(-(rect.width() - 2), 0); |
- break; |
- case West: |
- outline.moveTo(rect.x() + rect.width() + 0.5, rect.y() + 0.5); |
- outline.rLineTo(-(rect.width() - 2), 0); |
- outline.rLineTo(-2, 2); |
- outline.rLineTo(0, rect.height() - 5); |
- outline.rLineTo(2, 2); |
- outline.rLineTo(rect.width() - 2, 0); |
- break; |
- } |
- outline.close(); |
- |
- paint.setStyle(SkPaint::kFill_Style); |
- paint.setColor(buttonColor); |
- canvas->drawPath(outline, paint); |
- |
- paint.setAntiAlias(true); |
- paint.setStyle(SkPaint::kStroke_Style); |
- SkScalar thumbHSV[3]; |
- SkColorToHSV(thumbInactiveColor(), thumbHSV); |
- paint.setColor(outlineColor(trackHSV, thumbHSV)); |
- canvas->drawPath(outline, paint); |
- |
- // If the button is disabled or read-only, the arrow is drawn with the outline color. |
- if (states & EnabledState && !(states & ReadOnlyState)) |
- paint.setColor(SK_ColorBLACK); |
- |
- paint.setAntiAlias(false); |
- paint.setStyle(SkPaint::kFill_Style); |
- |
- SkPath path; |
- // The constants in this block of code are hand-tailored to produce good |
- // looking arrows without anti-aliasing. |
- switch (direction) { |
- case North: |
- path.moveTo(rect.x() + widthMiddle - 4, rect.y() + lengthMiddle + 2); |
- path.rLineTo(7, 0); |
- path.rLineTo(-4, -4); |
- break; |
- case South: |
- path.moveTo(rect.x() + widthMiddle - 4, rect.y() + lengthMiddle - 3); |
- path.rLineTo(7, 0); |
- path.rLineTo(-4, 4); |
- break; |
- case East: |
- path.moveTo(rect.x() + lengthMiddle - 3, rect.y() + widthMiddle - 4); |
- path.rLineTo(0, 7); |
- path.rLineTo(4, -4); |
- break; |
- case West: |
- path.moveTo(rect.x() + lengthMiddle + 1, rect.y() + widthMiddle - 5); |
- path.rLineTo(0, 9); |
- path.rLineTo(-4, -4); |
- break; |
- } |
- path.close(); |
- |
- canvas->drawPath(path, paint); |
-} |
- |
-} // namespace WebCore |
- |