目录
- 正确显示TabBar上的小图标
- 拉伸图片
- 设置导航条中间标题文字颜色和字体
- NSJSONReadingOptions
- block的使用
- 重写set方法首先要实现原先的方法
- 代码初始化或者XIB初始化Cell时调用的不同方法
- NSAttributedString.h富文本属性(部分)
1. 正确显示TabBar上的小图标
ctrl.tabBarItem.image = [[UIImage imageNamed:imageArray[i]] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
2. 拉伸图片
UIImage *image = [imageTemp stretchableImageWithLeftCapWidth:5 topCapHeight:0];
3. 设置导航条中间标题文字颜色和字体
@property(nonatomic,copy) NSDictionary *titleTextAttributes NS_AVAILABLE_IOS(5_0) UI_APPEARANCE_SELECTOR;
4. NSJSONReadingOptions
typedef NS_OPTIONS(NSUInteger, NSJSONReadingOptions) {
NSJSONReadingMutableContainers = (1UL << 0),
NSJSONReadingMutableLeaves = (1UL << 1),
NSJSONReadingAllowFragments = (1UL << 2)
} NS_ENUM_AVAILABLE(10_7, 5_0);
NSJSONReadingMutableContainers
:返回可变容器,NSMutableDictionary或NSMutableArray。
NSJSONReadingMutableLeaves
:返回的JSON对象中字符串的值为NSMutableString,目前在iOS 7上测试不好用,应该是个bug,参见:
http://stackoverflow.com/questions/19345864/nsjsonreadingmutableleaves-option-is-not-working
NSJSONReadingAllowFragments
:允许JSON字符串最外层既不是NSArray也不是NSDictionary,但必须是有效的JSON Fragment。例如使用这个选项可以解析 @“123” 这样的字符串。参见:
http://stackoverflow.com/questions/16961025/nsjsonserialization-nsjsonreadingallowfragments-reading
5. block的使用
-
SubjectCell.h
@property (nonatomic, copy) void (^clickBlock) (AppItem *item);
-
SubjectCell.m
// cell中通常不处理事件 - (void)clickBtn:(AppButton *)sender { // block的方式 if (self.clickBlock) { self.clickBlock(sender.model); } } - (void)dealloc { _clickBlock = nil; }
-
SubjectViewController.m
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
…………………………………………………………………………………………// 弱引用对象, 防止self对象循环应用,不释放 __weak SubjectViewController *weakSelf = self; // block的方式 cell.clickBlock = ^(AppItem *item){ // 跳转到详情 DetailViewController *ctrl = [[DetailViewController alloc] init]; ctrl.appId = item.applicationId; [weakSelf.navigationController pushViewController:ctrl animated:YES]; }; return cell; }
6. 重写set方法首先要实现原先的方法
- (void)setModel:(AppItem *)model
{
// 重写set方法首先要实现原先的方法
_model = model;
……………………………………………………………………………………………………
}
7. 代码初始化或者XIB初始化Cell时调用的不同方法
@implementation SubjectCell
#warning 代码初始化调用
- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
if (self) {
…………………………………………………………………………………………
}
return self;
}
#warning XIB中初始化调用
- (instancetype)initWithCoder:(NSCoder *)coder
{
self = [super initWithCoder:coder];
if (self) {
…………………………………………………………………………………………
}
return self;
}
8. NSAttributedString.h富文本属性(部分)
NSFontAttributeName 设置字体属性,默认值:字体:Helvetica(Neue) 字号:12
NSForegroundColorAttributeNam 设置字体颜色,取值为 UIColor对象,默认值为黑色
NSBackgroundColorAttributeName 设置字体所在区域背景颜色,取值为 UIColor对象,默认值为nil, 透明色
NSLigatureAttributeName 设置连体属性,取值为NSNumber 对象(整数),0 表示没有连体字符,1 表示使用默认的连体字符
NSKernAttributeName 设定字符间距,取值为 NSNumber 对象(整数),正值间距加宽,负值间距变窄
NSStrikethroughStyleAttributeName 设置删除线,取值为 NSNumber 对象(整数)
NSStrikethroughColorAttributeName 设置删除线颜色,取值为 UIColor 对象,默认值为黑色
NSUnderlineStyleAttributeName 设置下划线,取值为 NSNumber 对象(整数),枚举常量 NSUnderlineStyle中的值,与删除线类似
NSUnderlineColorAttributeName 设置下划线颜色,取值为 UIColor 对象,默认值为黑色
NSStrokeWidthAttributeName 设置笔画宽度,取值为 NSNumber 对象(整数),负值填充效果,正值中空效果
NSStrokeColorAttributeName 填充部分颜色,不是字体颜色,取值为 UIColor 对象
NSShadowAttributeName 设置阴影属性,取值为 NSShadow 对象
NSTextEffectAttributeName 设置文本特殊效果,取值为 NSString 对象,目前只有图版印刷效果可用:
NSBaselineOffsetAttributeName 设置基线偏移值,取值为 NSNumber (float),正值上偏,负值下偏
NSObliquenessAttributeName 设置字形倾斜度,取值为 NSNumber (float),正值右倾,负值左倾
NSExpansionAttributeName 设置文本横向拉伸属性,取值为 NSNumber (float),正值横向拉伸文本,负值横向压缩文本
NSWritingDirectionAttributeName 设置文字书写方向,从左向右书写或者从右向左书写
NSVerticalGlyphFormAttributeName 设置文字排版方向,取值为 NSNumber 对象(整数),0 表示横排文本,1 表示竖排文本
NSLinkAttributeName 设置链接属性,点击后调用浏览器打开指定URL地址
NSAttachmentAttributeName 设置文本附件,取值为NSTextAttachment对象,常用于文字图片混排
NSParagraphStyleAttributeName 设置文本段落排版格式,取值为 NSParagraphStyle 对象
-
NSParagraphStyle包括以下属性
alignment //对齐方式
firstLineHeadIndent //首行缩进
headIndent //缩进
tailIndent //尾部缩进
lineBreakMode //断行方式
maximumLineHeight //最大行高
minimumLineHeight //最低行高
lineSpacing //行距
paragraphSpacing //段距
paragraphSpacingBefore //段首空间
baseWritingDirection //句子方向
lineHeightMultiple //可变行高,乘因数。
hyphenationFactor //连字符属性