先将imageViewframe手动写成:宽20,高20,再勾选Aspect Ratio加入宽高比约束【2015-03-23 11:29:04 by beyond】
【自编号:61】【Cell中,先运行这个- (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier,再运行这个-(void)awakeFromNib;】【2015-03-23 11:40:01 by beyond】
【自编号:71】【推断tableView滚动到了最后一行】
self.tableView.contentSize.height =contentOffset+bounds.size.height【2015-03-23 15:27:43 by beyond】
【自编号:78】【错误installAppearanceSwizzlesForSetter】
原因是:[[UINavigationBar appearance] setTranslucent:NO]在iOS8中才有, 解决的方法:#define IOS8 [[[UIDevice currentDevice] systemVersion] floatValue] >= 8.0 if(IOS8 && [UINavigationBar conformsToProtocol:@protocol(UIAppearanceContainer)]) { [[UINavigationBar appearance] setTranslucent:NO]; }【2015-03-23 17:14:57 by beyond】
【自编号:79】【Unable to determine simulator device to boot】
原因:XCode不知道选择哪一个模拟器去执行app. 解决方法:退出全部XCode和模拟器,若还不行,就重新启动mac【2015-03-23 17:24:04 by beyond】
【自编号:80】【打开模拟器】
XCode-->Open Developer Tool-->Simulator【2015-03-23 17:24:48 by beyond】
【自编号:160】【自己主动定位:No. 3-1 Xianing Alley, No. 3-1 Xianing Alley, Wen'er Road Xixi Residential District, Xihu Hangzhou, Zhejiang China @ <+30.28138170,+120.14211600> +/- 100.00m, region (identifier <+30.28138150,+120.14211600> radius 49.29) <+30.28138150,+120.14211600> radius 49.29m】【2015-03-24 09:46:15 by beyond】
【自编号:161】【自己主动定位:中国浙江省杭州市西湖区西溪街道文二路下宁巷3-1号, 中国浙江省杭州市西湖区西溪街道文二路下宁巷3-1号 @ <+30.28138170,+120.14211600> +/- 100.00m, region (identifier <+30.28138150,+120.14211600> radius 49.29) <+30.28138150,+120.14211600> radius 49.29m】【2015-03-24 09:49:49 by beyond】
【自编号:162】【UserDefault写入的文件夹是:/var/mobile/Applications/Library/Preferences/com.beyond.testUserD.plist】【2015-03-24 10:15:15 by beyond】
【自编号:165】【UILabel显示:标题。
。。
张数,设置NSLineBreakByTruncatingMiddle就可以】【2015-03-24 15:43:37 by beyond】
【自编号:179】【URL Schemes打开app】 【2015-03-25 11:59:52 by beyond】
【自编号:180】【URL Schemes打开app】 【2015-03-25 12:02:43 by beyond】
【自编号:184】【SDWebImage默认会永久缓存一张图片】
但假设同一个url下的图片是变化的。那临时想到的是用内存缓存,[imgView sd_setImageWithURL:url placeholderImage:imgPlace options:SDWebImageCacheMemoryOnly];【2015-03-25 15:14:35 by beyond】
【自编号:186】【推断包括字符串NSRange】
NSRange range = [requestURLStr rangeOfString:@"sg31.com"];if (range.length > 0) {}或者if(range.location !=NSNotFound){}【2015-03-25 16:41:50 by beyond】
【自编号:195】【正则NSPredicate检查中文】
// 检查汉字,YES代表全是汉字- (BOOL)isHanziCheck:(NSString *)str{ // NSString *regex = @"[a-zA-Z\u4e00-\u9fa5][a-zA-Z0-9\u4e00-\u9fa5]+"; NSString *regex = @"[\u4e00-\u9fa5]{2,8}"; NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", regex]; if(![pred evaluateWithObject: str]){ /* //此动画为在顶上显示文字 [MPNotificationView notifyWithText:@"昵称仅仅能由中文、字母或数字组成" andDuration:0.5]; */ return NO; } return YES;}【2015-03-27 10:14:24 by beyond】
【自编号:196】【无法在真机执行,XCode提示ineligible device】
解决的方法:在targets---->build settings---->iOS Deployment Target选择iOS6.1或者更低的版本号【2015-03-30 09:36:17 by beyond】
【自编号:197】【CardI扫描卡没有反应】
card.io only scans 5 card types (MasterCard, Visa, Discover, American Express, JCB),后面是stackoverflow的解答【2015-03-30 11:34:15 by beyond】
【自编号:198】【pod install报错 版本号不兼容】
VKVideoPlayerTests` (iOS 5.0) is not compatible with `Expecta (0.3.2)` which,解决方法:将项目deployment改高一点如:6.1就可以【2015-03-30 11:35:52 by beyond】
【自编号:199】【第3方_VKPlayer播放器】 【2015-03-30 11:42:41 by beyond】
【自编号:201】【Not a git repository】
fatal: Not a git repository (or any of the parent directories): .git解决的方法:git init 就可以【2015-03-30 11:58:48 by beyond】
【自编号:202】【OCR图像识别】
能够实现相似taobaoclient扫描银行卡号的功能【2015-03-30 14:49:13 by beyond】
【自编号:208】【往模拟器里加入照片的最简单的方法:直接把照片拖到模拟器上就能够了】【2015-03-31 13:44:57 by beyond】
【自编号:209】【特效滤镜】 【2015-03-31 13:46:07 by beyond】
【自编号:210】【DLog】
#ifdef DEBUG#define DLog(fmt, ...) NSLog((@"%s [Line %d] " fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);#else#define DLog(...)#endif【2015-03-31 18:55:00 by beyond】
【自编号:211】【怎样设置appIcon】
点击targets--->general--->use asset catalog【2015-04-01 14:53:43 by beyond】
【自编号:214】【MJRefresh的github】 【2015-04-01 17:31:26 by beyond】
【自编号:216】【scrollView滚动方向】
向上拉时,contentOffset.y为正向下拉时。contentOffset.y为负滚动推断用到的变量:typedef void (^ScrollBlock)(void);// 向上滚动时的block@property (nonatomic,strong) ScrollBlock scrollUpBlock;// 向下滚动时的block@property (nonatomic,strong) ScrollBlock scrollDownBlock;// 滚动推断 CGFloat startY; BOOL isNowUp; BOOL isDown; BOOL isUserDrag;#pragma mark - 滚动,新增,显示,隐藏- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{ // 開始时,标记置真 isUserDrag = YES; // 记录一下開始滚动的offsetY startY = scrollView.contentOffset.y;}- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{ // 结束时,置flag还原 isUserDrag = NO;}- (void)scrollViewDidScroll:(UIScrollView *)scrollView{ // 仅仅实用户drag时,才进行响应 if(isUserDrag){ // 实时 // 推断一下,并发出通知 CGFloat newY = scrollView.contentOffset.y; if(startY - newY >0){ // 说明向上滚动 if(!isNowUp){ //通过block告诉外部控制器 if(_scrollUpBlock){ _scrollUpBlock(); } isNowUp = YES; isDown = NO; } }else if(startY - newY<0){ // 说明向下滚动 if(!isDown){ //通过block告诉外部控制器 if(_scrollDownBlock){ _scrollDownBlock(); } isDown = YES; isNowUp = NO; } } startY = scrollView.contentOffset.y; } }- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ if (_scrollDownBlock && self.tableView.contentSize.height - (self.tableView.contentOffset.y+self.tableView.bounds.size.height) < 1) { _scrollDownBlock(); return; } if(_scrollUpBlock){ _scrollUpBlock(); isNowUp = YES; isDown = NO; return; } }【2015-04-02 11:41:05 by beyond】
【自编号:217】【定义枚举】
// 定义一个枚举typedef enum { // 返回button FootViewBtnTypeBack, // 我的 FootViewBtnTypeMine, // 写评论 FootViewBtnTypeWriteComment, // 查看评论 FootViewBtnTypeReadComment, // 关注、取消关注 FootViewBtnTypeAttention, // 很多其它button FootViewBtnTypeMore } FootViewBtnType;【2015-04-02 14:57:34 by beyond】
【自编号:218】【变量名和类型同样时的异常错误】
FilterCtrl *FilterCtrl = [[FilterCtrl alloc]init];这样命名变量,会报错,提示:没有声明alloc方法。
。
。
。
【2015-04-02 15:04:13 by beyond】【自编号:222】【IOS7新特性之XCODE】 【2015-04-03 10:55:31 by beyond】
【自编号:223】【第3方集成支付】 【2015-04-03 10:56:07 by beyond】
【自编号:224】【popping动画演示】 【2015-04-03 10:56:28 by beyond】
【自编号:226】【实时获得webView的contentSize】
iOS 怎样计算UIWebView的ContentSize分类: iPhone常见问题 2014-02-27 17:33 1754人阅读 评论(0) 收藏 举报首选要等UIWebView载入内容后,然后在它的回调方法里将webview的高度Height设置足够小,就设置为1吧。由于这样才干用sizeThatFits才干计算出webview得内容大小- (void)webViewDidFinishLoad:(UIWebView *)aWebView { CGRect frame = aWebView.frame; frame.size.height = 1; aWebView.frame = frame; CGSize fittingSize = [aWebView sizeThatFits:CGSizeZero]; frame.size = fittingSize; aWebView.frame = frame; NSLog(@"size: %f, %f", fittingSize.width, fittingSize.height);}UIWebView计算高度 (2013-10-09 14:48:39)转载▼标签: uiwebview 高度 计算 sizethatfits 分类: ios第一种:- (void)webViewDidFinishLoad:(UIWebView *)webView{ float height = [[webView stringByEvaluatingJavaScriptFromString:@"document.body.offsetHeight;"] floatValue]; //document.body.scrollHeight}第二种:- (void) webViewDidFinishLoad:(UIWebView *)webView{ CGRect frame = webView.frame; CGSize fittingSize = [webView sizeThatFits:CGSizeZero]; frame.size = fittingSize; webView.frame = frame;}第二种- (void)viewDidLoad { [super viewDidLoad]; webview.delegate = self; [webview loadHTMLString:@"fdasfda" baseURL:nil];}- (void)webViewDidFinishLoad:(UIWebView *)webView{NSString *output = [webview stringByEvaluatingJavaScriptFromString:@"document.getElementByIdx_x_x_x("foo").offsetHeight;"]; NSLog(@"height: %@", output);}【2015-04-03 15:46:30 by beyond】
【自编号:227】【ios_数组中放枚举】
NSInteger _btnTagArr[4] = {ContactSelectBtnChatting,ContactSelectBtnTel,isTeacher?
ContactSelectBtnLeave:ContactSelectBtnDetail};
【2015-04-03 17:01:13 by beyond】【自编号:246】【this class is not key value coding-compliant for the key HeightConstraint】
问题:this class is not key value coding-compliant for the key HeightConstraint原因:在IB上拖线时的时候。有多的 ,删除掉就可以解答:【2015-04-07 11:14:44 by beyond】
【自编号:247】【dispatch_after延时改变约束】
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ // 当事件触发时,改变其constant值,然后调用约束所在的对象的 layoutIfNeeded方法,固定的~ 比如: _topView.collectionViewHeightConstraint.constant = 50; // self.leftMarginConstraint.constant = 100; // self.widthConstraint.constant = 200; [UIView animateWithDuration:2.0 animations:^{ [self.view layoutIfNeeded]; [_topView layoutIfNeeded]; }]; });【2015-04-07 11:23:03 by beyond】
【自编号:253】【ios_VLC】 【2015-04-08 17:04:16 by beyond】
【自编号:254】【ios_VLC】
VLC for iOS 2.3.0 关于VLC配置问题,依据个人经验整理了一下,希望能帮到须要的朋友。官网链接:https://wiki.videolan.org/IOSCompile/百度云盘链接:http://pan.baidu.com/s/1bnEOXPH password:ur4l配置说明(百度云盘)官网依照说明操作就能够了仅仅是下载的地址是个谷歌的什么站点,所以你懂得。百度云盘下载下来后须要配置下文件VLC/ios/External 这个目录以下有六个文件(快捷方式):MediaLibraryKit,MobileVLCKit,PLCrashReporter,QuincyKit,gtl,upnpx又一次配置下这六个文件路径就能够用了,vlc源代码是区分真机和模拟器的终端配置路径1、在终端进入External目录2、ln -s -f是终端改动文件路径的,关于终端命令不懂的朋友请百度,在此就不班门弄斧了。真机就用Release-iphoneos,模拟器就用Release-iphonesimulatorln -s -f /Users/stlink/Desktop/VLC/ios/ImportedSources/MediaLibraryKit/build/Release-iphoneos MediaLibraryKit ln -s -f /Users/stlink/Desktop/VLC/ios/ImportedSources/VLCKit/build/Release-iphoneos MobileVLCKitln -s -f /Users/stlink/Desktop/VLC/ios/ImportedSources/PLCrashReporter/build/Release-iphoneos PLCrashReporter ln -s -f /Users/stlink/Desktop/VLC/ios/ImportedSources/QuincyKit/client/iOS/QuincyLib/build/Release-iphoneos QuincyKit ln -s -f /Users/stlink/Desktop/VLC/ios/ImportedSources/GDrive/build/Release-iphoneos gtl ln -s -f /Users/stlink/Desktop/VLC/ios/ImportedSources/upnpx/projects/xcode4/upnpx/build/Release-iphoneos upnpx3、路径正确的话就没问题了,ls -l 查看文件路径改动完毕后就能够启动了VLC/iOS/VLC for iOS.xcodeproj注意:我有时候配置正确路径可是文件还是报错,这样的情况的话解压又一次搞吧,临时不知道怎么处理。SimplePlayback这个是VLC在线播放的一个demo,路径:VLC/ios/ImportedSources/VLCKit/Examples_iOS/SimplePlayback项目直接拷贝出来不能用的,要配置下。libMobileVLCKit.a 这个demo用到这个静态库。
静态库区分真机和模拟器的。
静态库我不太懂怎么配置,搞了几次没搞定 只是有另外的办法MobileVLCKit.framework这个不区分真机和模拟器的。 路径:VLC/ios/ImportedSources/VLCKit/build 注意:Deployment target 要低于7.0 END 最后希望能帮到须要的朋友,不懂得能够联系我,qq:527993842,加好友请说明谢谢,因为工作原因可能无法及时回复请见谅,并且我也是刚接触vlc。
关键词:iOS VLC MediaLibraryKit项目中的Search paths使用相对路径就能够了。 Header Search Paths --> ../../External/MobileVLCKit/include Library Search Paths --> ../../External/MobileVLCKit MediaLibraryKit项目中相对路径$(SRCROOT)得到的值是/XXX/XXX/VLC/ios/ImportedSources/MediaLibraryKit,而不是想象中的/XXX/XXX/VLC/ios/ 多谢LZ的奉献~~~
【2015-04-08 17:05:30 by beyond】【自编号:255】【导航返回button】
UIButton* btn = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, image.size.width+10, 40)]; btn.showsTouchWhenHighlighted = YES; [btn setImage:image forState:UIControlStateNormal]; [btn addTarget:theTarget action:sel forControlEvents:UIControlEventTouchUpInside]; UIBarButtonItem *backBtn = [[UIBarButtonItem alloc] initWithCustomView:btn]; backBtn.tag = 9528; vc.navigationItem.leftBarButtonItem = backBtn;【2015-04-08 17:29:42 by beyond】
【自编号:256】【iphone真机死活不旋转】
死活不走代理方法:- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation{ return (interfaceOrientation == UIInterfaceOrientationPortrait || interfaceOrientation == UIInterfaceOrientationLandscapeLeft || interfaceOrientation == UIInterfaceOrientationLandscapeRight);}原因可能是:手机上拉高速设置栏中:竖排方向锁定 :打开了【2015-04-09 11:13:39 by beyond】
【自编号:257】【模拟器上面 播放视频崩溃】
iphone 4s 8.0系统的模拟器上面 播放视频:崩溃:Apr 9 11:44:39 [jun] rtcreporting[57158] : logging starts...Apr 9 11:44:39 [jun] rtcreporting[57158] : setMessageLoggingBlock: called原因:在模拟器上面播放视频解决的方法:去掉全局断点,这是一个bug【2015-04-09 11:52:57 by beyond】
【自编号:258】【应该竖屏,仅在视频播放页面横屏】
在app delegate中。启动时, [userDefault setBool:NO forKey:@"userDefault_isAllowLandscape"]; [userDefault synchronize];在app delegate中,通过一个本地保存的key进行推断。是否进行横屏- (NSUInteger)application:(UIApplication *)application supportedInterfaceOrientationsForWindow:(UIWindow *)window{ // 全局的设置:同意竖屏+横屏 NSUserDefaults *userDefault = [NSUserDefaults standardUserDefaults]; BOOL isAllowLandscape = [userDefault boolForKey:@"userDefault_isAllowLandscape"]; if (isAllowLandscape) { return UIInterfaceOrientationMaskPortrait|UIInterfaceOrientationMaskLandscape; } else { return UIInterfaceOrientationMaskPortrait; }}在视频播放控制器中。更改本地保存的key就可以【2015-04-09 14:40:52 by beyond】
【自编号:261】【ios_xib_preview预览】
右上方----show the assistant edit ---- 选择新窗体中manual最下方的Preview【2015-04-10 09:51:28 by beyond】
【自编号:267】【inDatabase: was called reentrantly on the same queue, which would lead to a deadlock】
在使用时,假设在queue里面的block运行过程中,又调用了 indatabase方法,则会检查 是不是同一个queue,假设是同一个queue会死锁;原因非常easy:队列里面 放了一个block,该block又在 本队列 后面放了一个 block;从而:前一个block 里面 调用了 后一个block,必须等后一个block运行完毕了。前一个block才会 出队列;而后一个block想要运行,则又必须先等 前一个block出队列。因此 死锁。!
。!
解决方法:在indatabase的block中,不要再调用indatabase方法 [[[DBHelper shareInstance] dbQueue]inDatabase:^(FMDatabase *db){ isSuccess = [self.helper update4Table:TB_User_Friend withArgs:args where:where]; }]; >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> - (void)inDatabase:(void (^)(FMDatabase *db))block { /* Get the currently executing queue (which should probably be nil, but in theory could be another DB queue * and then check it against self to make sure we're not about to deadlock. */ FMDatabaseQueue *currentSyncQueue = (__bridge id)dispatch_get_specific(kDispatchQueueSpecificKey); assert(currentSyncQueue != self && "inDatabase: was called reentrantly on the same queue, which would lead to a deadlock"); }
【2015-04-16 10:49:41 by beyond】【自编号:270】【自己主动布局scrollView】
contentSize 必须明白指定。如label距离下方多少。距离右边多少,这样才干够 让scrollView计算出contentSize【2015-04-16 15:50:52 by beyond】
【自编号:271】【先对数组统一排序,再进行分组,再组内排序】
// 其它情况,返回是数组 NSMutableArray *contentDictArr = (NSMutableArray *)content; DLog(@"返回是数组,长度是 %d",contentDictArr.count); //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> // NSArray 转成 NSMutableArray // 0、对于不启用的,即enabled为0的字典模型,删除掉 NSMutableArray *dictArr = [NSMutableArray array]; for (NSInteger i = 0; i < contentDictArr.count; i++) { NSDictionary *dict = contentDictArr[i]; if ([[dict objectForKey:@"FEnabled"]intValue] == 1) { [dictArr addObject:dict]; } } // DLog(@"清除未启用的字典后的数组:%@",dictArr); // 0.1、对于被包括的模块。临时剔除 NSMutableArray *tempdictArr = [NSMutableArray array]; for (NSInteger i = 0; i < dictArr.count; i++) { NSDictionary *dict = dictArr[i]; // 假设有值,则说明是某个模块的子模块@"26e86235-e04c-46e1-a7d5-6d513c02de39" // 假设没有值,即NSNull,表示是根文件夹模块,直接展示 if ([[dict objectForKey:@"FUpCMID"] class] == [NSNull class]) { [tempdictArr addObject:dict]; } } // 1、对数组按GroupTag排序 NSArray *sortDesc = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"FGroupTag" ascending:YES]]; NSArray *sortedArr = [tempdictArr sortedArrayUsingDescriptors:sortDesc]; // DLog(@"排序后的数组:%@",sortedArr); // 2、对数组进行分组,按GroupTag // 遍历,创建组数组,组数组中的每个元素是一个模型数组 NSMutableArray *testGroupArr = [NSMutableArray array]; NSMutableArray *currentArr = [NSMutableArray array]; // 由于肯定有一个字典返回,先加入一个 [currentArr addObject:sortedArr[0]]; [testGroupArr addObject:currentArr]; // 假设不止一个,才要动画加入 if(sortedArr.count > 1){ for (NSInteger i = 1; i < sortedArr.count; i++) { // 先取出组数组中 上一个模型数组的第一个字典模型的groupID NSMutableArray *preModelArr = [testGroupArr objectAtIndex:testGroupArr.count-1]; NSInteger preGroupID = [[[preModelArr objectAtIndex:0] objectForKey:@"FGroupTag"] intValue]; // 取出当前字典,依据groupID比較,假设同样则加入到同一个模型数组;假设不同样,说明不是同一个组的 NSDictionary *currentDict = sortedArr[i]; NSInteger groupID = [[currentDict objectForKey:@"FGroupTag"] intValue]; if (groupID == preGroupID) { [currentArr addObject:currentDict]; }else{ // 假设不同样,说明 有新的一组,那么创建一个模型数组,并加入到组数组testGroupArr currentArr = [NSMutableArray array]; [currentArr addObject:currentDict]; [testGroupArr addObject:currentArr]; } } } // 3、遍历 对每一组 进行排序 NSMutableArray *tempGroupArr = [NSMutableArray array]; for (NSArray *arr in testGroupArr) { // NSArray *sortDesc = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"FOrder" ascending:YES]]; NSArray *tempArr = [arr sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) { if([[obj1 objectForKey:@"FOrder"]intValue] < [[obj2 objectForKey:@"FOrder"]intValue]){ return NSOrderedAscending; } if([[obj1 objectForKey:@"FOrder"]intValue] > [[obj2 objectForKey:@"FOrder"]intValue]){ return NSOrderedDescending; } return NSOrderedSame; }]; [tempGroupArr addObject:tempArr]; } testGroupArr = tempGroupArr; DLog(@"封装好的group数组:%@",testGroupArr); //>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> // testGroupArr 将封装好的字典数组缓存起来,以便下次调用 userDefault_localGroupArr // 依据用户上次选择的,展示 NSUserDefaults *userDefault = [NSUserDefaults standardUserDefaults]; [userDefault setBool:YES forKey:@"userDefault_hasCached_moduleDictArr"]; NSString *jsonStr = testGroupArr.JSONString; DLog(@"没有网络的时候用:jsonStr:%@",jsonStr); [userDefault setObject:jsonStr forKey:@"testGroupArr_jsonStr"]; [userDefault sync【2015-04-17 11:39:14 by beyond】
【自编号:272】【awakeFromNib】
- (id)initWithFrame:(CGRect)frame { self = [super initWithFrame:frame]; if (self) { // Initialization code } return self; } - (void)awakeFromNib{ [super awakeFromNib]; NSLog(@"call %s", __FUNCTION__); self.backgroundColor = [UIColor redColor]; // 其它初始化方法}【2015-04-17 13:44:36 by beyond】
【自编号:273】【iOS开发的一些奇巧淫技】 【2015-04-17 13:45:06 by beyond】
【自编号:274】【nsrange,是 一个结构体,方法: NSMakeRange(<#NSUInteger loc#>, <#NSUInteger len#>)】【2015-04-17 15:36:04 by beyond】
【自编号:279】【textView占位】
Easy way, just create placeholder text in UITextView by using the following UITextViewDelegate methods:- (void)textViewDidBeginEditing:(UITextView *)textView{ if ([textView.text isEqualToString:@"placeholder text here..."]) { textView.text = @""; textView.textColor = [UIColor blackColor]; //optional } [textView becomeFirstResponder];}- (void)textViewDidEndEditing:(UITextView *)textView{ if ([textView.text isEqualToString:@""]) { textView.text = @"placeholder text here..."; textView.textColor = [UIColor lightGrayColor]; //optional } [textView resignFirstResponder];}just remember to set myUITextView with the exact text on creation e.g.UITextView *myUITextView = [[UITextView alloc] init];myUITextView.delegate = self;myUITextView.text = @"placeholder text here...";myUITextView.textColor = [UIColor lightGrayColor]; //optionaland make the parent class a UITextViewDelegate before including these methods e.g.@interface MyClass () @end【2015-04-20 10:30:15 by beyond】
【自编号:281】【btn得到cell得到table得到row】
while (![btn isMemberOfClass:[self class]]){ btn = (UIButton *)[btn superview]; } MyProjectCell *cell = (MyProjectCell *)btn; UITableView *tableView = (UITableView *)cell; while (![tableView isMemberOfClass:[UITableView class]]){ tableView = (UITableView *)[tableView superview]; } NSIndexPath *path = [tableView indexPathForCell:cell]; row = path.row; // 已经弃用,调用外界的控制器的block,并将cell的行号传递过去 // _wannaChangeStatusBlock(row); // 调用外界的控制器的block,并将cell的行号传递过去 _wannaChangeStatusBlockExt(row,cell);【2015-04-21 15:31:01 by beyond】
【自编号:282】【auto adjust cell】
viewdidload tableView.rowHeight = UITableViewAutomaticDimension; tableView.estimatedRowHeight = 10;cellForRow [cell layoutIfNeeded];【2015-04-21 15:37:29 by beyond】
【自编号:283】【iOS开发的一些奇巧淫技】 【2015-04-22 16:46:25 by beyond】
【自编号:284】【url schemes】
project--->targets--->info--->urlTypesidentifier: com.sg31.wwwurl schemes: beyond以下的为接收到外部调用的时候程序启动,响应方法,在safari输入:beyond://com.sg31.www- (BOOL)application:(UIApplication *)application handleOpenURL:(NSURL *)url { if ([[url scheme] isEqualToString:@"beyond"]) { NSLog(@"外部调用成功"); } return YES; }【2015-04-23 09:58:25 by beyond】
【自编号:285】【动画特效1】
CAKeyframeAnimation * animation; animation = [CAKeyframeAnimation animationWithKeyPath:@"transform"]; animation.duration = 0.5; animation.delegate = self; animation.removedOnCompletion = YES; animation.fillMode = kCAFillModeForwards; NSMutableArray *values = [NSMutableArray array]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.1, 0.1, 1.0)]]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.2, 1.2, 1.0)]]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.9, 0.9, 0.9)]]; [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.0, 1.0, 1.0)]]; animation.values = values; [_contentView.layer addAnimation:animation forKey:nil];【2015-04-23 17:22:19 by beyond】