iOS實(shí)現(xiàn)背景滑動(dòng)效果
本文實(shí)例為大家分享了iOS實(shí)現(xiàn)背景滑動(dòng)效果的具體代碼,供大家參考,具體內(nèi)容如下
1、在很多APP中,我們都可以看見那些特效絢麗的滑動(dòng)選項(xiàng)條,那么如何才能夠簡單,快速的實(shí)現(xiàn)那樣的效果呢
#import <UIKit/UIKit.h> ? ?? @interface ViewController : UIViewController{ ? ? ? NSMutableArray *btnArray; ? ? ? NSMutableArray *titleArray; ? } ? ?? @property (nonatomic,strong) UIView *customView; ? @property (nonatomic,strong) UIView *backView; ? @property (nonatomic,strong) UIButton *myButton; ? ?? -(void)myButtonClcik:(id)sender; ? ?? @end ?
第二步:在我們的額viewdidload方法中,或者自定義一個(gè)方法中創(chuàng)建我么的界面元素。《這里我引日了QuartzCore框架,是為了使用其layer屬性》
#import "ViewController.h" ? #import <QuartzCore/QuartzCore.h> ? ?? @interface ViewController () ? ?? @end ? ?? @implementation ViewController ? ?? @synthesize customView; ? @synthesize backView; ? @synthesize myButton; ? ?? //每行顯示的button個(gè)數(shù) ? #define kSelectNum 6 ? ?? - (void)viewDidLoad ? { ? ? ? [super viewDidLoad]; ? ? ? // Do any additional setup after loading the view, typically from a nib. ? ? ? ?? ? ? //創(chuàng)建背景視圖,并設(shè)置背景顏色或者圖片 ? ? ? customView = [[UIView alloc]initWithFrame:CGRectMake(20, 100, 900, 60)]; ? ? ? customView.backgroundColor = [UIColor blackColor]; ? ? ? //設(shè)置customView的樣式,變?yōu)閳A角 ? ? ? customView.layer.cornerRadius = 15.0f; ? ? ? customView.layer.masksToBounds = YES; ? ? ? //將customView add 到當(dāng)前主View中 ? ? ? [self.view addSubview:customView]; ? ? ? ?? ? ? //創(chuàng)建button的背景視圖 ? ? ? backView = [[UIView alloc] initWithFrame:CGRectMake(5, 5, 95, 50)]; ? ? ? backView.backgroundColor = [UIColor blueColor]; ? ? ? //設(shè)置為圓角。以免造成重疊顯示 ? ? ? backView.layer.cornerRadius = 15.0f; ? ? ? backView.layer.masksToBounds = YES; ? ? ? //將backView視圖add到customView中 ? ? ? [customView addSubview:backView]; ? ? ? ?? ? ? ?? ? ? //創(chuàng)建button,首先button的個(gè)數(shù)是不固定的,因此我們需要?jiǎng)討B(tài)的生成button ? ? ? //創(chuàng)建數(shù)組,保存button的title ? ? ? btnArray = [[NSMutableArray alloc]init]; ? ? ? titleArray = [[NSMutableArray alloc]initWithObjects:@"熱播大片",@"最新更新",@"最熱觀看",@"美劇大片",@"韓劇頻道",@"綜藝娛樂", nil]; ? ? ? //動(dòng)態(tài)生成button ? ? ? for (int i = 0; i < kSelectNum; i ++){ ? ? ? ? ? myButton = [UIButton buttonWithType:UIButtonTypeCustom]; ? ? ? ? ? myButton.titleLabel.font = [UIFont boldSystemFontOfSize:20.0f]; ? ? ? ? ? [myButton setTitle:[titleArray objectAtIndex:i] forState:UIControlStateNormal]; ? ? ? ? ? [myButton setTitleColor:[UIColor grayColor] forState:UIControlStateNormal]; ? ? ? ? ? [myButton setTitleColor:[UIColor whiteColor] forState:UIControlStateSelected]; ? ? ? ? ? [myButton setFrame:CGRectMake(i%(kSelectNum + 1)*140+5, 5, 95, 50)]; ? ? ? ? ? [myButton addTarget:self action:@selector(myButtonClcik:) forControlEvents:UIControlEventTouchUpInside]; ? ? ? ? ? myButton.tag = i; ? ? ? ? ? [btnArray addObject:myButton]; ? ? ? ? ? [customView addSubview:myButton]; ? ? ? ? ? ?? ? ? ? ? //設(shè)置默認(rèn)選擇的button.title的顏色 ? ? ? ? ? if(i == 0){ ? ? ? ? ? ? ? myButton.selected = YES; ? ? ? ? ? } ? ? ? } ? } ?
第三步:我們?yōu)閎utton添加按鈕點(diǎn)擊事件,同時(shí)設(shè)置背景色滑動(dòng)特效。
- (void)myButtonClcik:(id)sender{ ? // ? ?NSString *selectedBtn = [NSString stringWithFormat:@"%@",[titleArray objectAtIndex:button.tag]]; ? // ? ?UIAlertView *alert = [[UIAlertView alloc]initWithTitle:nil message:selectedBtn delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil, nil]; ? // ? ?[alert show]; ? ? ? ?? ? ? //添加動(dòng)畫過度效果 ? ? ? [UIView beginAnimations:@"slowGlide" context:nil]; ? ? ? [UIView setAnimationDuration:0.3f]; ? ? ? ?? ? ? //設(shè)置每次只能選擇一個(gè)button ? ? ? UIButton *button = (UIButton *)sender; ? ? ? if(!button.selected){ ? ? ? ? ? for (UIButton *eachBtn in btnArray) { ? ? ? ? ? ? ? if(eachBtn.isSelected){ ? ? ? ? ? ? ? ? ? [eachBtn setSelected:NO]; ? ? ? ? ? ? ? } ? ? ? ? ? } ? ? ? ? ? [button setSelected:YES]; ? ? ? ? ? ?? ? ? ? ? //設(shè)置點(diǎn)擊那個(gè)按鈕,那個(gè)按鈕的背景改變?yōu)閎ackView的顏色 ? ? ? ? ? [backView setFrame:button.frame]; ? ? ? } ? ? ? [UIView commitAnimations]; ? } ?
最后成型,我們就可以根據(jù)我們的樣式需要進(jìn)行調(diào)整了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- IOS仿今日頭條滑動(dòng)導(dǎo)航欄
- ios scrollview嵌套tableview同向滑動(dòng)的示例
- iOS使用pageViewController實(shí)現(xiàn)多視圖滑動(dòng)切換
- iOS滑動(dòng)解鎖、滑動(dòng)獲取驗(yàn)證碼效果的實(shí)現(xiàn)代碼
- 詳解iOS中position:fixed吸底時(shí)的滑動(dòng)出現(xiàn)抖動(dòng)的解決方案
- 微信小程序在ios下Echarts圖表不能滑動(dòng)的問題解決
- 微信瀏覽器彈出框滑動(dòng)時(shí)頁面跟著滑動(dòng)的實(shí)現(xiàn)代碼(兼容Android和IOS端)
- iOS 頁面滑動(dòng)與標(biāo)題切換顏色漸變的聯(lián)動(dòng)效果實(shí)例
- IOS開發(fā)中禁止NavigationController的向右滑動(dòng)返回
- iOS開發(fā)上下滑動(dòng)UIScrollview隱藏或者顯示導(dǎo)航欄的實(shí)例
相關(guān)文章
iOS點(diǎn)擊推送消息跳到應(yīng)用指定頁面方法
現(xiàn)在的推送用的越來越頻繁,幾乎每個(gè)應(yīng)用都開始用到了。這篇文章主要介紹了iOS點(diǎn)擊推送消息跳到應(yīng)用指定頁面方法,有需要的可以了解一下。2016-11-11IOS CoreLocation實(shí)現(xiàn)系統(tǒng)自帶定位的方法
本篇文章主要介紹了IOS Core Location實(shí)現(xiàn)系統(tǒng)自帶定位的方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-02-02Swift實(shí)現(xiàn)iOS應(yīng)用中短信驗(yàn)證碼倒計(jì)時(shí)功能的實(shí)例分享
這篇文章主要介紹了Swift實(shí)現(xiàn)iOS應(yīng)用中短信驗(yàn)證碼倒計(jì)時(shí)功能的實(shí)例分享,開啟和關(guān)閉倒計(jì)時(shí)功能的步驟實(shí)現(xiàn)比較關(guān)鍵,需要的朋友可以參考下2016-04-04iOS實(shí)現(xiàn)無限循環(huán)滾動(dòng)的TableView實(shí)戰(zhàn)教程
這篇文章主要給大家介紹了關(guān)于iOS實(shí)現(xiàn)無限循環(huán)滾動(dòng)的TableView的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-05-05iOS Xcode8更新后輸出log日志關(guān)閉的方法
今天剛把xcode更新到了xcode8,運(yùn)行發(fā)現(xiàn)好多l(xiāng)og輸出,怎么關(guān)閉呢,不是很清楚,通過查閱相關(guān)資料順利關(guān)掉這些log日志,下面小編把方法共享下,需要的朋友參考下2016-09-09