`
zcw_java
  • 浏览: 305663 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

UI圆角以及阴影等效果利用layer属性

 
阅读更多
制作圆角button等
//必须导入的空间
#import<QuartzCore/QuartzCore.h>

就拿view来举例
view.layer.masksToBounds=YES; //设置为yes,就可以使用圆角
view.layer.cornerRadius= 5; //设置它的圆角大小
view.layer.borderWidth=1; //视图的边框宽度
view.layer.borderdg= [[UIdggray  dg].CGdg]; //视图的边框颜色


制作阴影NavBar稍后附上代码

按钮从A点平滑到B点

+ (void)animateWithDuration:(NSTimeInterval)duration delay:(NSTimeInterval)delay options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_4_0);

+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_4_0); // delay = 0.0, options = 0

+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_4_0); // delay = 0.0, options = 0, completion = NULL


- (void)move
{
    __block CGRect rect = button.frame;
    
    [UIView animateWithDuration:0.5
                     animations:^{
                         //button.transform = CGAffineTransformMakeRotation(3.14);
                         button.transform = CGAffineTransformMakeTranslation(20, 20);
                     }
                     completion:^(BOOL finished){
                         rect.origin.x+=20;
                         rect.origin.y+=20;
                         button.frame = rect;
                     }];
}
- (IBAction)bkTap:(id)sender
{
    [self move];
}
//以上存在第一次有用后在不起作用,改成如下:
fOffsetX,fOffsetY表示移动的话,代码这么写就对了:
fOffsetX+=20;
fOffsetY+=20;
CGAffineTransformMakeTranslation(fOffsetX, fOffsetY);


//从上拉到下
//show
    [UIView beginAnimations:nil context:nil];
    [UIView setAnimationDuration:0.5];
    //显示tableview时,展开当前view
    self.frame = CGRectMake(90, 122, 210,28);
    m_tableViewDownList.frame = CGRectMake(0, 28, self.frame.size.width, nHeight);
    [UIView commitAnimations];
//hide
    [UIView beginAnimations:nil context:nil];
    [UIView setAnimationDuration:0.5];
    self.frame =CGRectMake(90, 122, 210,28);
    m_tableViewDownList.frame = CGRectMake(0, 28, self.frame.size.width, 0);
    [UIView commitAnimations];

//加入动画淡入淡出
[UIView animateWithDuration:1.0 animations:^{
        m_tableViewDownList.alpha = 0.0;
        m_tableViewDownList.alpha = 1.0;
    }];
分享到:
评论

相关推荐

    IOS圆角和阴影处理

    总结,iOS中的圆角和阴影处理是通过`CALayer`属性实现的,通过设置`cornerRadius`、`shadow*`属性,以及优化策略,可以创建出美观且性能良好的界面效果。实践中,结合具体的代码示例和图片,能更好地帮助开发者理解...

    IOS控件阴影和圆角

    在iOS开发中,UI设计往往追求精致和细腻,其中控件的圆角和阴影效果是提升界面质感的重要手段。本文将深入探讨如何在iOS中实现控件(如UILabel)的圆角和阴影效果,并通过一个具体的例子来阐述相关知识点。 首先,...

    ios-TableviewGroup阴影加圆角.zip

    在这个子类中,我们可以重写`layoutSubviews`方法,设置视图的layer属性,包括`cornerRadius`来实现圆角效果。例如: ```swift override func layoutSubviews() { super.layoutSubviews() layer.cornerRadius = ...

    自定义圆角图片Demo

    在实际项目中,我们可能还需要考虑其他因素,比如图片的边框、阴影效果等。这些可以通过增加额外的绘制步骤来实现,比如在绘制圆角之前先绘制一个带有圆角的矩形边框,或者使用layer-list作为Drawable来添加阴影效果...

    通过一行代码即可实现阴影效果.zip

    这个开源项目可能利用了`layer-list`、`shape`以及`NinePatch`等Drawable资源来构造阴影。`layer-list`可以将多个Drawable堆叠起来,通过调整它们的顺序和透明度,模拟出阴影效果。`shape`则可以用来定义各种形状的...

    Android编程使用自定义shape实现shadow阴影效果的方法

    阴影层(SHADOW LAYER)的`&lt;shape&gt;`设置了深色透明度(#66000000,即60%不透明的黑色),并调整了位置(通过`android:left`和`android:top`属性),模拟了阴影效果。同时,`&lt;corners&gt;`标签用于设置圆角,让阴影看...

    Android 给控件添加边框阴影效果

    除了使用`layer-list`,Android还提供了其他方法来实现控件的阴影效果,如`CardView`组件自带的阴影效果,或者利用`Paint`对象的`setShadowLayer()`方法在自定义视图中绘制阴影。然而,使用XML drawable的方式简单且...

    swift-XYRoundedCorner-异步渲染圆角避免离屏渲染

    这个库还可能包含一些高级特性,如自定义阴影、动画效果等,以满足更复杂的设计需求。同时,由于它是异步的,所以需要注意线程安全问题,避免在渲染过程中对视图进行其他修改。 总的来说,XYRoundedCorner是一个...

    Android实现万能自定义阴影控件实例代码

    设置阴影需要注意几个属性,包括阴影的宽度、view 到 ViewGroup 的距离、视图自带的圆角等。如果视图和父布局一样大的话,那阴影就不好显示,需要设置 clipChildren=false。视图自带的圆角需要达到高度还原阴影的...

    swift-ZHCornerRadius一句话设置图片圆角高性能避免离屏渲染畅享丝滑

    在使用ZHCornerRadius时,要注意的是,虽然库提供了便利的API,但在特定场景下,如需要自定义阴影效果或者复杂的图层组合时,可能还需要结合其他技术进行调整。此外,对于内存管理也需要留意,确保不会因为过多的...

    实现给界面视图添加圆角的效果

    这种方法的优点是可以处理渐变背景、图片背景以及阴影等效果。 在提供的"TKRoundedView"源码中,开发者可能已经实现了这样一个自定义视图。通常,自定义视图会包含以下步骤: 1. 创建一个新的`UIView`子类,例如`...

    UI相关面试题1

    UI的异步绘制可以通过layer的代理方法`displayLayer:`实现,由代理生成对应的位图并设置为layer的contents属性,这样可以在后台线程进行,避免阻塞主线程。 七、离屏渲染 离屏渲染发生在GPU不在当前屏幕缓冲区中...

    ios-主要的银行卡类型 显示 背景色.zip

    2. **圆角和阴影效果**:为了提升视觉效果,银行卡视图的边角通常会被设计为圆角,这可以通过设置`layer.cornerRadius`属性来实现。同时,添加阴影可以增加立体感,使用`layer.shadowColor`, `layer.shadowOpacity`,...

    阴影视图 偶尔

    "阴影视图 偶尔"是一个由作者YotrolZ开发的开源项目,名为YCShadowView,它提供了一种极度简便的方式来设置视图的四周圆角、单个圆角,以及各种阴影效果,如四周阴影、单边阴影、上下阴影和左右阴影。这个库的目标是...

    多种样式的无背景图片的按钮效果_IOS应用源码.rar

    通过调整其属性,我们可以定制按钮的外观和行为,包括字体、颜色、边框、阴影等。 在本源码中,重点在于实现无背景图片的按钮效果。这通常意味着开发者需要通过纯色、渐变色或者自定义形状来替代传统的背景图片,以...

    UILabdel自定义

    3. **边框样式**:为了创建自定义边框,我们可以利用UILabel的`layer`属性,设置`borderWidth`和`borderColor`。同时,还可以通过`cornerRadius`来实现圆角效果。 4. **动画效果**:利用Core Animation,我们可以为...

    各种Button 制作实例 (苹果风格,……)

    苹果风格的按钮通常具有鲜明的质感和阴影效果,这可以通过设置按钮的背景色、边框、圆角以及高亮状态来实现。例如,我们可以使用`UIButton`类的`backgroundColor`属性设置背景颜色,`layer.cornerRadius`设置圆角,`...

    iOS开发中CALayer使用的基本教程

    在iOS开发中,CALayer是Core Animation框架的核心组成部分,它负责UI元素的渲染和动画效果。CALayer并不属于UIKit框架,而是包含在QuartzCore框架内,因此它具有跨平台的特性,适用于iOS和Mac OS X。CALayer是UIView...

    多种颜色和样式的按钮(未使用图片作背景的)_IOS应用源码.rar

    它允许开发者设置文字、图像、边框、阴影等属性,以创建各种各样的按钮样式。在这个源码中,我们将看到如何利用UIButton的自定义属性来创建多彩的按钮。 2. 自定义外观: 按钮的外观可以通过修改其标题颜色、背景...

Global site tag (gtag.js) - Google Analytics