轮播图片——APP顶上头条
来源:互联网 发布:陕西师范网络教育 编辑:程序博客网 时间:2024/04/28 20:45
#import "ViewController.h"
#define imageCount 5
@interface ViewController ()<UIScrollViewDelegate>
@property (nonatomic,strong)UIScrollView *scrollView;
@property (nonatomic,strong)UIPageControl *pageControl;
@property (nonatomic,strong)NSTimer *timer;
@end
@implementation ViewController
-(UIScrollView *)scrollView
{
if (_scrollView ==nil) {
_scrollView = [[UIScrollViewalloc]initWithFrame:CGRectMake(10,20, 300, 130)];
_scrollView.backgroundColor = [UIColorredColor];
[self.viewaddSubview:_scrollView];
// 要分页
_scrollView.pagingEnabled =YES;
// contentSize 在_scrollView设置可以滚动的局域
_scrollView.contentSize =CGSizeMake(imageCount *_scrollView.bounds.size.width,0);
// 设置代理
_scrollView.delegate =self;
}
return_scrollView;
}
-(UIPageControl *)pageControl
{
if (_pageControl ==nil) {
//分页控件,本质上和scrollView没有任何关系,是两个独立的控件
_pageControl = [[UIPageControlalloc] init];
// 总页数
_pageControl.numberOfPages =imageCount;
// 控件尺寸
//CGSize size = [_pageControl sizeForNumberOfPages:imageCount];
// _pageControl.bounds = CGRectMake(0, 0, size.width, size.height);
_pageControl.center =CGPointMake(self.view.center.x,130);
// 设置颜色
_pageControl.pageIndicatorTintColor = [UIColorredColor];
_pageControl.currentPageIndicatorTintColor = [UIColorblueColor];
[self.viewaddSubview:_pageControl];
// 添加监听方法
/** 在OC中,绝大多数"控件",都可以监听UIControlEventValueChanged事件,button除外" */
[_pageControladdTarget:selfaction:@selector(pagechanged:)forControlEvents:UIControlEventValueChanged];
}
return_pageControl;
}
// 分页控件的监听方法
-(void)pagechanged:(UIPageControl *)page
{
// 根据页数,调整滚动视图中的图片位置 contentOffset
CGFloat x = page.currentPage *self.scrollView.bounds.size.width;
[self.scrollViewsetContentOffset:CGPointMake(x,0) animated:YES];
}
// 视图加载完成调用,通常用来设置数据
- (void)viewDidLoad {
[superviewDidLoad];
[selfscrollView];
// 设置图片
for (int i =0; i < imageCount; i++) {
NSString *imageName = [NSStringstringWithFormat:@"img_%02d",i +1];
UIImage *imge = [UIImageimageNamed:imageName];
UIImageView *imageView = [[UIImageViewalloc] initWithFrame:self.scrollView.bounds];
imageView.image = imge;
[self.scrollViewaddSubview:imageView];
}
// 计算imageView的位置
[self.scrollView.subviewsenumerateObjectsUsingBlock:^(UIImageView *imageView,NSUInteger idx, BOOL *stop) {
CGRect frame = imageView.frame;
frame.origin.x = idx * frame.size.width;
imageView.frame = frame;
NSLog(@"%@",self.scrollView.subviews);
}];
// 分页初始页数为0
self.pageControl.currentPage =0;
// 启动时钟
[selfstartTime];
}
-(void)startTime
{
self.timer = [NSTimertimerWithTimeInterval:2.5target:selfselector:@selector(updateTimer)userInfo:nilrepeats:YES];
// 添加到运行循环
[[NSRunLoopcurrentRunLoop]addTimer:self.timerforMode:NSRunLoopCommonModes];
}
-(void )updateTimer
{
// 页号发生变化
// (当前的页数 + 1) %总页数
int page = (self.pageControl.currentPage +1) % imageCount;
self.pageControl.currentPage = page;
//调用监听方法,让滚动视图滚动
[selfpagechanged:self.pageControl];
}
#pragma mark - ScrollView的代理方法
// 滚动视图停下来,修改页面控件的小点(页数)
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
NSLog(@"%@",NSStringFromCGPoint(scrollView.contentOffset));
int page = scrollView.contentOffset.x /scrollView.bounds.size.width;
self.pageControl.currentPage = page;
}
-(void) scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
[self.timerinvalidate];
}
-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
[selfstartTime];
}
@end
- 轮播图片——APP顶上头条
- 自定义控件:垂直轮播的小贴士Banner,仿 淘宝app的“淘宝头条”
- phpcms头条图片
- js动画——图片轮播
- 电子商店——图片轮播
- Android—( RollViewPager)图片轮播
- 略仿今日头条部分功能,只供参考,娱乐而已(图片3秒跳转,无限轮播,webview,tablayout,listview,Xlistview)
- ViewPager实现APP首页图片轮播和自由切换
- Android App图片轮播效果的组件化
- Android——今日头条APP——高仿——ZYFNewsCTZF
- 仿网易新闻APP(一)——爬网易首页新闻头条
- AndroidStudio——今日头条(可以实时获取数据的app)
- iOS项目之Swift新闻App(五)—头条新闻的实现
- 自定义ViewSwitcher, 支持自定义布局和轮播(淘宝头条效果)
- 使用VerticalBannerView实现垂直轮播广告(仿淘宝头条)
- 一行代码快速实现今日头条 网易新闻焦点图自动循环轮播效果
- 实现垂直轮播广告(仿淘宝头条) OC版本
- 获取头条{3秒转换,轮播(HTTPURLconnection+handler)}
- DOM树
- CALayer动画
- OPENSOC
- MyBatis学习总结(五)——实现关联表查询
- Android扩展存储--ExtraStorage
- 轮播图片——APP顶上头条
- 10个VisualStudio原生开发的调试技巧
- POJ - 3069 Saruman's Army(贪心)
- UIView
- 各种子序列的动态规划求法与优化
- 逆向编程与反汇编的区别
- Android启动服务播放音乐(两种启动方式)
- MyBatis学习总结(六)——调用存储过程
- Mongodb 32位 2G