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

一、需求分析

 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)));
        }
    }
}

三、实现效果

  (可左右循环滚动)

  

四、代码

  http://pan.baidu.com/s/1sjqJsK1 提取码:xvfl

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值