麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

swift-教你如何實現導航上的UISearchController動畫效果。

2019-11-14 17:56:08
字體:
來源:轉載
供稿:網友

   這個代碼片段是我這周我從網上找了各種資料然后經過自己的修改終于弄好了導航的上下動畫效果:

step1:==>因為這個搜索要有動畫效果,所以這個頁面必須要有一個導航控制器:

//1.自定義創建導航控制器

這個頁面我是從其他頁面跳轉過來的,跳轉之前我自定義了一個導航控制器:

   let actionSearchTable=searchTable();

        let navVC = UINavigationController(rootViewController: actionSearchTable);

        navVC.navigationBar.barStyle = UIBarStyle.BlackTranslucent;

        self.PResentViewController(navVC, animated: true, completion: nil);

//2.點擊搜索跳轉到 searchTable.swift,這個頁面我繼承的是 UITableViewController,而不是UiViewController,一定要注意,不然每當點擊一次搜索取消的時候table上面會多出一片空白,這個原理我還不是太明白,如果你們發現了其中的原理希望能指點一二。

這個表格的數據源我引用的是一個txt文件。格式如下圖:

 

////  searchResultTable.swift//  搜索框////  Created by 盧洋 on 15/11/6.//  Copyright © 2015年 奈文摩爾. All rights reserved.//import UIKitclass searchTable: UITableViewController,UISearchBarDelegate{    lazy var dismissBtn: UIButton = { UIButton(frame: CGRectMake(0, 0, 24, 24)) }();//返回按鈕        var itemsString:[String]!    var searcher:UISearchController!    var searchBars:UISearchBar?        struct SearchControllerRestorableState {        var wasActive = false        var wasFirstResponder = false    }    var restoredState = SearchControllerRestorableState();        //初始化函數    override func viewDidLoad() {        super.viewDidLoad();        self.title="查找商家";        initView();            }        //初始化UI    func initView(){        dismissBtnPrepare();        //創建Table        self.tableView=UITableView(frame: CGRectMake(0, 80, UIScreen.mainScreen().bounds.width, UIScreen.mainScreen().bounds.height));        self.tableView.delegate=self;        self.tableView.dataSource=self;        self.tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "cells")                //1.讀取表格數據        let tablePath = NSBundle.mainBundle().pathForResource("states", ofType: "txt")!;        let tableData=try! NSString(contentsOfFile: tablePath, encoding: NSUTF8StringEncoding);        itemsString = tableData.componentsSeparatedByString("/n") as [String];                let src = searchResultTable(data: itemsString)        searcher = UISearchController(searchResultsController: src)                searcher.searchResultsUpdater = src;        //獲取焦點時有陰影效果        searcher.dimsBackgroundDuringPresentation=true;        //獲取焦點導航向上移的動畫效果        searcher.hidesNavigationBarDuringPresentation=true;        searchBars = searcher.searchBar        tableView.tableHeaderView = searchBars        searchBars?.delegate=self;        searchBars?.placeholder="輸入商家名稱";        //取消按鈕顏色和文本框光標顏色        searchBars?.tintColor=UIColor.blueWithTabbar();        //搜索框背景顏色        //searchBars?.barTintColor=UIColor.blackColor();        searcher.searchBar.sizeToFit();        self.tableView.reloadData();
     //背景充滿導航 definesPresentationContext
