iOS 动画基础总结篇

iOS 动画基础总结篇

 

动画的大体分类(个人总结可能有误)

1.png

分类.png

UIView 动画

属性动画

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
    [UIView beginAnimations:nil context:nil];
    [UIView setAnimationDelay:1];
    [UIView setAnimationDuration:2];
    [UIView setAnimationRepeatCount:100];
    [UIView setAnimationRepeatAutoreverses: YES];  // 翻转
    [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut]; //设置动画变化的曲线
    UIView *view =  self.redview;
    view.alpha = 0;
    view.center = CGPointMake(view.center.x + 300, view.center.y);
    [UIView setAnimationDelegate:self];   // 设置代理 监测动画结束的
    [UIView setAnimationDidStopSelector:@selector(shopAction)];
    [UIView commitAnimations];
   其中   setAnimationCurve 参数为
   UIViewAnimationCurveEaseInOut:这种曲线的动画开始缓慢,在其持续时间的中间加速,然后在完成之
 前再次减慢。这是大多数动画的默认曲线。
   UIViewAnimationCurveEaseIn:动画开始时缓慢,然后加速,直到动画结束。这里选用这种类型动画曲
 线。
   UIViewAnimationCurveEaseOut:动画开始时速度很快,在结束前开始减速。
   UIViewAnimationCurveLinear:在动画持续时间内,动画匀速运行。

基于Block的属性动画

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
     [UIView animateWithDuration:0.5 animations:^{
     
    UIView *view = self.viewArray[4];
   view.transform = CGAffineTransformRotate(view.transform, M_2_PI); // 顺时针旋转
}];
[UIView animateKeyframesWithDuration:2 delay:0 options:UIViewKeyframeAnimationOptionRepeat animations:^{
    UIView *view = self.viewArray[5];
   view.transform = CGAffineTransformMakeScale(21);//宽高伸缩比例;
} completion:^(BOOL finished) {
    if (finished) {
       UIView *view = self.viewArray[5];
       view.backgroundColor = [UIColor colorWithRed: arc4random()%256 255.0 green:arc4random()%256 255.0 blue:arc4random()%256255.0  alpha:1.0];
    }
}];
[UIView animateKeyframesWithDuration:5 delay:0 options:UIViewKeyframeAnimationOptionRepeat animations:^{
     UIView *view = self.viewArray[6];
    view.transform = CGAffineTransformMakeTranslation(3006);//xy移动距离;
} completion:^(BOOL finished) {
    if (finished) {
        UIView *view = self.viewArray[6];
        view.backgroundColor = [UIColor colorWithRed: arc4random()%256 255.0 green:arc4random()%256 255.0 blue:arc4random()%256255.0  alpha:1.0];
    }
     
}];
[UIView animateWithDuration:0.5 delay:0 options:UIViewAnimationOptionRepeat animations:^{
      UIView *view = self.viewArray[7];
      view.transform = CGAffineTransformMake(1.51221,1);//自定义形变,参数自拟;
     
} completion:^(BOOL finished) {
    if (finished) {
           UIView *view = self.viewArray[7];
           view.backgroundColor = [UIColor colorWithRed: arc4random()%256 255.0 green:arc4random()%256 255.0 blue:arc4random()%256255.0  alpha:1.0];
    }
     
}];
// 弹簧效果  // 一  动画执行的时间   二  动画延迟执行的时间  第三个  弹簧震动的频率 0 - 1 值越小频率越高 四 弹簧的起始抖动的速度  五 代表动画的效果  六 具体执行的动画   七 执行完之后 的操作
[UIView animateWithDuration:1 delay:0 usingSpringWithDamping:0.1 initialSpringVelocity:10 options:UIViewAnimationOptionCurveLinear animations:^{
         UIView *view = self.viewArray[8];
    if (view.center.x > [UIScreen mainScreen].bounds.size.width) {
        view.center = CGPointMake(0, view.center.y);
    }else{
        view.center = CGPointMake(view.center.x + 10, view.center.y);
    }
     
     
     
} completion:^(BOOL finished) {
     
}];

我的理解是UIView的属性动画 就是在一定时间内改变其属性值从而达到动画的效果。

属性动画效果如下,有助于理解不同参数的效果

2.gif

UIview 属性动画.gif

