【OC随笔】写给自己的一些小东西

前言:

在这里写一些自己粗心容易忽略和忘记的东西,不定期更新……


素材网:

聚合数据(各种免费API,要注册实名认证):https://www.juhe.cn
atool(在线批量剪裁各种尺寸iOS、Android APP icon图标):
http://www.atool.org/ios_logo.php
tool(在线代码格式化(数据解析)):http://tool.oschina.net/codeformat/json
ydimage(在线批量剪裁各种尺寸iOS、Android APP icon图标):http://ydimage.yidianhulian.com
阿里巴巴矢量图(各种矢量图标):http://www.iconfont.cn/plus/home/index
千库网(各种免费下载的免修图): http://588ku.com/print/0-0-pxnum-0-8-0-0-3/
千图网:http://www.58pic.com/app/
logoko (logo在线生成 纯色):http://www.logoko.com.cn/index.php?
logaster (logo在线生成 彩色 推荐):https://www.logaster.cn/logo/
移动开发图标规范:http://www.ui001.com/chicun/
oc转swift: https://objectivec2swift.com/#/home/main
showapi(免费api,可以不实名认证):https://www.showapi.com/


生成高清二维码:
/**
 * 根据CIImage生成指定大小的UIImage
 *
 * @param image CIImage
 * @param size 图片宽度
 */
- (UIImage *)createNonInterpolatedUIImageFormCIImage:(CIImage *)image withSize:(CGFloat) size
{
    CGRect extent = CGRectIntegral(image.extent);
    CGFloat scale = MIN(size/CGRectGetWidth(extent), size/CGRectGetHeight(extent));
    // 1.创建bitmap;
    size_t width = CGRectGetWidth(extent) * scale;
    size_t height = CGRectGetHeight(extent) * scale;
    CGColorSpaceRef cs = CGColorSpaceCreateDeviceGray();
    CGContextRef bitmapRef = CGBitmapContextCreate(nil, width, height, 8, 0, cs, (CGBitmapInfo)kCGImageAlphaNone);
    CIContext *context = [CIContext contextWithOptions:nil];
    CGImageRef bitmapImage = [context createCGImage:image fromRect:extent];
    CGContextSetInterpolationQuality(bitmapRef, kCGInterpolationNone);
    CGContextScaleCTM(bitmapRef, scale, scale);
    CGContextDrawImage(bitmapRef, extent, bitmapImage);
    // 2.保存bitmap到图片
    CGImageRef scaledImage = CGBitmapContextCreateImage(bitmapRef);
    CGContextRelease(bitmapRef);
    CGImageRelease(bitmapImage);
    return [UIImage imageWithCGImage:scaledImage];
}


通过字符串的字数获取应该要的size:
+(CGSize)textSize:(NSString*)str withWidth:(CGFloat)width withFont:(NSInteger)font{  
    CGSize size;  
    if (iosVersion>=7.0) {  
        NSDictionary *attribute = @{NSFontAttributeName: [UIFont systemFontOfSize:font]};  
        size = [str boundingRectWithSize:CGSizeMake(width, CGFLOAT_MAX) options: NSStringDrawingTruncatesLastVisibleLine | NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading attributes:attribute context:nil].size;  
    }else{  
        size=[str sizeWithFont:[UIFont systemFontOfSize:font] constrainedToSize:CGSizeMake(width, CGFLOAT_MAX) lineBreakMode:NSLineBreakByCharWrapping|NSLineBreakByWordWrapping];  
    }  
    return size;  
}  

NSTextAlignmentCenter不生效:
cell = [[UITableViewCell alloc ] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:@"cell"];

//改为

cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@“cell”];

tableview分区头不悬停在顶部:
_tableView = [[UITableView alloc] initWithFrame:CGRectMake(0, 40, self.view.frame.size.width, Height/1.6) style:UITableViewStylePlain];

//改为

_tableView = [[UITableView alloc] initWithFrame:CGRectMake(0, 40, self.view.frame.size.width, Height/1.6) style:UITableViewStyleGrouped];

tableviewcell自定移动到最后一个
- (void)scrollTableToFoot:(BOOL)animated
{
    NSInteger s = [self.tableView numberOfSections];  //有多少组
    if (s<1) return;  //无数据时不执行 要不会crash
    NSInteger r = [self.tableView numberOfRowsInSection:s-1]; //最后一组有多少行
    if (r<1) return;
    NSIndexPath *ip = [NSIndexPath indexPathForRow:r-1 inSection:s-1];  //取最后一行数据
    [self.tableView scrollToRowAtIndexPath:ip atScrollPosition:UITableViewScrollPositionBottom animated:animated]; //滚动到最后一行
}

