1. Json简单介绍
json和plist本质都是一堆以一定格式编写的字符串
json和plist都可以用来表示数据信息
json '{}' 表示字典
json '[]' 表示数组
Json在线格式化查看器:
http://www.jsoneditoronline.org/
http://www.bejson.com/
http://www.sojson.com/
2. Json数据简单解析
解析json和解析plist基本一致
plist中有一句 可以直接把文件的路径 转化成字典或数组
json中是两句 先把文件转成 data 再转成字典或数组
关键类 : NSJSONSerialization
// 获取文件路径
NSURL* path = [[NSBundle mainBundle] URLForResource:@"test.json" withExtension:nil];
//根据文件 转化成 NSData
NSData* data = [NSData dataWithContentsOfURL:path];
// 通过data转 字典
NSArray* dict = [NSJSONSerialization JSONObjectWithData:data options:0 error:nil];
3. 数组泛型介绍
写法:声明数组的时候 在 NSArray 后面 (在*之前) , 写一个 <希望放的类型>
两点好处
1.这个数组 只放<希望放的类型>对象,不放其他的,如果放了会提示(警告)
2.这个数组获取的某一个元素能够直接'点'出来'<希望放的类型>'的属性
@property(strong,nonatomic)NSArray *spus;
4. 转模型数据中使用setValues中的一对儿方法
在字典中的某个key 有相对应的属性,那么会走 setValue:forKey: 方法
在字典中的某个key 如果在模型中没有相对应的属性,那么会走 setValue:forUndefinedKey: 方法
- (void)setValue:(id)value forKey:(NSString *)key{
if ([key isEqualToString:@"spus"]) {
NSArray *temArray = value;
NSMutableArray *arrM = [NSMutableArray array];
for (NSDictionary *dict in temArray) {
GMHomeFoodSpus *homeFoodSpus = [GMHomeFoodSpus foodSpusWithDict:dict];
[arrM addObject:homeFoodSpus];
}
[super setValue:arrM forKey:key];
return;
//**这里的return一定要写。不然上面的方法全都白写了,会继续执行下面的方法。**
}
[super setValue:value forKey:key];
}
- (void)setValue:(id)value forUndefinedKey:(NSString *)key{
if ([key isEqualToString:@"description"]) {
self.discountDescription = value;
}
}
5. 使用SDWebImage加载图片
步骤:
导入SDWebImage
通过 sd_setImageUrl的方法 进行加载
报错http的处理方法,控制器会提示错误, ATS。iOS9.0 之后默认是不支持http了,官方建议使用https。所以需要开启支持http。
需要在infoPlist中配置一个叫做 App Transport Security Settings 的key,这是一个字典,下面再加一个 allow 开的bool类型的 YES即可
图片还是加载不出来,需要把picture属性中的后缀名 删除掉
Alt text
// 使用框架中的方法,将图片的后缀wbp删除掉
NSString *imageName = [self.foodSpusData.picture stringByDeletingPathExtension];
// 使用框架中的方法,设置图片及占位图片
[self.pictureView sd_setImageWithURL:[NSURL URLWithString:imageName] placeholderImage:[UIImage imageNamed:@"img_food_loading"]];
6. tableView里面的小方法
6.1 让屏幕滚动到指定的cell
- (void)scrollToRowAtIndexPath:(NSIndexPath *)indexPath atScrollPosition:(UITableViewScrollPosition)scrollPosition animated:(BOOL)animated;
6.2 获取屏幕上出现的cell信息
view有一个属性,可以获取屏幕上出现的cell信息。返回值是一个数组。
@property (nonatomic, readonly, nullable) NSArray *indexPathsForVisibleRows;
利用这个属性,可以获取到屏幕上出现的第一个cell的indexPath
//获取屏幕上出现的cell的第一个indexpath
NSIndexPath *firstIndexPath = [self.categoryFoodView indexPathsForVisibleRows].firstObject;
6.3 选中指定的indexpath的cell
- (void)selectRowAtIndexPath:(nullable NSIndexPath *)indexPath animated:(BOOL)animated scrollPosition:(UITableViewScrollPosition)scrollPosition;
7. 绘制抛物线动画
步骤:
获取抛物线的起止点
创建关键帧动画
创建bezierPath
将path移动至起点
添加带控制点的抛物线
将path赋值给动画路径
可以给view设置一个额外的的属性,方便能够找到这个view
- (void)startAnimation{
// 获取加号的坐标
CGPoint startPoint = [categoryFoodCell convertPoint:shoppingCartBtn.center toView:self.view];
// 定义动画的结束点坐标
CGPoint endPoint = [self.cartIconView convertPoint:self.cartIconView.center toView:self.view];
// 创建动画小红点
UIImageView *redPointView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"icon_common_point"]];
[self.view addSubview:redPointView];
redPointView.center = startPoint;
// 设置动画
CAKeyframeAnimation *keyAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
UIBezierPath *path = [UIBezierPath bezierPath];
[path moveToPoint:startPoint];
//绘制抛物线,添加控制点
[path addQuadCurveToPoint:endPoint controlPoint:CGPointMake(startPoint.x - 100, startPoint.y - 100)];
keyAnimation.path = path.CGPath;
keyAnimation.delegate = self;
keyAnimation.removedOnCompletion = NO;
// 设置动画持续时间
keyAnimation.duration = 2;
keyAnimation.fillMode = kCAFillModeForwards;
// 给小红点设置一个额外的标示赋,用于动画播放结束后移除
[keyAnimation setValue:redPointView forKey:@"tagOfRedPointView"];
[redPointView.layer addAnimation:keyAnimation forKey:@"shoppingCart"];
}
//动画播放结束
- (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag{
// 将小红点的view先取出来,然后从父控件删除
UIImageView *imageView = [anim valueForKey:@"tagOfRedPointView"];
[imageView removeFromSuperview];
// 加这句话的意思是让imageview立即从内存中释放掉。不然等待ARC释放,还需要一段时间
imageView = nil;
}
8. 自定义控件(集成UIControl)
如果之前是某一个继承view的视图,如果想要监听,可以直接把这个view改成继承自UIControl
通过addtarget的方法 进行监听.
在需要使用的时候,发送一个事件(sendActionsForControlEvents)