Swift基础之实现下拉变大和OC下拉变大上拉缩小Demo
2016-08-18 15:24
253 查看
Swift语言实现下拉变大效果:(上拉缩小效果随后研究......)
关键代码:方法一:
self.automaticallyAdjustsScrollViewInsets = false;
tableViewW = UITableView.init(frame: CGRectMake(0, 0, screenWidth(), screenHeight()), style: .Plain);
tableViewW.delegate = self;
tableViewW.dataSource = self;
tableViewW.showsVerticalScrollIndicator = false;
tableViewW.tableFooterView = UIView.init();
//下面两句话是关键点,并且顺序不能错,否则初始化运行的时候图片显示不完全
tableViewW.contentInset = UIEdgeInsetsMake(200, 0, 0, 0);
tableViewW.contentOffset = CGPointMake(0, -200);
if tableViewW.respondsToSelector(Selector("setLayoutMargins:"))
{
tableViewW.layoutMargins = UIEdgeInsetsZero;
}
if tableViewW.respondsToSelector(Selector("setSeparatorInset:"))
{
tableViewW.separatorInset = UIEdgeInsetsZero;
}
self.view.addSubview(tableViewW);
headView = UIImageView.init(frame: CGRectMake(0, -200, screenWidth(), 200));
headView.image = UIImage.init(named: "33.jpg");
//这句话是关键点设置高度改变宽度也改变
headView.contentMode = UIViewContentMode.ScaleAspectFill;
tableViewW.addSubview(headView);
实现UIScrollView的代理方法:
func scrollViewDidScroll(scrollView: UIScrollView) {
let offSetY:CGFloat = scrollView.contentOffset.y;//当这里有导航条的时候:+NavigationBarHeight
if offSetY < -200
{
//下拉,图片放大
var frameE:CGRect = headView.frame;
frameE.origin.y = offSetY;
frameE.size.height = -offSetY;//contentMode = UIViewContentModeScaleAspectFill;时,高度改变宽度也改变
headView.frame = frameE;
}
OC语言运用第二种方法实现,图片的下拉放大,下拉缩小的效果
关键代码:
self.title = @"下拉变大,上拉缩小";
self.automaticallyAdjustsScrollViewInsets = NO;
_myTableView = [[UITableView alloc]initWithFrame:CGRectMake(0, navHeight, screenWidth, screenHeight - navHeight)];
_myTableView.delegate = self;
_myTableView.dataSource = self;
_myTableView.contentInset = UIEdgeInsetsMake(headViewRect.size.height-navHeight-navHeight, 0, 0, 0);
[self.view addSubview:_myTableView];
_myView = [[HeadView alloc]initWithFrame:headViewRect backgroundView:@"22.jpg" headView:@"sun.png" headViewWidth:(CGFloat)(screenWidth / 4) signLabel:@"用户名:太阳*黑子"];
_myView.backgroundColor = [UIColor clearColor];
_myView.userInteractionEnabled = NO;
[self.view addSubview:_myView];
UIButton *backBtn = [UIButton buttonWithType:UIButtonTypeCustom];
backBtn.frame = CGRectMake(20, 20, 60, 44);
[backBtn setTitle:@"<<返回" forState:UIControlStateNormal];
[backBtn setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
[backBtn addTarget:self action:@selector(backBtnClick) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:backBtn];
实现UIScrollView的方法:
#pragma mark ------- UIScrollViewDelegate
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
CGFloat offset_Y = scrollView.contentOffset.y + headViewRect.size.height-navHeight-navHeight;
if (offset_Y < 0) {
//下拉图片放大
_myView.backgroundView.contentMode = UIViewContentModeScaleToFill;
_myView.backgroundView.frame = CGRectMake(offset_Y*0.5 , -navHeight, screenWidth - offset_Y, headViewRect.size.height - offset_Y);
}else if (offset_Y > 0 && offset_Y <= (headViewRect.size.height-navHeight-navHeight)) {
//下拉图片缩小,并改变图片的显示效果
_myView.backgroundView.contentMode = UIViewContentModeTop;
_myView.backgroundView.frame = CGRectMake(0 ,navHeight* offset_Y/(headViewRect.size.height-navHeight-navHeight)-navHeight , screenWidth , headViewRect.size.height -(navHeight + navHeight* offset_Y/(headViewRect.size.height-navHeight-navHeight)-navHeight) - offset_Y);
CGFloat width = offset_Y*(40-(screenWidth / 4))/(headViewRect.size.height-navHeight-navHeight)+(screenWidth / 4);
_myView.headView.frame =CGRectMake(0, 0, width,width);
_myView.headView.layer.cornerRadius =width*0.5;
_myView.headView.center = _myView.backgroundView.center;
_myView.signLabel.frame =CGRectMake(0, CGRectGetMaxY(_myView.headView.frame), screenWidth, 40);
_myView.signLabel.alpha = 1 - (offset_Y*3 / (headViewRect.size.height-navHeight-navHeight) /2);
}
}
效果图:
Demo下载:http://download.csdn.net/detail/hbblzjy/9606681
关键代码:方法一:
self.automaticallyAdjustsScrollViewInsets = false;
tableViewW = UITableView.init(frame: CGRectMake(0, 0, screenWidth(), screenHeight()), style: .Plain);
tableViewW.delegate = self;
tableViewW.dataSource = self;
tableViewW.showsVerticalScrollIndicator = false;
tableViewW.tableFooterView = UIView.init();
//下面两句话是关键点,并且顺序不能错,否则初始化运行的时候图片显示不完全
tableViewW.contentInset = UIEdgeInsetsMake(200, 0, 0, 0);
tableViewW.contentOffset = CGPointMake(0, -200);
if tableViewW.respondsToSelector(Selector("setLayoutMargins:"))
{
tableViewW.layoutMargins = UIEdgeInsetsZero;
}
if tableViewW.respondsToSelector(Selector("setSeparatorInset:"))
{
tableViewW.separatorInset = UIEdgeInsetsZero;
}
self.view.addSubview(tableViewW);
headView = UIImageView.init(frame: CGRectMake(0, -200, screenWidth(), 200));
headView.image = UIImage.init(named: "33.jpg");
//这句话是关键点设置高度改变宽度也改变
headView.contentMode = UIViewContentMode.ScaleAspectFill;
tableViewW.addSubview(headView);
实现UIScrollView的代理方法:
func scrollViewDidScroll(scrollView: UIScrollView) {
let offSetY:CGFloat = scrollView.contentOffset.y;//当这里有导航条的时候:+NavigationBarHeight
if offSetY < -200
{
//下拉,图片放大
var frameE:CGRect = headView.frame;
frameE.origin.y = offSetY;
frameE.size.height = -offSetY;//contentMode = UIViewContentModeScaleAspectFill;时,高度改变宽度也改变
headView.frame = frameE;
}
OC语言运用第二种方法实现,图片的下拉放大,下拉缩小的效果
关键代码:
self.title = @"下拉变大,上拉缩小";
self.automaticallyAdjustsScrollViewInsets = NO;
_myTableView = [[UITableView alloc]initWithFrame:CGRectMake(0, navHeight, screenWidth, screenHeight - navHeight)];
_myTableView.delegate = self;
_myTableView.dataSource = self;
_myTableView.contentInset = UIEdgeInsetsMake(headViewRect.size.height-navHeight-navHeight, 0, 0, 0);
[self.view addSubview:_myTableView];
_myView = [[HeadView alloc]initWithFrame:headViewRect backgroundView:@"22.jpg" headView:@"sun.png" headViewWidth:(CGFloat)(screenWidth / 4) signLabel:@"用户名:太阳*黑子"];
_myView.backgroundColor = [UIColor clearColor];
_myView.userInteractionEnabled = NO;
[self.view addSubview:_myView];
UIButton *backBtn = [UIButton buttonWithType:UIButtonTypeCustom];
backBtn.frame = CGRectMake(20, 20, 60, 44);
[backBtn setTitle:@"<<返回" forState:UIControlStateNormal];
[backBtn setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
[backBtn addTarget:self action:@selector(backBtnClick) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:backBtn];
实现UIScrollView的方法:
#pragma mark ------- UIScrollViewDelegate
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
CGFloat offset_Y = scrollView.contentOffset.y + headViewRect.size.height-navHeight-navHeight;
if (offset_Y < 0) {
//下拉图片放大
_myView.backgroundView.contentMode = UIViewContentModeScaleToFill;
_myView.backgroundView.frame = CGRectMake(offset_Y*0.5 , -navHeight, screenWidth - offset_Y, headViewRect.size.height - offset_Y);
}else if (offset_Y > 0 && offset_Y <= (headViewRect.size.height-navHeight-navHeight)) {
//下拉图片缩小,并改变图片的显示效果
_myView.backgroundView.contentMode = UIViewContentModeTop;
_myView.backgroundView.frame = CGRectMake(0 ,navHeight* offset_Y/(headViewRect.size.height-navHeight-navHeight)-navHeight , screenWidth , headViewRect.size.height -(navHeight + navHeight* offset_Y/(headViewRect.size.height-navHeight-navHeight)-navHeight) - offset_Y);
CGFloat width = offset_Y*(40-(screenWidth / 4))/(headViewRect.size.height-navHeight-navHeight)+(screenWidth / 4);
_myView.headView.frame =CGRectMake(0, 0, width,width);
_myView.headView.layer.cornerRadius =width*0.5;
_myView.headView.center = _myView.backgroundView.center;
_myView.signLabel.frame =CGRectMake(0, CGRectGetMaxY(_myView.headView.frame), screenWidth, 40);
_myView.signLabel.alpha = 1 - (offset_Y*3 / (headViewRect.size.height-navHeight-navHeight) /2);
}
}
效果图:
Demo下载:http://download.csdn.net/detail/hbblzjy/9606681
相关文章推荐
- Swift基础之实现下拉变大和OC下拉变大上拉缩小Demo
- Swift基础之实现一个镂空图片的小Demo
- Swift基础之实现一个镂空图片的小Demo
- Swift实现下拉图片放大效果
- Swift 用Delegate和Block实现回调的Demo
- Swift基础之实现选择图片时,出现类似于ActionSheet的样式
- 苹果官方Toast Demo关键代码,Swift实现
- Swift实现的iOS常用手势识别Demo
- swift3.0实现图片放大缩小动画效果
- Qt5.10 用基础控件实现下拉列表菜单,可以展开多级菜单
- Server Side Swift With Vapor(基础配置&使用DropLet类实现http请求)
- iOS ScrollView 下拉放大图片,上滑覆盖图片实现方法(Swift 3.0)
- 使用UICollectionView实现一个列表头部拉伸效果(下拉放大)(OC 和 Swift)
- 下拉加载更多DEMO(js实现)
- Swift开发之使用UIRefreshControl实现下拉刷新数据及uirefreshcontrol使用
- swift实现图片下拉放大,导航栏渐变效果
- jQuery实现滚动鼠标放大缩小图片的方法(附demo源码下载)
- UIScrollView下拉实现图片放大或缩小
- Swift基础之Demo包含刷新,加载,网络请求,MVC
- swift基础之实现单例模式(仿NSUserDefaults)