去除tableview的灰线:
_tableView.separatorStyle = NO;
tabelview点击后还原(不会一直显示灰色):

-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath 中写

[self.tableView deselectRowAtIndexPath:indexPath animated:YES];

UIImage UIImageView 展示图片 不变形 处理:

imageView 的contentMode 属性 网上有个 很形象的例子

但是 尽量 其中 UIViewContentModeScaleAspectFill 会保证图片比例不变,但是是填充整个ImageView的
但是 我使用的情况 比例严重不符合要求 所以 变形的非常明显
这个时候 关键代码就是
imageView.clipsToBounds = YES;
When YES, content and subviews are clipped to the bounds of the view. Default is NO.
这里的clip是修剪的意思,bounds是边界的意思是,合起来就是:如果子视图的范围超出了父视图的边界,那么超出的部分就会被裁剪掉。 那么图片 就会按比例显示 尽管 图片不会显示全 这也是合理的吧哈哈


nib创建cell的两种注册方法:

血和泪的记忆

方法一:
//第一步:
[self.collectionView registerNib:[UINib nibWithNibName:@"QGLShareBtnCell" bundle:nil] forCellWithReuseIdentifier:@"QGLShareBtnCell”];
//第二步:
QGLShareBtnCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"QGLShareBtnCell" forIndexPath:indexPath];
方法二:
QGLIMGroupListCell *cell = (QGLIMGroupListCell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier];    
if (cell == nil) 
{       
 cell= (QGLIMGroupListCell *)[[[NSBundle  mainBundle]  loadNibNamed:@"QGLIMGroupListCell" owner:self options:nil]  lastObject];    
}

presentViewController弹出页面反应迟钝的问题

想要实现点击tableview中的一个cell,弹出一个页面,代码如下:

HSLoginViewController *loginVC = [HSLoginViewController new];  
[self presentViewController:loginVC animated:YES completion:nil];       

结果页面弹出速度非常慢,有时几秒钟才能弹出,又是根本不弹出,直到在页面上随意再次点击一下才弹出。
将代码做如下修改后,问题解决:

dispatch_async(dispatch_get_main_queue(), ^{  
            HSLoginViewController *loginVC = [HSLoginViewController new];  
            [self presentViewController:loginVC animated:YES completion:nil];  
        });  

由此推断,presentViewController这个方法有可能不是在UI线程执行的。


系统自带分享功能

很多APP中都带有社交分享功能,国内较或的分享平台有微信,IOS6后苹果集成的新浪微博,还有IOS7后集成的腾讯微博。 在IOS中,实现社交分享可以自己编写各个平台的分享代码,但代码量较多,也可以利用iOS自带的Social.framework,更可以利用第三方的分享框架,如友盟,ShareSDK等。

  1. 分享视图控制器:SLComposeViewController
    SLComposeViewController的呈现在iPhone采用模态视图,iPad则需要Popover视图呈现。如果发送微博信息并不像弹出分享列表,再去选择,而是在应用中直接进入写评论的地方(iOS系统提供的UI画面)。SLComposeViewController类可以帮助我们实现这个目的,SLComposeViewControlelr不仅可以撰写weibo,还可以撰写Tweet和Facebook。发送这样的社交网络信息一般会包含3中信息:初始文本、图片和超链接,因此SLComposeViewController类设计3个相对方法:

setInitialText:(NSString *)text,设置初始文本内容
addImage:(UIImage *)iamge,添加图片
addURL:(NSURL *)url,添加超链接信息

使用SLComposeViewController来实现社交分享的具体步骤如下:

  1. 判断设备是否可以向指定的分享平台分享。
  2. 创建分享视图控制器,指定分享平台
  3. 设置分享内容。
  4. 进入分享界面。5. 监听用户操作。

本文主要介绍一下系统自带的分享服务框架。 iOS系统为我们提供了两个不同的类来实现分享服务。

需要用真机测试