= true; } override func viewDidAppear(animated: Bool) { super.viewDidAppear(animated) // Restore the searchController's active state. if restoredState.wasActive { searcher.active = restoredState.wasActive restoredState.wasActive = false if restoredState.wasFirstResponder { searcher.searchBar.becomeFirstResponder() restoredState.wasFirstResponder = false } } } override func viewDidDisappear(animated: Bool) { super.viewDidAppear(animated); //2.3將狀態欄變為白色 UIapplication.sharedApplication().statusBarStyle = UIStatusBarStyle.LightContent; } func searchBarSearchButtonClicked(searchBar: UISearchBar) { searchBar.resignFirstResponder() } override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return itemsString.count } override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCellWithIdentifier("cells", forIndexPath: indexPath) cell.textLabel!.text = itemsString[indexPath.row]; return cell } override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { //取消選中的樣式 tableView.deselectRowAtIndexPath(indexPath, animated: true); //獲取點擊的行索引 if(indexPath.row == 0){ } } /** 返回按鈕 */ func dismissBtnPrepare(){ dismissBtn.setImage(UIImage(named: "img.bundle/cancel"), forState: UIControlState.Normal) dismissBtn.addTarget(self, action: "dismissLogin", forControlEvents: UIControlEvents.TouchUpInside) self.navigationItem.leftBarButtonItem = UIBarButtonItem(customView: dismissBtn) } /** 釋放當前頁面 */ func dismissLogin(){ self.dismissViewControllerAnimated(true, completion: nil) } func searchBarCancelButtonClicked(searchBar: UISearchBar) { print("b"); //2.3將狀態欄變為白色 UIApplication.sharedApplication().statusBarStyle = UIStatusBarStyle.LightContent; } //搜索框開始編輯事件 func searchBarTextDidBeginEditing(searchBar: UISearchBar) { //2.3將狀態欄變為白色 UIApplication.sharedApplication().statusBarStyle = UIStatusBarStyle.Default; } func searchBarTextDidEndEditing(searchBar: UISearchBar) { //2.3將狀態欄變為白色 UIApplication.sharedApplication().statusBarStyle = UIStatusBarStyle.LightContent; }}

//3.搜索結果頁面  searchResultTable.swift

////  searchResultTable2.swift//  searchBarDemo////  Created by 盧洋 on 15/11/6.//  Copyright © 2015年 奈文摩爾. All rights reserved.//import Foundationimport UIKitclass searchResultTable:UITableViewController,UISearchResultsUpdating{    var tableData:UITableView!;    var originalData:[String]!                  //原數據    var filteredData:[String]!                  //過濾數據        override func viewDidLoad() {        super.viewDidLoad();        self.title="輸入商家名稱";        initView()    }    init(data:[String]){        originalData = data        super.init(nibName: nil, bundle: nil)            }        required init?(coder aDecoder: NSCoder) {        fatalError("init(coder:) has not been implemented")    }        //初始化UI    func initView(){        //創建Table        tableData=UITableView(frame: CGRectMake(0, 0, UIScreen.mainScreen().bounds.width, UIScreen.mainScreen().bounds.height));        self.view.addSubview(tableData);        //tableData.backgroundColor=UIColor.redColor();        tableData.delegate=self;        tableData.dataSource=self;        tableData.registerClass(UITableViewCell.self, forCellReuseIdentifier: "cells")            }         override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {        // #warning Incomplete implementation, return the number of rows        return filteredData.count    }     override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {        let cell = tableView.dequeueReusableCellWithIdentifier("cells", forIndexPath: indexPath)                cell.textLabel!.text = originalData[indexPath.row];                return cell    }    func updateSearchResultsForSearchController(searchController: UISearchController) {        let searchBar=searchController.searchBar;        let target=searchBar.text;        filteredData = originalData.filter()            {                                s in                var options = NSStringCompareOptions.CaseInsensitiveSearch                if searchController.searchBar.selectedScopeButtonIndex == 0                {                    options = options.union(.AnchoredSearch)                }                let found = s.rangeOfString(target!, options: options)                                return (found != nil)        }        tableData.reloadData()            }    override func didReceiveMemoryWarning() {        super.didReceiveMemoryWarning();    }}

 

好最后效果圖如下:但是其中的字符串過濾有一點點問題,解決了一定要告訴我。。

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 九九热视频这里只有精品 | 成人宗合网 | 亚洲四播房 | 久草在线新时代视觉 | 黄污免费网站 | 曰本三级日本三级日本三级 | 在线看一区二区三区 | 国产精品成人一区 | 麻豆视频免费网站 | 91 视频网站| 欧美性色生活片免费播放 | 精品国产一区二区久久 | 亚洲欧洲日产v特级毛片 | 国产一级做a爰片在线看 | 一级毛片电影网 | 青草视频在线观看视频 | 亚洲成人伊人 | 国产精品视频免费在线观看 | 国产日韩久久久久69影院 | 粉嫩粉嫩一区二区三区在线播放 | 日韩美香港a一级毛片免费 日韩激情 | 成年人观看免费视频 | 成人免费影院 | 欧美 日韩 国产 成人 | 天天色宗合 | 91色综合综合热五月激情 | 一级毛片真人免费播放视频 | 欧美一级高潮 | 99re热视频这里只精品 | 日韩黄色免费观看 | 91av资源在线| 亚洲成人福利在线 | 国产精品高潮99久久久久久久 | 性爱视频在线免费 | 在线小视频国产 | 亚洲日本韩国精品 | 黄色片免费在线 | 欧产日产国产精品乱噜噜 | 少妇的肉体2无删减版 | 国产亚洲精品成人a | 国产女同疯狂激烈互摸 |