码迷,mamicode.com
首页 > 移动开发 > 详细

IOS 类似于网易新闻首页新闻轮播的组件

时间:2014-12-24 14:37:32      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:

一、需求分析

 1、可横向循环滚动新闻图片

 2、滚动到对应图片时显示新闻标题 

 3、每张新闻图片可点击

 4、有pageControl提示

 5、具有控件的扩展能力

 

二、设计实现

 1、显示图片使用SDWebImage第三方库,可缓存图片、通过url异步加载图片

 2、使用一个横向滚动的UITableView实现循环滚动

 3、使用一个黑色半透明的背景、白色文字的UILabel显示标题

 4、定义每个新闻的数据结构:

   

/** @brief 默认使用本地地址,如果本地没有的话,使用网络图片 */

@interface PhotoNewsModel : NSObject

/** @brief 加载时展示的图片*/
@property (nonatomic, strong) UIImage *loadingImage;

/** @brief 图片本地的地址 */
@property (nonatomic, strong) NSString *localPath;

/** @brief 新闻图片的地址 */
@property (nonatomic, strong) NSString *photoUrl;

/** @brief 新闻标题 */
@property (nonatomic, strong) NSString *title;


@end

5、代理协议:

@protocol UIPhotoNewsViewDelegate <NSObject>

/**
 *  取得多少条图片新闻
 *
 *  @param photoNews 控件自身
 *
 *  @return 图片新闻的个数
 */
- (NSUInteger)photoNewsCount:(UIPhotoNewsView *)photoNews;



/**
 *  返回第几个图片新闻的model
 *
 *  @param photoNews 控件自身
 *  @param index
 *
 *  @return 返回描述图片新闻的model
 */
- (PhotoNewsModel *)photoNews:(UIPhotoNewsView *)photoNews
            photoModelAtIndex:(NSUInteger)index;



/**
 *  图片新闻点击的回调
 *
 *  @param photoNews 控件自身
 *  @param model     点击新闻对应的model
 */
- (void)photoNews:(UIPhotoNewsView *)photoNews
    photoDidClick:(PhotoNewsModel *)model;




@end

6、循环滚动如何实现

  a)将要展示的数据复制一份相当于 1、2、3、4|1、2、3、4

  b)数据初始化时,定位到第二份的1这里

  c)滚动到前面的1或者2时,设置跳转到第二份的1和2

  d)关键代码:

- (void)makeCycleScroll
{
    if(self.realCount >= 2)
    {
        CGFloat currentOffsetX = self.contentTableView.contentOffset.x;
        CGFloat currentOffSetY = self.contentTableView.contentOffset.y;
        CGFloat contentHeight  = self.contentTableView.contentSize.height;
        
        if (currentOffSetY < (contentHeight / 8.0)) {
            self.contentTableView.contentOffset = CGPointMake(currentOffsetX,(currentOffSetY + (contentHeight/2)));
        }
        if (currentOffSetY >= ((contentHeight * 6)/ 8.0)) {
            self.contentTableView.contentOffset = CGPointMake(currentOffsetX,(currentOffSetY - (contentHeight/2)));
        }
    }
}

  

 

三、实现效果

  (可左右循环滚动)

  技术分享

 

四、代码

  发邮件到:480071411@qq.com

 

IOS 类似于网易新闻首页新闻轮播的组件

标签:

原文地址:http://www.cnblogs.com/doudouyoutang/p/4182353.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!