iOS动画相关iOS学习牛叉的demo

iOS 实现凤凰新闻的视觉差轮播图

2016-11-16  本文已影响309人  sdupidBoby

手机里下载了很多新闻类的App,当然作为一个码农就算看新闻也会从技术的角度去思考一些内容的实现过程,这也能帮你发现很多trick ,于是就有了本文

凤凰banner.gif

通过Reveal不难发现:

1.  banner结构就是常用的scrollview +  3个ContainerView的重用
2.  视觉差的效果并不是用ContainerView来实现,ContainerView只作用为重用的父视图
3.  动画大概是在ContainerView上的SubView(SetImage) 相对于 ScrollView的contentOffset来完成的
rea.png
hierarchy

scrollView重用代码

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{

    div_t x = div(scrollView.contentOffset.x,scrollView.frame.size.width);

    if (x.quot == 0) {
        self.currentIndex -=1;
    }else if(x.quot == 2){
        self.currentIndex +=1;
    }
    
    [self setContainerImageViews];
    self.scrollView.contentOffset = CGPointMake(CGRectGetWidth(scrollView.bounds), 0);
    
    [self resumeTimer];
}

视差动画代码

//参数是scrollView的contentOffset.y
- (void)setOffsetWithFactor:(float)value{
    CGRect  selfToWindow = [self convertRect:self.bounds toView:self.window]; //当前View的frame
    CGFloat selfCenterX = CGRectGetMidX(selfToWindow); //当前View的centerX
    CGPoint windowCenter = self.window.center;
    CGFloat selfOffsetX = selfCenterX - windowCenter.x; //偏移距离
    
    CGAffineTransform transX = CGAffineTransformMakeTranslation(- selfOffsetX * value, 0);
    self.contentIMG.transform = transX;
}

demo地址,欢迎star

YYBanner.gif
上一篇 下一篇

猜你喜欢

热点阅读