OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2010, 2011 Apple Inc. All rights reserved. | 2 * Copyright (C) 2010, 2011 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 21 matching lines...) Expand all Loading... |
32 #include "platform/geometry/FloatRect.h" | 32 #include "platform/geometry/FloatRect.h" |
33 #include "platform/geometry/IntRect.h" | 33 #include "platform/geometry/IntRect.h" |
34 #include "platform/mac/BlockExceptions.h" | 34 #include "platform/mac/BlockExceptions.h" |
35 #include "platform/mac/NSScrollerImpDetails.h" | 35 #include "platform/mac/NSScrollerImpDetails.h" |
36 #include "platform/scroll/ScrollableArea.h" | 36 #include "platform/scroll/ScrollableArea.h" |
37 #include "platform/scroll/ScrollbarTheme.h" | 37 #include "platform/scroll/ScrollbarTheme.h" |
38 #include "platform/scroll/ScrollbarThemeMac.h" | 38 #include "platform/scroll/ScrollbarThemeMac.h" |
39 #include "public/platform/Platform.h" | 39 #include "public/platform/Platform.h" |
40 #include "public/platform/WebScheduler.h" | 40 #include "public/platform/WebScheduler.h" |
41 #include "wtf/MathExtras.h" | 41 #include "wtf/MathExtras.h" |
42 #include "wtf/PassOwnPtr.h" | 42 #include "wtf/PtrUtil.h" |
| 43 #include <memory> |
43 | 44 |
44 using namespace blink; | 45 using namespace blink; |
45 | 46 |
46 static bool supportsUIStateTransitionProgress() | 47 static bool supportsUIStateTransitionProgress() |
47 { | 48 { |
48 // FIXME: This is temporary until all platforms that support ScrollbarPainte
r support this part of the API. | 49 // FIXME: This is temporary until all platforms that support ScrollbarPainte
r support this part of the API. |
49 static bool globalSupportsUIStateTransitionProgress = [NSClassFromString(@"N
SScrollerImp") instancesRespondToSelector:@selector(mouseEnteredScroller)]; | 50 static bool globalSupportsUIStateTransitionProgress = [NSClassFromString(@"N
SScrollerImp") instancesRespondToSelector:@selector(mouseEnteredScroller)]; |
50 return globalSupportsUIStateTransitionProgress; | 51 return globalSupportsUIStateTransitionProgress; |
51 } | 52 } |
52 | 53 |
(...skipping 294 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
347 double m_startTime; // In seconds. | 348 double m_startTime; // In seconds. |
348 double m_duration; // In seconds. | 349 double m_duration; // In seconds. |
349 BlinkScrollbarPartAnimation* m_animation; // Weak, owns this. | 350 BlinkScrollbarPartAnimation* m_animation; // Weak, owns this. |
350 RefPtr<CubicBezierTimingFunction> m_timingFunction; | 351 RefPtr<CubicBezierTimingFunction> m_timingFunction; |
351 }; | 352 }; |
352 | 353 |
353 } // namespace blink | 354 } // namespace blink |
354 | 355 |
355 @interface BlinkScrollbarPartAnimation : NSObject { | 356 @interface BlinkScrollbarPartAnimation : NSObject { |
356 Scrollbar* _scrollbar; | 357 Scrollbar* _scrollbar; |
357 OwnPtr<BlinkScrollbarPartAnimationTimer> _timer; | 358 std::unique_ptr<BlinkScrollbarPartAnimationTimer> _timer; |
358 RetainPtr<ScrollbarPainter> _scrollbarPainter; | 359 RetainPtr<ScrollbarPainter> _scrollbarPainter; |
359 FeatureToAnimate _featureToAnimate; | 360 FeatureToAnimate _featureToAnimate; |
360 CGFloat _startValue; | 361 CGFloat _startValue; |
361 CGFloat _endValue; | 362 CGFloat _endValue; |
362 } | 363 } |
363 - (id)initWithScrollbar:(Scrollbar*)scrollbar featureToAnimate:(FeatureToAnimate
)featureToAnimate animateFrom:(CGFloat)startValue animateTo:(CGFloat)endValue du
ration:(NSTimeInterval)duration; | 364 - (id)initWithScrollbar:(Scrollbar*)scrollbar featureToAnimate:(FeatureToAnimate
)featureToAnimate animateFrom:(CGFloat)startValue animateTo:(CGFloat)endValue du
ration:(NSTimeInterval)duration; |
364 @end | 365 @end |
365 | 366 |
366 @implementation BlinkScrollbarPartAnimation | 367 @implementation BlinkScrollbarPartAnimation |
367 | 368 |
368 - (id)initWithScrollbar:(Scrollbar*)scrollbar featureToAnimate:(FeatureToAnimate
)featureToAnimate animateFrom:(CGFloat)startValue animateTo:(CGFloat)endValue du
ration:(NSTimeInterval)duration | 369 - (id)initWithScrollbar:(Scrollbar*)scrollbar featureToAnimate:(FeatureToAnimate
)featureToAnimate animateFrom:(CGFloat)startValue animateTo:(CGFloat)endValue du
ration:(NSTimeInterval)duration |
369 { | 370 { |
370 self = [super init]; | 371 self = [super init]; |
371 if (!self) | 372 if (!self) |
372 return nil; | 373 return nil; |
373 | 374 |
374 _timer = adoptPtr(new BlinkScrollbarPartAnimationTimer(self, duration)); | 375 _timer = wrapUnique(new BlinkScrollbarPartAnimationTimer(self, duration)); |
375 _scrollbar = scrollbar; | 376 _scrollbar = scrollbar; |
376 _featureToAnimate = featureToAnimate; | 377 _featureToAnimate = featureToAnimate; |
377 _startValue = startValue; | 378 _startValue = startValue; |
378 _endValue = endValue; | 379 _endValue = endValue; |
379 | 380 |
380 return self; | 381 return self; |
381 } | 382 } |
382 | 383 |
383 - (void)startAnimation | 384 - (void)startAnimation |
384 { | 385 { |
(...skipping 290 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
675 | 676 |
676 ScrollAnimatorBase* ScrollAnimatorBase::create(ScrollableArea* scrollableArea) | 677 ScrollAnimatorBase* ScrollAnimatorBase::create(ScrollableArea* scrollableArea) |
677 { | 678 { |
678 return new ScrollAnimatorMac(scrollableArea); | 679 return new ScrollAnimatorMac(scrollableArea); |
679 } | 680 } |
680 | 681 |
681 ScrollAnimatorMac::ScrollAnimatorMac(ScrollableArea* scrollableArea) | 682 ScrollAnimatorMac::ScrollAnimatorMac(ScrollableArea* scrollableArea) |
682 : ScrollAnimatorBase(scrollableArea) | 683 : ScrollAnimatorBase(scrollableArea) |
683 , m_initialScrollbarPaintTaskFactory(CancellableTaskFactory::create(this, &S
crollAnimatorMac::initialScrollbarPaintTask)) | 684 , m_initialScrollbarPaintTaskFactory(CancellableTaskFactory::create(this, &S
crollAnimatorMac::initialScrollbarPaintTask)) |
684 , m_sendContentAreaScrolledTaskFactory(CancellableTaskFactory::create(this,
&ScrollAnimatorMac::sendContentAreaScrolledTask)) | 685 , m_sendContentAreaScrolledTaskFactory(CancellableTaskFactory::create(this,
&ScrollAnimatorMac::sendContentAreaScrolledTask)) |
685 , m_taskRunner(adoptPtr(Platform::current()->currentThread()->scheduler()->t
imerTaskRunner()->clone())) | 686 , m_taskRunner(wrapUnique(Platform::current()->currentThread()->scheduler()-
>timerTaskRunner()->clone())) |
686 , m_haveScrolledSincePageLoad(false) | 687 , m_haveScrolledSincePageLoad(false) |
687 , m_needsScrollerStyleUpdate(false) | 688 , m_needsScrollerStyleUpdate(false) |
688 { | 689 { |
689 ThreadState::current()->registerPreFinalizer(this); | 690 ThreadState::current()->registerPreFinalizer(this); |
690 | 691 |
691 m_scrollAnimationHelperDelegate.adoptNS([[BlinkScrollAnimationHelperDelegate
alloc] initWithScrollAnimator:this]); | 692 m_scrollAnimationHelperDelegate.adoptNS([[BlinkScrollAnimationHelperDelegate
alloc] initWithScrollAnimator:this]); |
692 m_scrollAnimationHelper.adoptNS([[NSClassFromString(@"NSScrollAnimationHelpe
r") alloc] initWithDelegate:m_scrollAnimationHelperDelegate.get()]); | 693 m_scrollAnimationHelper.adoptNS([[NSClassFromString(@"NSScrollAnimationHelpe
r") alloc] initWithDelegate:m_scrollAnimationHelperDelegate.get()]); |
693 | 694 |
694 m_scrollbarPainterControllerDelegate.adoptNS([[BlinkScrollbarPainterControll
erDelegate alloc] initWithScrollableArea:scrollableArea]); | 695 m_scrollbarPainterControllerDelegate.adoptNS([[BlinkScrollbarPainterControll
erDelegate alloc] initWithScrollableArea:scrollableArea]); |
695 m_scrollbarPainterController = [[[NSClassFromString(@"NSScrollerImpPair") al
loc] init] autorelease]; | 696 m_scrollbarPainterController = [[[NSClassFromString(@"NSScrollerImpPair") al
loc] init] autorelease]; |
(...skipping 404 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1100 if (Scrollbar* verticalScrollbar = m_scrollableArea->verticalScrollbar()) | 1101 if (Scrollbar* verticalScrollbar = m_scrollableArea->verticalScrollbar()) |
1101 rectInViewCoordinates = verticalScrollbar->convertToContainingWidget(scr
ollerThumb); | 1102 rectInViewCoordinates = verticalScrollbar->convertToContainingWidget(scr
ollerThumb); |
1102 | 1103 |
1103 if (rectInViewCoordinates == m_visibleScrollerThumbRect) | 1104 if (rectInViewCoordinates == m_visibleScrollerThumbRect) |
1104 return; | 1105 return; |
1105 | 1106 |
1106 m_visibleScrollerThumbRect = rectInViewCoordinates; | 1107 m_visibleScrollerThumbRect = rectInViewCoordinates; |
1107 } | 1108 } |
1108 | 1109 |
1109 } // namespace blink | 1110 } // namespace blink |
OLD | NEW |