Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(66)

Unified Diff: Source/WebCore/platform/chromium/ScrollbarOverlayUtilitiesChromiumMac.mm

Issue 7134051: Merge 88396 - 2011-06-08 Sailesh Agrawal <sail@chromium.org> (Closed) Base URL: http://svn.webkit.org/repository/webkit/branches/chromium/782/
Patch Set: Created 9 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: Source/WebCore/platform/chromium/ScrollbarOverlayUtilitiesChromiumMac.mm
===================================================================
--- Source/WebCore/platform/chromium/ScrollbarOverlayUtilitiesChromiumMac.mm (revision 88459)
+++ Source/WebCore/platform/chromium/ScrollbarOverlayUtilitiesChromiumMac.mm (working copy)
@@ -60,6 +60,7 @@
@property CGFloat knobAlpha;
@property CGFloat trackAlpha;
@property CGFloat knobProportion;
+@property NSInteger knobStyle;
@property(getter=isEnabled) BOOL enabled;
@property(getter=isHorizontal) BOOL horizontal;
@property double doubleValue;
@@ -75,6 +76,7 @@
- (void)setOverlayScrollerState:(NSScrollerStyle)state
forceImmediately:(BOOL)flag;
- (void)setDelegate:(id)delegate;
+- (NSRect)rectForPart:(NSUInteger)arg1;
@end
@@ -122,6 +124,11 @@
static NSScrollerStyle preferredScrollerStyle()
{
+ // TODO(sail): Disable overlay scrollbars for now until the following issues are fixed:
+ // #1: Invalidation issues causes the scrollbar to leave trailing artifacts.
+ // #2: Find tick marks need to be drawn on the scrollbar track.
+ return NSScrollerStyleLegacy;
+
if ([NSScroller respondsToSelector:@selector(preferredScrollerStyle)])
return [NSScroller preferredScrollerStyle];
return NSScrollerStyleLegacy;
@@ -159,6 +166,7 @@
frameRect.size.height = [painter trackWidth];
else
frameRect.size.width = [painter trackWidth];
+ frameRect.origin = NSZeroPoint;
[painter drawKnobSlotInRect:frameRect highlight:NO];
[painter drawKnob];
@@ -230,7 +238,7 @@
CGRect wkScrollbarPainterKnobRect(WKScrollbarPainterRef painter)
{
- return NSRectToCGRect(NSZeroRect);
+ return NSRectToCGRect([painter rectForPart:NSScrollerKnob]);
}
void wkSetScrollbarPainterKnobAlpha(WKScrollbarPainterRef painter, CGFloat alpha)
@@ -245,7 +253,7 @@
void wkSetScrollbarPainterKnobStyle(WKScrollbarPainterRef painter, wkScrollerKnobStyle style)
{
- // TODO(sail): A knob style API doesn't exist in the seeds currently available.
+ [painter setKnobStyle:style];
}
WKScrollbarPainterControllerRef wkMakeScrollbarPainterController(id painterControllerDelegate)
@@ -325,13 +333,6 @@
bool isScrollbarOverlayAPIAvailable()
{
- // TODO(sail): Disable overlay scrollbars for now until the following issues are fixed:
- // #1: Invalidation issues causes the scrollbar to leave trailing artifacts.
- // #2: Various messages such as live resize started/ended need to be piped from the UI.
- // #3: Find tick marks need to be drawn on the scrollbar track.
- // #4: Need to have the theme engine draw the thumb.
- return false;
-
static bool apiAvailable = [lookUpNSScrollerImpClass() respondsToSelector:@selector(scrollerImpWithStyle:controlSize:horizontal:replacingScrollerImp:)] &&
[lookUpNSScrollerImpPairClass() instancesRespondToSelector:@selector(scrollerStyle)];
return apiAvailable;

Powered by Google App Engine
This is Rietveld 408576698