CAlayer一

//
//  ViewController.m
//  Layer
//
//  Created by City--Online on 15/4/9.
//  Copyright (c) 2015年 City--Online. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    UIButton *btn=[UIButton buttonWithType:UIButtonTypeSystem];
    btn.frame=CGRectMake(150, 250, 50, 80);
    [btn setTitle:@"按钮" forState:UIControlStateNormal];
    [btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
    [btn addTarget:self action:@selector(btnclick:) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn];

    //图层属性
    self.myview=[[UIView alloc]init];
    self.myview.frame=CGRectMake(100, 100, 100, 100);
    //设置背景色
    self.myview.layer.backgroundColor=[UIColor redColor].CGColor;
    //设置边框宽度
    self.myview.layer.borderWidth=5;
    //设置圆角
    self.myview.layer.cornerRadius=20;
    //设置透明度
    self.myview.layer.opacity=0.9;
    //设置内容 id类型
    self.myview.layer.contents=(id)[UIImage imageNamed:@"test.jpg"].CGImage;
    //设置边框颜色
    self.myview.layer.borderColor=[UIColor greenColor].CGColor;
    //设置超过自图层的部分剪掉,否则设置圆角后contents中图片的四个角的部分还会显示出来 当设置此属性为yes时,阴影看不到
    self.myview.layer.masksToBounds=YES;
    //设置阴影颜色
    self.myview.layer.shadowColor=[UIColor blackColor].CGColor;
    // 设置阴影偏移量 width正往右 height正往下
    self.myview.layer.shadowOffset=CGSizeMake(5, 15);
    //设置阴影透明度 默认0
    self.myview.layer.shadowOpacity=1.0;
    [self.view addSubview:self.myview];

    //图层创建
    CALayer *calayer=[[CALayer alloc]init];

//    calayer.frame=CGRectMake(220, 100, 100, 100);
    calayer.bounds=CGRectMake(0, 0, 100, 100);
    calayer.position=CGPointMake(260, 150);
    calayer.backgroundColor=[UIColor redColor].CGColor;
    calayer.contents=(id)[UIImage imageNamed:@"test.jpg"].CGImage;
    calayer.masksToBounds=YES;
    calayer.cornerRadius=20;
    calayer.borderWidth=5;
    [self.view.layer addSublayer:calayer];

}
-(void)btnclick:(id)sender
{
    //有时候UIView和CALayer都能解决同样的问题,UIView和CAlayer用什么比较好?
    //UIView继承UIResponder,可以响应用户事件,CAlayer的话是没继承UIResponder,没有响应,CAlayer是轻量的
    //2d旋转变化
//    self.myview.transform=CGAffineTransformMakeTranslation(100, 100);//UIView变化
//    self.myview.layer.affineTransform=CGAffineTransformMakeTranslation(100, 100);//clayer变换
//
//    self.myview.layer.transform=CATransform3DMakeScale(2,2,0);//缩放
//    self.myview.layer.transform=CATransform3DMakeTranslation(20,20,0);//平移
//    self.myview.layer.transform=CATransform3DMakeRotation(3.1415926, 1, 1, 0.5);//旋转
    //kvox  设置
    NSValue *v=[NSValue valueWithCATransform3D:CATransform3DMakeTranslation(100, 20, 0)];
    [self.myview.layer setValue:v forKeyPath:@"transform"];
//    如果是只需要设置在某一个方向上的移动,可以参考下面的代码
//    [self.myview.layer setValue:@(-100) forKeyPath:@"transform.translation.x"];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end
时间: 2024-12-09 10:33:07

CAlayer一的相关文章

实现UIView的无限旋转动画(非CALayer动画)

实现UIView的无限旋转动画(非CALayer动画) 效果: 素材: 源码: // // ViewController.m // Animation // // Created by YouXianMing on 15/2/5. // Copyright (c) 2015年 YouXianMing. All rights reserved. // #import "ViewController.h" @interface ViewController () @property (no

CALayer动画的暂停,恢复,以及结束时候的回调

CALayer动画的暂停,恢复,以及结束时候的回调 源码如下: // // ViewController.m // AnimationLineView // // Created by YouXianMing on 14/11/7. // Copyright (c) 2014年 YouXianMing. All rights reserved. // #import "ViewController.h" #import "YXGCD.h" @interface Vi

变换CALayer锚点实现模拟时钟的动画

变换CALayer锚点实现模拟时钟的动画   变换锚点得需要一点理论知识,看下图就能明白:). https://developer.apple.com/library/ios/documentation/Cocoa/Conceptual/CoreAnimation_guide/CoreAnimationBasics/CoreAnimationBasics.html#//apple_ref/doc/uid/TP40004514-CH2-SW15 开始实现模拟时钟效果: // // RootView

iOS开发之CALayer

1.概述 在iOS中,你能看得见摸得着的东西基本上都是UIView,比如一个按钮.一个文本标签.一个文本输入框.一个图标等等,这些都是UIView,其实UIView之所以能显示在屏幕上,完全是因为它内部的一个图层,在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性可以访问这个层: ? 1 @property(nonatomic,readonly,retain) CALayer *layer; 当UIView需要显示到屏幕上时,会

用CALayer实现下载进度条

用CALayer实现下载进度条 效果: 源码: // // ViewController.m // ProgressView // // Created by YouXianMing on 14/11/18. // Copyright (c) 2014年 YouXianMing. All rights reserved. // #import "ViewController.h" @interface ViewController () @property (nonatomic, st

暂停、恢复CALayer 动画

CALayer都是实现了CAMediaTiming协议(或者叫做接口).所以layer的动画有一个很有意思的属性speed.如果一个layer的动画速度变成0.0的时候,很显然这个动画就不再动了.设置layer的speed为0时,layer的动画暂停.speed属性设置为任意大于0的值时,动画回复. 要暂停一个动画时: -(void)pauseLayer:(CALayer*)layer { CFTimeInterval pausedTime = [layer convertTime:CACurr

CALayer(持续更新)

CALayer The CALayer class manages image-based content and allows you to perform animations on that content. Layers are often used to provide the backing store for views but can also be used without a view to display content. A layer's main job is to

CALayer的additive属性解析

CALayer的additive属性解析 效果: 源码:https://github.com/RylanJIN/ShareOfCoreAnimation // // CAPartAViewController.m // ShareOfCoreAnimation // // Created by xjin on 8/8/14. // Copyright (c) 2014 ArcSoft. All rights reserved. // #import "CAPartAViewController.

iOS开发CoreAnimation解读之二——对CALayer的分析

iOS开发CoreAnimation解读之二--对CALayer的分析 一.UIView中的CALayer属性 1.Layer专门负责view的视图渲染         每一个UIView的对象中都有一个layer这样的属性,并且layer会负责view中有关图形绘制的相关操作,例如我们设置view的背景颜色和设置layer的背景颜色都是有效的,并且,设置view的背景色依然是通过layer来展示的,我们可以写如下的测试代码: ? 1 2 3 4 5 6 7     UIView * view