过渡动画(本来有做gif 图但是不知道为啥放上来不会动了 捂脸!)

图好了

2.gif

转场.gif

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  [UIView transitionWithView:self.view3 duration:1 options:UIViewAnimationOptionTransitionFlipFromTop animations:^{
        self.view1.hidden = NO;
        self.view2.hidden = YES;
    } completion:^(BOOL finished) {
         
    }];
  参数  
 //转场动画相关的
  UIViewAnimationOptionTransitionNone            //无转场动画
  UIViewAnimationOptionTransitionFlipFromLeft    //转场从左翻转
  UIViewAnimationOptionTransitionFlipFromRight   //转场从右翻转
  UIViewAnimationOptionTransitionCurlUp          //上卷转场
  UIViewAnimationOptionTransitionCurlDown        //下卷转场
  UIViewAnimationOptionTransitionCrossDissolve   //转场交叉消失
  UIViewAnimationOptionTransitionFlipFromTop     //转场从上翻转
  UIViewAnimationOptionTransitionFlipFromBottom  //转场从下翻转

layer 层动画

layer 层属性 设置一些边框 圆角等

1
2
3
4
5
view.layer.borderWidth = 6;
view.layer.borderColor = [UIColor redColor].CGColor;
view.layer.cornerRadius = 10;
CGPoint archP = view.layer.anchorPoint;
CGPoint postion = view.layer.position;

layer 动画 CABasicAnimation

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
   // 一些常用的key
   /*   transform.scale 比例转化    @(0.8)
 transform.scale.x  宽的比例    @(0.8)
 transform.scale.y  高的比例    @(0.8)
 transform.rotation.x   围绕x轴旋转  @(M_PI)
 transform.rotation.y   围绕y轴旋转  @(M_PI)
 transform.rotation.z   围绕z轴旋转  @(M_PI)
 cornerRadius   圆角的设置   @(50)
 backgroundColor    背景颜色的变化 (id)[UIColor purpleColor].CGColor
 bounds 大小,中心不变 [NSValue valueWithCGRect:CGRectMake(0, 0, 200, 200)];
 position   位置(中心点的改变)  [NSValue valueWithCGPoint:CGPointMake(300, 300)];
 contents   内容,比如UIImageView的图片 imageAnima.toValue = (id)[UIImage imageNamed:@"to"].CGImage;
 opacity    透明度 @(0.7)
 contentsRect.size.width    横向拉伸缩放  @(0.4)最好是0~1之间的
 */
   /*  属性   说明
duration    动画的时长
repeatCount 重复的次数。不停重复设置为 HUGE_VALF
repeatDuration  设置动画的时间。在该时间内动画一直执行,不计次数。
beginTime   指定动画开始的时间。从开始延迟几秒的话,设置为【CACurrentMediaTime() + 秒数】 的方式
timingFunction  设置动画的速度变化
autoreverses    动画结束时是否执行逆动画
fromValue   所改变属性的起始值
toValue 所改变属性的结束时的值
byValue 所改变属性相同起始值的改变量
 */
 //CABasicAnimation 最终不会修改其属性  只是为了做动画使用
 // 设置需要修改的layer层属性
CABasicAnimation *basicAnimation = [CABasicAnimation animationWithKeyPath:@"position.x"];
//设置对应的控件Layer层position.x 的起始值
basicAnimation.fromValue = @(-112);
// 设置最终值
basicAnimation.toValue = @(425);
// 设置时间
basicAnimation.duration = 4;
// 设置动画重复的次数
basicAnimation.repeatCount = 1000000;
// 将动画添加到对应视图的layer层上
[view1.layer addAnimation:basicAnimation forKey:nil];
CABasicAnimation *transformAnima = [CABasicAnimation animationWithKeyPath:@"transform.rotation.y"];
transformAnima.fromValue = @(M_PI_2);
transformAnima.toValue = @(M_PI);
transformAnima.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
transformAnima.autoreverses = YES;
transformAnima.repeatCount = HUGE_VALF;
transformAnima.beginTime = CACurrentMediaTime() + 1;
// 这两个是在动画结束之后使view 到最终状态而不是原始状态  因为layer 层动画 其实view 本身frame 没有改变的
transformAnima.removedOnCompletion = NO;
transformAnima.fillMode = kCAFillModeForwards;
//    fillMode
 /* 该属性定义了你的动画在开始和结束时的动作。默认值是 kCAFillModeRemoved。
  取值的解释
   kCAFillModeRemoved 设置为该值,动画将在设置的 beginTime 开始执行(如没有设置beginTime属性,则动画立即执行),动画执行完成后将会layer的改变恢复原状。
   kCAFillModeForwards 设置为该值,动画即使之后layer的状态将保持在动画的最后一帧,而removedOnCompletion的默认属性值是 YES,所以为了使动画结束之后layer保持结束状态,应将removedOnCompletion设置为NO。
   kCAFillModeBackwards 设置为该值,将会立即执行动画的第一帧,不论是否设置了 beginTime属性。观察发现,设置该值,刚开始视图不见,还不知道应用在哪里。
 kCAFillModeBoth 该值是 kCAFillModeForwards 和 kCAFillModeBackwards的组合状态
*/
   // 添加动画
   [view.layer addAnimation:transformAnima forKey:@"A"];