项目中需要导入一个系统自带头文件 #import 我们在屏幕的点击事件中来实现分享到微博
 - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
    // 首先判断新浪分享是否可用
    if (![SLComposeViewController isAvailableForServiceType:SLServiceTypeSinaWeibo]) {
        return;
    }
    // 创建控制器,并设置ServiceType
    SLComposeViewController *composeVC = [SLComposeViewController composeViewControllerForServiceType:SLServiceTypeSinaWeibo];
    // 添加要分享的图片
    [composeVC addImage:[UIImage imageNamed:@"Snip20150429_9"]];
    // 添加要分享的文字
    [composeVC setInitialText:@"share my CSDN Blog"];
    // 添加要分享的url
    [composeVC addURL:[NSURL URLWithString:@"http://blog.csdn.net/u011058732"]];
    // 弹出分享控制器
    [self presentViewController:composeVC animated:YES completion:nil];
    // 监听用户点击事件
    composeVC.completionHandler = ^(SLComposeViewControllerResult result){
        if (result == SLComposeViewControllerResultDone) {
            NSLog(@"点击了发送");
        }
        else if (result == SLComposeViewControllerResultCancelled)
        {
            NSLog(@"点击了取消");
        }
    };
}

2 . 分享列表:UIActivityViewController
在iOS6之后系统为我们提供了一个分享列表视图,它通过UIActivityViewController管理。苹果设计它的主要目的是替换分享动作,分享动作选单是出于分享目的的动作选单。内置活动列表项主要有一下几个:

UIActivityTypePostToFacebook,Facebook活动列表项;
UIActivityTypePostToTwitter,Twitter活动列表项;
UIActivityTypePostToWeibo,新浪微博活动列表项;
UIActivityTypeMessage,iOS中的iMessage应用活动那个列表项;
UIActivityTypeMail,发送Mail活动列表项;
UIActivityTypePrint,共享打印活动列表项;
UIActivityTypeCopyToPasteboard,复制到剪切板活动列表项;
UIActivityTypeAssignToContact,访问联系人活动列表项;
UIActivityTypeSaveToCameraRoll,访问设备上的相册活动列表项;

使用UIActivityViewController我们可以选中需要分享的平台,然后跳转到分享内容的边界界面,具体的实现步骤如下:1. 设置分享内容。2. 创建分享列表的控制器,并传入分享内容3. 推出分享视图控制器。

-(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    // 设置分享内容
    NSString *text = @"分享内容";
    UIImage *image = [UIImage imageNamed:@"01"];    NSURL *url = [NSURL URLWithString:@"https://www.baidu.com"];
    NSArray *activityItems = @[text, image, url];
    // 服务类型控制器
    UIActivityViewController *activityViewController =    [[UIActivityViewController alloc] initWithActivityItems:activityItems applicationActivities:nil];
    [self presentViewController:activityViewController animated:YES completion:nil];
    // 选中分享类型
    [activityViewController setCompletionWithItemsHandler:^(NSString * __nullable activityType, BOOL completed, NSArray * __nullable returnedItems, NSError * __nullable activityError){
        // 显示选中的分享类型
        NSLog(@"act type %@",activityType);
        if (completed) {
            NSLog(@"ok");
        }else {
            NSLog(@"no ok");
        }
    }];
}

多线程各种问题

http://www.jianshu.com/p/0b0d9b1f1f19


iOS 8中的Self Sizing Cells和Dynamic Type

http://www.cocoachina.com/ios/20140922/9717.html

在iOS 8中,苹果引入了UITableView的一项新功能--Self Sizing Cells,对于不少开发者来说这是新SDK中一项非常有用的新功能。在iOS 8之前,如果想在表视图中展示可变高度的动态内容时,你需要手动计算行高,而Self Sizing Cells为展示动态内容提供了一个解决方案。

tableView.estimatedRowHeight = 44.0
tableView.rowHeight = UITableViewAutomaticDimension

优化UITableViewCell高度计算的那些事

http://blog.sunnyxx.com/2015/05/17/cell-height-calculation/


iOS多线程

http://www.jianshu.com/p/0b0d9b1f1f19

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 生活很无趣,我也不知道我现在一个什么心态去面对生活,只想平淡的过,但是生活的压力又使我不得不去,努力的去面对生活!...
    斉飛阅读 611评论 0 1
  • 月半掩着,周围散发着淡淡的微光。 每次都沿着同一条路散步,马路两边停着不同颜色不同品牌的轿车,开着的超...
    H红馆阅读 168评论 0 0
  • 如若此时我已故去 生命如雪花般消融 微笑也不会离开脸庞 只为你从原野上扯过的风 如若此时我已故去 生命如银杏叶般飘...
    岚皊阅读 192评论 0 0
  • 当你认真谈过一段感情,最后却不得不分手了,后来你会很难再去喜欢别人,你不想花时间也不想去了解,就好比你写一篇作文快...
    心受伤了阅读 401评论 0 0