您好,登錄后才能下訂單哦!
iOS6,7中UISearchBar內部的view布局已經完全不一樣。如圖:
上面是iOS6的,下面是iOS7的,對應的去除UISearchBar的背景色和添加其中的UITextField的代碼也不一樣。如下:
//搜索框 UISearchBar *sBar = [[UISearchBar alloc] initWithFrame:CGRectMake(83, 6, 230, 31)]; sBar.placeholder = @"請選擇類型后輸入關鍵字"; sBar.delegate = self; sBar.barStyle = UIBarStyleDefault; if ([sBar respondsToSelector:@selector(barTintColor)]) { [sBar setBarTintColor:[UIColor clearColor]]; UIView *searchview = [sBar.subviews objectAtIndex:0]; for (UIView *view in searchview.subviews){ if ([view isKindOfClass: [UITextField class]]) { UITextField *tf = (UITextField *)view; tf.clearButtonMode = UITextFieldViewModeWhileEditing; tf.borderStyle = UITextBorderStyleNone; tf.background = [[UIImage p_w_picpathNamed:@"bg_searchbox.png"] stretchableImageWithLeftCapWidth:20 topCapHeight:0]; tf.leftView = nil; break; } } [_typeBtn setImageEdgeInsets:UIEdgeInsetsMake(0, 2, 0, -65)]; } else{ [[sBar.subviews objectAtIndex:0] removeFromSuperview]; [sBar setBackgroundColor:[UIColor clearColor]]; for (UIView *view in sBar.subviews){ if ([view isKindOfClass: [UITextField class]]) { UITextField *tf = (UITextField *)view; tf.clearButtonMode = UITextFieldViewModeWhileEditing; tf.borderStyle = UITextBorderStyleNone; tf.background = [[UIImage p_w_picpathNamed:@"bg_searchbox.png"] stretchableImageWithLeftCapWidth:20 topCapHeight:0]; tf.leftView = nil; break; } } } _searchBar = [sBar retain]; [self.view addSubview:sBar]; [sBar release];
事情到這里,公司的任務就算結束了。這個要多問一句了。圖片中的數據哪里來的?這才是重點。
玩過Linux c/c++的人都知道gdb,雖然你可能完全沒有用過,好吧,我承認,我也沒正經用過,只是偶爾看到而已。iOS以前也是用gcc/gdb的,后來改用了llvm/lldb,但是大同小異了。只是這么大的程序的到底怎么玩調試,我還不知道,哪里去輸入,我查了半天才找到,其實挺簡單,只要你斷點打上,在輸出log的那個區域可以直接輸入的。
網上一哥們寫的 Xcode LLDB Debug教程,我抄在這里:
在xcode中打開一個app,在想要break的行號上單擊,即可生成一個深色的箭頭標識--斷點。如下圖,在viewDidLoad:中設置了斷點。
運行app,等待。。。就可以看到xcode在斷點處進入調試模式,現在讓我們把視線移到xcode右下角的控制臺,有木有看到(lldb)這樣一行,鼠標移到此行,輸入
1 | po [self view] |
po(print object)是LLDB的一個命令,其主要功能是輸出objective-c中對象(objects)的信息,與之相似的另外一個命令是 p(print),其主要功能是輸出原生類型(boolean、integer、float、etc)的信息。
控制臺輸入
p (int)[[[self view] subviews] count]結果如下
(int) $2 = 2
注意這個使用了類型轉換告知調試器應該如何處理返回值。
你以前怎么驗證是不是某個變量的值導致整段程序不能正常工作?修改代碼中的變量的值,然后cmd+r重新啟動app?現在你不需要這么做了,只需要設置一個斷點,當程序在這進入調試模式后,使用expr命令即可在運行時修改變量的值。
假如有一個loginWithUsername:方法,需要兩個參數:username,password。
首先設置好斷點,如下圖所示:
運行app,進入斷點模式后,在(lldb)后輸入
1 | expr username = @ "username" |
2 | expr password = @ "badpassword" |
1 | (NSString *) $0 = 0x3d3504c4 @ "username" |
2 | (NSString *) $1 = 0x1d18ef60 @ "badpassword" |
1 | (0x1c59aae0) A line for the breakpoint |
2 | (0x1c59aae0) Username and Password after: username:badpassword |
右擊斷點選擇“Edit Breakpoint...”(或者按住cmd+option,單擊斷點),然后如下圖所示設置斷點
注意選中了最后一行(“Automatically continue after evaluating”)的選擇框,這就保證運行到這個斷點的時,填充變量的值,然后繼續運行,并不在此處斷點進入調試模式。
運行app,你會得到和上述手動設置變量的值一樣的輸出。
接下來單擊斷點,使其處于禁用狀態,現在箭頭的顏色應該是淺藍色的,重新運行app,你會發現username和password的值沒有在運行時被改變了。
斷點的另外一個重要作用,是可以設置觸發斷點生效的條件,這樣我們就可以在運行時針對特定的數據進行分析,觀察app是否運行在正確的軌道上。如下圖:
上述截圖可以看到如下語句
1 | ( BOOL )[(NSString*)[item valueForKey:@ "ID" ] isEqualToString:@ "93306" ] |
如果你厭倦了代碼里無窮無盡的NSLog,幸運的是我們可以在編輯斷點使其輸出格式化字符串就像平常編碼時一樣。不過有一點需要注意,平常編碼時可能會使用NSString‘s stringWithFormat:輸出格式化字符串,不過這個方法貌似在斷點中木有效果,你需要使用alloc/init形式的方法,如下:
1 | po [[NSString alloc] initWithFormat:@ "Item index is: %d" , index] |
運行app,就能在控制臺看到想要的輸出啦!
簡單!強大!這就是LLDB給你的選擇,從此代碼里可以不用再有NSLog滿天飛的情況了,代碼變得更干凈了,心情變得更愉悅了!
LLDB還有很多強大的地方,本教程只不過揭開了它的面紗,即便如此,仍讓我們沉醉不已。
到這里,算是正式可以開始玩lldb調試了,官方主頁可以去查你想要額東西:http://lldb.llvm.org , l
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。