CAKeyframeAnimation 关键帧动画

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// 关键帧动画
// 指定动画需要修改的属性
CAKeyframeAnimation *keyFrameA = [CAKeyframeAnimation animationWithKeyPath:@"position"];
// 获得起始的点
CGPoint point1 = view12.layer.position;
// 第二个点
CGPoint point2 = CGPointMake(375 2.0, -50);
// 第三个点
CGPoint point3 = CGPointMake(375 50, point1.y);
// 第四个点
CGPoint point4 = point1;
NSValue *pointV1 = [NSValue valueWithCGPoint:point1];
NSValue *pointV2 = [NSValue valueWithCGPoint:point2];
NSValue *pointV3 = [NSValue valueWithCGPoint:point3];
NSValue *pointV4 = [NSValue valueWithCGPoint:point4];
keyFrameA.values = @[pointV1,pointV2,pointV3,pointV4];
// 设置每帧动画的起始和结束点
keyFrameA.duration = 5;
// 设置重复的次数
keyFrameA.repeatCount = 1000;
//将动画添加到指定的控件的layer上;
[view12.layer addAnimation:keyFrameA forKey:nil];
//绕矩形循环跑
CALayer * rectLayer = [[CALayer alloc] init];
rectLayer.frame = CGRectMake(152003030);
rectLayer.cornerRadius = 15;
rectLayer.backgroundColor = [[UIColor blackColor] CGColor];
[self.view.layer addSublayer:rectLayer];
CAKeyframeAnimation *rectRunAnimation = [CAKeyframeAnimation animationWithKeyPath:@"position"];
//设定关键帧位置,必须含起始与终止位置
rectRunAnimation.values = @[[NSValue valueWithCGPoint:rectLayer.frame.origin],
                            [NSValue valueWithCGPoint:CGPointMake([UIScreen mainScreen].bounds.size.width - 15,
                                                                  rectLayer.frame.origin.y)],
                            [NSValue valueWithCGPoint:CGPointMake([UIScreen mainScreen].bounds.size.width - 15,
                                                                  rectLayer.frame.origin.y + 100)],
                            [NSValue valueWithCGPoint:CGPointMake(15, rectLayer.frame.origin.y + 100)],
                            [NSValue valueWithCGPoint:rectLayer.frame.origin]];
 //    CGMutablePathRef path = CGPathCreateMutable()
//    CGPathMoveToPoint(path, NULL, rectLayer.position.x - 15, rectLayer.position.y - 15);
 //    CGPathAddLineToPoint(path, NULL, 320 - 15, rectLayer.frame.origin.y);
 //    CGPathAddLineToPoint(path, NULL, 320 - 15, rectLayer.frame.origin.y + 100);
 //    CGPathAddLineToPoint(path, NULL, 15, rectLayer.frame.origin.y + 100);
