问题描述
我的应用程序中有一个UIScrollView,我在其他一些应用程序中看到,当用户滚动时,顶部会在滚动时淡出而不是仅仅消失。
I've got a UIScrollView in my app and I have seen in some other apps that when the user scrolls, the top section fades out on scroll rather than just dissapearing out.
我真的很喜欢这种效果并希望实现它。有什么想法可以做到吗?
I really love this effect and want to achieve it. Any ideas how it can be done?
推荐答案
编辑:我已经把这段代码放了github,请参阅。
I've put this code up on github, see here.
请参阅以查找类似问题。
See my answer to a similar question.
我的解决方案是子类 UIScrollView
,并在 layoutSubviews
方法中创建一个遮罩层。 / p>
My solution is to subclass UIScrollView
, and create a mask layer in the layoutSubviews
method.
#import "FadingScrollView.h"
#import <QuartzCore/QuartzCore.h>
static float const fadePercentage = 0.2;
@implementation FadingScrollView
// ...
- (void)layoutSubviews
{
[super layoutSubviews];
NSObject * transparent = (NSObject *) [[UIColor colorWithWhite:0 alpha:0] CGColor];
NSObject * opaque = (NSObject *) [[UIColor colorWithWhite:0 alpha:1] CGColor];
CALayer * maskLayer = [CALayer layer];
maskLayer.frame = self.bounds;
CAGradientLayer * gradientLayer = [CAGradientLayer layer];
gradientLayer.frame = CGRectMake(self.bounds.origin.x, 0,
self.bounds.size.width, self.bounds.size.height);
gradientLayer.colors = [NSArray arrayWithObjects: transparent, opaque,
opaque, transparent, nil];
// Set percentage of scrollview that fades at top & bottom
gradientLayer.locations = [NSArray arrayWithObjects:
[NSNumber numberWithFloat:0],
[NSNumber numberWithFloat:fadePercentage],
[NSNumber numberWithFloat:1.0 - fadePercentage],
[NSNumber numberWithFloat:1], nil];
[maskLayer addSublayer:gradientLayer];
self.layer.mask = maskLayer;
}
@end
以上代码淡出顶部 UIScrollView
的底部从背景颜色变为透明,但这可以轻松更改为仅淡化顶部(或淡化为您想要的任何颜色)。
The code above fades the top and bottom of the UIScrollView
from the background colour to transparent, but this can be easily changed to fade the top only (or fade to any colour you want).
将此行更改为仅淡入顶部:
Change this line to fade the top only:
// Fade top of scrollview only
gradientLayer.locations = [NSArray arrayWithObjects:
[NSNumber numberWithFloat:0],
[NSNumber numberWithFloat:fadePercentage],
[NSNumber numberWithFloat:1],
[NSNumber numberWithFloat:1], nil];
编辑2:
或者只改变这两行来淡化顶部:
Or fade the top only by changing these two lines:
// Fade top of scrollview only
gradientLayer.colors = [NSArray arrayWithObjects: transparent, opaque, nil];
gradientLayer.locations = [NSArray arrayWithObjects: [NSNumber numberWithFloat:0],
[NSNumber numberWithFloat:fadePercentage], nil];
或者,仅淡出底部:
// Fade bottom of scrollview only
gradientLayer.colors = [NSArray arrayWithObjects: opaque, transparent, nil];
gradientLayer.locations = [NSArray arrayWithObjects: [NSNumber numberWithFloat:1.0 - fadePercentage],
[NSNumber numberWithFloat:1], nil];
这篇关于如何使用UIScrollView创建顶级淡入淡出效果?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!