• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            兔子的技術博客

            兔子

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            一個搜索效果的實現
            2008-11-02 14:11
            iPhone內置的Safari程序,點URL條,鍵盤和URL條中間部分變灰顯示,然后隨著URL的輸入,在中間以UITableView顯示搜索的結果。好多iPhone程序也都有類似的效果。這是如何實現的呢?下面說一下我的實現方法。
            首先注冊鍵盤事件UIKeyboardWillShowNotification的監聽
            [[NSNotificationCenter defaultCenter] addObserver:self 
                                                        selector:@selector(keyboardWillShow:) 
                                                            name:UIKeyboardWillShowNotification object:nil]; 
            程序在點擊textField或searchBar,鍵盤顯示之前,會發送UIKeyboardWillShowNotification通知消息到我們注冊的對象。在keyboardWillShow方法里,我們可以在要變灰的位置上加一個背景著色為黑色的UIView,并將其alpha屬性設為0.9,以達到效果
            - (void)keyboardWillShow:(NSNotification*)aNotification {
                if (keyboardShown) 
                    return; 
                NSDictionary* info = [aNotification userInfo]; 

                NSValue* aValue = [info objectForKey:UIKeyboardBoundsUserInfoKey]; 
                //鍵盤的大小
                CGSize keyboardRect = [aValue CGRectValue].size;
                //計算覆蓋上去的UIView的區域,因為鍵盤始終是在上面的,所以UIView *maskView下面可以大些,主要不要蓋住上面的searchBar之類的內容。要顯示結果的UITableView的大小則要根據鍵盤的大小算出確切的中間區域
                ...
                //將maskView移動最前面
                [window bringSubviewToFront:maskView];
                maskView.alpha = 0.0;
                //設置動畫和maskView最終的alpha值
                [UIView beginAnimations:nil context:NULL];
                [UIView setAnimationDuration:0.5];
                maskView.alpha = 0.9;
                [UIView commitAnimations];
                keyboardShown = YES; 
            }
            keyboardShown是用來跟蹤鍵盤是否已經顯示的布爾變量。如果有多個文本域,之間切換時雖然鍵盤不變,仍會生成UIKeyboardWillShowNotification。通過變量keyboardShown跟蹤鍵盤是不是真的隱藏,可以保證這個效果只執行一次。
            當searchBar有輸入時,可參考官方例子TableSearch,把UITableView加到上面的maskView上。
            當鍵盤隱藏時,把UITableView移掉,將maskView的alpha屬性設為0,即可隱藏maskView。
            實現方法可以更靈活,大體思路應該就是這樣吧。

            轉自:http://hi.baidu.com/programme/blog/item/6f8e4c08359015920b7b8249.html
            @import url(http://m.shnenglu.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
            posted on 2011-10-26 21:47 會飛的兔子 閱讀(5209) 評論(0)  編輯 收藏 引用 所屬分類: 蘋果相關
            久久久久久伊人高潮影院| 97久久精品人人做人人爽| 一本大道久久香蕉成人网| 久久这里只精品99re66| 嫩草伊人久久精品少妇AV| 久久美女人爽女人爽| 欧美日韩中文字幕久久久不卡 | 久久精品国产亚洲AV忘忧草18| 伊人久久大香线蕉精品不卡| 久久无码人妻一区二区三区午夜| 久久e热在这里只有国产中文精品99 | 久久伊人精品青青草原高清| 久久播电影网| 国产精品久久网| 天天综合久久一二三区| 久久国产精品77777| 99久久香蕉国产线看观香| 亚洲伊人久久大香线蕉苏妲己| 国内精品久久久久影院薰衣草| 国产成人精品久久一区二区三区av | 94久久国产乱子伦精品免费| 99久久国产综合精品女同图片| 国产精品免费久久久久电影网| 亚洲精品国产美女久久久| 无码任你躁久久久久久老妇| 国产91久久精品一区二区| 亚洲人成精品久久久久| 久久中文字幕精品| 日本亚洲色大成网站WWW久久 | 99久久精品日本一区二区免费| 久久青青草视频| 久久综合九色欧美综合狠狠| 久久国产亚洲精品麻豆| 69SEX久久精品国产麻豆| 久久久久久久久久久久中文字幕 | 久久超碰97人人做人人爱| 久久综合给合久久国产免费| 日产精品久久久久久久性色| 久久66热人妻偷产精品9| 日本久久久久亚洲中字幕| 精品久久久久久无码专区|