//    CGPathAddLineToPoint(path, NULL, 15, rectLayer.frame.origin.y);
//    rectRunAnimation.path = path;
//    CGPathRelease(path);
//设定每个关键帧的时长,如果没有显式地设置,则默认每个帧的时间=总duration/(values.count - 1)
rectRunAnimation.keyTimes = @[[NSNumber numberWithFloat:0.0], [NSNumber numberWithFloat:0.6],
                              [NSNumber numberWithFloat:0.7], [NSNumber numberWithFloat:0.8],
                              [NSNumber numberWithFloat:1]];
  //    1 kCAMediaTimingFunctionLinear//线性
  //    2 kCAMediaTimingFunctionEaseIn//淡入
  //    3 kCAMediaTimingFunctionEaseOut//淡出
 //    4 kCAMediaTimingFunctionEaseInEaseOut//淡入淡出
  //    5 kCAMediaTimingFunctionDefault//默认
rectRunAnimation.timingFunctions = @[[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
                                     [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseOut],
                                     [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn],
                                     [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionDefault]];
rectRunAnimation.repeatCount = 1000;
rectRunAnimation.autoreverses = NO;
 //    1 const kCAAnimationLinear//线性,默认
 //    2 const kCAAnimationDiscrete//离散,无中间过程,但keyTimes设置的时间依旧生效,物体跳跃地出现在各个关键帧上
 //    3 const kCAAnimationPaced//平均,keyTimes跟timeFunctions失效
 //    4 const kCAAnimationCubic//平均,同上
 //    5 const kCAAnimationCubicPaced//平均,同上
rectRunAnimation.calculationMode = kCAAnimationLinear;
rectRunAnimation.duration = 4;
rectRunAnimation.removedOnCompletion = NO;
rectRunAnimation.fillMode = kCAFillModeForwards;
[rectLayer addAnimation:rectRunAnimation forKey:@"rectRunAnimation"];
self.rectLayer = rectLayer;
}
  // 抖动示例
  // 创建帧动画对象
CAKeyframeAnimation *anim = [CAKeyframeAnimation animation];
  // 设置动画属性
anim.keyPath = @"transform.rotation";
anim.values = @[@(kAngleToRadian(-5)), @(kAngleToRadian(5))];
 // 设置动画执行次数
anim.repeatCount = HUGE_VALF;
 // 设置动画的执行时长
anim.duration = 0.1;
  // 设置动画的自动反转效果
anim.autoreverses = YES;
anim.removedOnCompletion = NO;
anim.fillMode = kCAFillModeForwards;
/ 将动画效果添加到lionImage的layer上
[self.imagev.layer addAnimation:anim forKey:nil];

本来都有动图的,现在都动不了,大家可以想象下 一个图在左右抖动 , 上面的那个图是 一个小球按着矩形 线路走一会快一会慢 ! 

图来了

2.gif

CAKeyframeAnimation.gif

其实关键帧动画相对来说可能会作出比较复杂的效果,使用方法很简单,只是复杂的动画会使用到算法,可能稍微需要思考。

CATransition 转场

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 kCATransitionFade                   //交叉淡化过渡                     
kCATransitionMoveIn               //移动覆盖原图                     
kCATransitionPush                    //新视图将旧视图推出去                     
kCATransitionReveal                //底部显出来     
 kCATransitionFromRight;                     
 kCATransitionFromLeft(默认值)                     
 kCATransitionFromTop;                     
 kCATransitionFromBottom          
注:kCATransitionFade 不支持Subtype   
CATransition *anima = [CATransition animation];
anima.type = kCATransitionFade;//设置动画的类型
anima.subtype = kCATransitionFromRight; //设置动画的方向
//anima.startProgress = 0.3;//设置动画起点
//anima.endProgress = 0.8;//设置动画终点
anima.duration = 1.0f;
 [_demoView.layer addAnimation:anima forKey:@"fadeAnimation"];

当然很多动画都不是单一的出现的,下面我们就看下动画组合。

其实动画组合无非就是多种动画作用在一个view上面达到的效果

例如

2.gif

组合动画.gif

动画组合

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
  // 动画组合
CABasicAnimation *positionAnima = [CABasicAnimation animationWithKeyPath:@"position.y"];
positionAnima.duration = 0.8;
positionAnima.fromValue = @(view.center.y);
positionAnima.toValue =  @(view.center.y + 100);
positionAnima.timingFunction = [CAMediaTimingFunction 
 functionWithName:kCAMediaTimingFunctionLinear];
positionAnima.repeatCount = HUGE_VALF;
//    positionAnima.repeatDuration = 2;
positionAnima.removedOnCompletion = NO;
positionAnima.fillMode = kCAFillModeForwards;
positionAnima.delegate = self;
positionAnima.autoreverses = YES; // 执行逆动画
[view.layer addAnimation:positionAnima forKey:@"AnimationMoveY"];
/* 放大缩小 */
// 设定为缩放
CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"transform.scale"];
// 动画选项设定
animation.duration = 2.5// 动画持续时间
animation.repeatCount = HUGE_VALF; // 重复次数
animation.autoreverses = YES; // 动画结束时执行逆动画
// 缩放倍数
animation.fromValue = [NSNumber numberWithFloat:1.0]; // 开始时的倍率
animation.toValue = [NSNumber numberWithFloat:2.0]; // 结束时的倍率
// 添加动画
animation.removedOnCompletion = NO;
animation.fillMode = kCAFillModeForwards;
[view.layer addAnimation:animation forKey:@"scale-layer"];
效果就是在移动的过程中放大缩小

好了,至此都总结完毕,这些都是基础的东西,好好利用这些再复杂的动画也能做出来! 当然,还有粒子效果这里因为没有动图就不先不总结了,好的,谢谢大家的捧场!

转载于:https://www.cnblogs.com/shenlaiyaoshi/p/8496140.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/267536.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

bootstraptable获得所有行_郎酒领衔,2020“川酒全国行”首站香满花城

12月8日,2020“川酒全国行”首站在广州开启。以“川酒金花醉美珠江”为主题,本次活动由四川省经济和信息化厅指导,四川中国白酒金三角酒业协会主办,四川郎酒股份有限公司承办,五粮液、泸州老窖、剑南春、舍得、水井坊协…

centos7根据端口查进程_记录一次CentOs7下Nginx+WSGI部署Django项目(超详细)

记录一次Django部署的文章,不是很熟悉Linux系统,踩了不少坑,本篇文章相当于是一个总结,我会在本文中详细介绍,部署单个Django项目和多个Django的方法,如读者有更好的方法,欢迎留言一起探讨~长话…

淘宝跨域获取Cookie分析

最近在发现使用Taobao的时候的一个小细节,于是便萌发起了写这篇文章。 当我们在 www.taobao.com 中进行登录之后,然后直接切换到 www.tmall.com 域名下,发现www.tmall.com首页的最顶部马上显示成了: 您好, andyfaces。 首先&#…

js原型和原型链

我们要理解js的原型,首先需要知道5条js原型规则: 1.js引用类型(function ,array ,object)都可以任意扩展自己的属性。 1 function fn(){2 3 }4 fn.age10;5 console.log(fn.age);//106 7 var arr[1,2,3];8 arr.namekeke;9 console.log(arr);//[1,2,3,name…

蜡笔小新里的钢达姆机器人怎么画_写字机器人好用吗? 组装就花了5个小时 还要学习软件、录入字体...

据江苏公共新闻频道《新闻360》报道:新学期开学,各种各样的课后作业成了孩子和家长关注的话题。前不久,一条“孩子购买代写作业机器人,被家长发现”的新闻,引发了强烈争议。这种可以写字的机器人到底是什么&#xff1f…

20165235 Java第一周学习总结

(# 20165235 Java第一周学习总结 Ubuntu下git的安装与使用首先Ubuntu下git的安装,使用sudo apt-get install git下载Ubuntu,下载完成后可以用指令git查看。 安装完git之后输入git config --global user.name "名字",git config --global user.…

解决opencv在pycharm中无代码自动提示的bug

2018-03-0422:19:39 首先,估计这不是bug 可能是我自己误操作导致的,但是让我搞了好久才搞定,实在是苦恼 如图已实现功能,百度里有很多朋友出现了,这个无代码提示的问题 大概是这样的,毕竟,软件这…

看风水用什么罗盘最好_兰花用什么花盆栽植最好?

兰花用什么花盆栽植最好?高低深浅如何选?文:花木君经常有兰友咨询关于兰花的花盆的问题,诸如用浅盆还是深盆,用什么材质的花盆适宜之类,由于品种不同,兰丛大小各异,如果泛泛的回答&a…

发布到服务器接口404_接口测试怎么做?

上一期咱们讲到如何使用咱们的龙测工具实现黑盒测试这不,接口也来啦实验步骤抢先看1.首先确定接口的结构,以龙测登录为例请求方式:POSTURL:https://prod.dragontesting.com/api/login请求体:包含两个必填参…

docker ubuntu 文件同步_Docker 的数据管理--Docker从入门到精通摘记

Docker 数据管理用户在使用 Docker 的过程中,‍‍往往需要能够查看容器内应用产生的数据,‍‍或者说‍‍需要把容器内的数据进行备份,‍‍再或者说‍‍多个容器之间需要进行数据的共享,‍‍那么这些就必然涉及到容器的数据管理操作…

杂项:UN-APP

ylbtech-杂项:APP1.返回顶部 2.返回顶部3.返回顶部4.返回顶部5.返回顶部 6.返回顶部7.返回顶部8.返回顶部9.返回顶部 10.返回顶部11.返回顶部12.返回顶部13.返回顶部14.返回顶部15.返回顶部 1、https://baike.baidu.com/item/%E6%89%8B%E6%9C%BA%E8%BD%AF%E4%BB%B62…

ubuntu上网慢的问题

2019独角兽企业重金招聘Python工程师标准>>> 测试用的是ubuntu11.10,教育网宽带,静态IP,无路由 如果用的是路由的应该不会很慢吧,路由自带DNS缓存功能的,本地DNS缓存就没有必要了 建立本地DNS缓存: (1) 安装DNS缓存软件…

c include 多层目录_Rsync 秒杀一切备份工具,你能手动屏蔽某些目录吗?

转自:高效运维引言Rsync 是一种快速且通用的命令行实用程序,可通过远程shell在两个位置之间同步文件和文件夹。使用 Rsync,可以镜像数据,创建增量备份,并在系统之间复制文件。复制数据时,你可能要根据文件名…

Lucene学习笔记(1)

Lucene学习笔记可以搜索文本文件,理论上可以搜索任何类型的数据。只要先把数据转化为文本,就可以对数据进行索引和搜索。使用了反向索引的机制,维护一个词/短语的表,对于每个词和短语都有一个链表描述有哪些文档包含这个词和短语。…

android 录音原始文件_5分钟短文 | Android证书生成,签名,验证,虽然难,但学一次就够了!...

引言从Android演进开始,APK签名就已经成为Android的一部分,并且android要求所有Apks都必须先签名,然后才能将其安装在设备上。关于如何生成密钥以及如何签名的文章很多。一个Apk,但我们将从安全角度进行研究。在对Apk文件进行反编…

WCF跨域 这可能是由于试图以跨域方式访问服务而又没有正确的跨域策略,或策略不适用于 SOAP...

尝试向 URI“http://localhost:8001/AccountService.svc”发出请求时出错。这可能是由于试图以跨域方式访问服务而又没有正确的跨域策略,或策略不适用于 SOAP 服务。您可能需要与该服务的所有者联系,以发布跨域策略文件并确保该文件允许发送 SOAP 相关的…

go语言api源码中文版_Go语言学习——sync.map源码剖析

1.简介 最近看了下Sync包,详读了sync.map源码,感觉源码实现还是比较巧妙的,有不少可以学习的地方;在讲源码前,先看下sync.map的"历史",从网上搜资料,sync.map是Go语言在1.9版本才引入…

怎么成为日上会员直邮_18个日上直邮问题汇总,可以参考一下哦

前段时间发的日上直邮的微头条和视频,很多朋友遇到一些不明白的地方,我把问题汇总了一下,统一回答一下哦其实因为疫情,很多免税店都在做活动,活动方式不太一样,有好多种,我跟大家分享的只是其中…

python中sort返回值_Python函数你真的都学会了吗?来看看这篇Python高阶函数!

二、高阶函数高级函数, 英文叫 Higher-order Function.那么什么是高阶函数呢?在说明什么是高阶函数之前, 我们需要对函数再做进一步的理解!2.1 函数的本质函数的本质是什么?函数和函数名到底是一种什么关系?在python中,一切皆对象&#xff0…

基于数据库的事务消息解决分布式事务方案

转载请注明出处:http://www.cnblogs.com/lizo/p/8516502.html 概述 当单库已不能支撑当前业务的时候,我们往往都考虑进行分库(横向拆分或者纵向拆分)。但分库有个无法回避的问题,就是事务问题。网上有很多分布式事务解…