`

UIView总结

 
阅读更多

如果想调用某个类的某个方法可以写成这样,这个方法来自NSObject类

 

performSelector:
performSelector:withObject:
performSelector:withObject:withObject:

 实际调用

 

[self performSelector:@selector(displayViews) withObject:nil afterDelay:1.0f];

  有三个方法分别是

 

//父视图 
[self.view superview]
//所有子视图
 [self.view subviews]
//自身的window
 self.view.window

循环一个视图下面所有视图的方法

 

NSArray *allSubviews(UIView *aView)
{
	NSArray *results = [aView subviews];
	for (UIView *eachView in [aView subviews])
	{
		NSArray *riz = allSubviews(eachView);
		if (riz) {
			results = [results arrayByAddingObjectsFromArray:riz];
		}
	}
	return results;
}

循环返回一个APPLICATION里面所有的VIEW

 

// Return all views throughout the application
NSArray *allApplicationViews()
{
    NSArray *results = [[UIApplication sharedApplication] windows];
    for (UIWindow *window in [[UIApplication sharedApplication] windows])
	{
		NSArray *riz = allSubviews(window);
        if (riz) results = [results arrayByAddingObjectsFromArray: riz];
	}
    return results;
}
 

 找出所有的父视图

 

// Return an array of parent views from the window down to the view
NSArray *pathToView(UIView *aView)
{
    NSMutableArray *array = [NSMutableArray arrayWithObject:aView];
    UIView *view = aView;
    UIWindow *window = aView.window;
    while (view != window)
    {
        view = [view superview];
        [array insertObject:view atIndex:0];
    }
    return array;
}

UIView提供了大量管理视图的方法

 

//加一个视图到一个视图里面
addSubview:
//将一个视图移到前面
bringSubviewToFront:
//将一个视图推送到背后
sendSubviewToBack:
//把视图移除
removeFromSuperview
//插入视图 并指定索引
insertSubview:atIndex:
//插入视图在某个视图之上
insertSubview:aboveSubview:
//插入视图在某个视图之下
insertSubview:belowSubview:
//交换两个位置索引的视图
exchangeSubviewAtIndex:withSubviewAtIndex:

视图回调

 

//当加入视图完成后调用
(void)didAddSubview:(UIView *)subview
//当视图移动完成后调用
(void)didMoveToSuperview
//当视图移动到新的WINDOW后调用
(void)didMoveToWindow
//在删除视图之后调用
(void)willRemoveSubview:(UIView *)subview
//当移动视图之前调用
(void)didMoveToSuperview:(UIView *)subview
//当视图移动到WINDOW之前调用
(void)didMoveToWindow

 给UIView设置标记和检索视图

 

myview.tag = 1001;
[self.view viewWithTag:1001];
(UILable *)[self.view.window viewWithTag:1001];

视图的几何特征

 

//框架
struct CGPoint {
  CGFloat x;
  CGFloat y;
};
typedef struct CGPoint CGPoint;

/* Sizes. */

struct CGSize {
  CGFloat width;
  CGFloat height;
};
typedef struct CGSize CGSize;

struct CGRect {
  CGPoint origin;
  CGSize size;
};
typedef struct CGRect CGRect;



CGRect rect = CGRectMake(0,0,320,480);
UIView *view = [[UIView allow]initWithFrame:rect];

//将String转成CGPoint 如 @”{3.0,2.5}”    {x,y}
CGPoint CGPointFromString (
   NSString *string
);

//将String转成CGRect  @”{{3,2},{4,5}}”  {{x,y},{w, h}}
CGRect CGRectFromString (
   NSString *string
);

//将String转成CGSize @”{3.0,2.5}” {w, h}
CGSize CGSizeFromString (
   NSString *string
);

//CGPoint转成NSString
NSString * NSStringFromCGPoint (
   CGPoint point
);

//CGRect转成NSString
NSString * NSStringFromCGRect (
   CGRect rect
);

//CGSize转成NSString
NSString * NSStringFromCGSize (
   CGSize size
);

//对一个CGRect进行修改 以这个的中心来修改 正数表示更小(缩小) 负数表示更大(放大)
CGRect CGRectInset (
   CGRect rect,
   CGFloat dx,
   CGFloat dy
);

//判断两个矩形是否相交
bool CGRectIntersectsRect (
   CGRect rect1,
   CGRect rect2
);

//初始为0的
const CGPoint CGPointZero;
const CGRect CGRectZero;
const CGSize CGSizeZero;

//创建CGPoint
CGPoint CGPointMake (
   CGFloat x,
   CGFloat y
);
//创建CGRect
CGRect CGRectMake (
   CGFloat x,
   CGFloat y,
   CGFloat width,
   CGFloat height
);
//创建CGSize
CGSize CGSizeMake (
   CGFloat width,
   CGFloat height
);

仿射变换

 

CGAffineTransform form = CGAffineTransformMakeRotation(PI);
myview.transform = form;

如想复原

 

myview.transform = CGAffineTransformIdentity;

 直接设置视图的中心

 

myview.center = CGPointMake(100,200);

 中心

 

CGRectGetMinX
CGRectGetMinY
//X的中间值
CGRectGetMidX
//Y的中间值
CGRectGetMidY
CGRectGetMaxX
CGRectGetMaxY

  定时器

 

NSTime *timer = [NSTimer scheduledTimerWithTimeInterval:0.1f target:self selector:@selector(move:) userInfo:nil repeats:YES];

  定义视图边界

typedef struct UIEdgeInsets {
    CGFloat top, left, bottom, right;  // specify amount to inset (positive) for each of the edges. values can be negative to 'outset'
} UIEdgeInsets;
//eg
UIEdgeInsets insets = UIEdgeInsetsMake(5, 5, 5, 5);
CGRect innerRect = UIEdgeInsetsInsetRect([aView bounds], insets);
CGRect subRect = CGRectInset(innerRect, self.frame.size.width / 2.0f, self.frame.size.height / 2.0f);

仿射变换补充

//创建CGAffineTransform

//angle 在0-2*PI之间比较好  旋转
CGAffineTransform transform = CGAffineTransformMakeRotation(angle);
//缩放 
CGAffineTransform transform = CGAffineTransformMakeScale(0.5f,0.5f);
//改变位置的
CGAffineTransform transform = CGAffineTransformMakeTranslation(50,60);

//修改CGAffineTransform
//修改 缩放 
CGAffineTransform scaled = CGAffineTransformScale(transform, degree, degree);
//修改 位置
CGAffineTransform transform = CGAffineTransformTranslate(
   CGAffineTransform t,
   CGFloat tx,
   CGFloat ty
);

//修改角度 
CGAffineTransform transform = CGAffineTransformRotate (
   CGAffineTransform t,
   CGFloat angle
);
//最后设置到VIEW
 [self.view setTransform:scaled];
 

建立UIView动画块

   //首先建立CGContextRef

CGContextRef context = UIGraphicsGetCurrentContext();
//标记动画开始
[UIView beginAnimations:nil context:context];
//定义动画加速或减速的方式
[UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];
//定义动画的时长 1秒
[UIView setAnimationDuration:1.0];
//中间处理 位置变化,大小变化,旋转,等等的
[[self.view viewWithTag:999] setAlpha:1.0f];
//标志动画块结束
[UIView commitAnimations];
//还可以设置回调
[UIView setAnimationDelegate:self];
//设置回调调用的方法
[UIView setAnimationDidStopSelector:@selector(animationFinished:)];

  视图翻转

 

UIView *whiteBackdrop = [self.view viewWithTag:100];
// Choose left or right flip 选择左或右翻转
if ([(UISegmentedControl *)self.navigationItem.titleView selectedSegmentIndex]){
[UIView setAnimationTransition: UIViewAnimationTransitionFlipFromLeft forView:whiteBackdrop cache:YES];
}else{
[UIView setAnimationTransition: UIViewAnimationTransitionFlipFromRight forView:whiteBackdrop cache:YES];
}
	NSInteger purple = [[whiteBackdrop subviews] indexOfObject:[whiteBackdrop viewWithTag:999]];
	NSInteger maroon = [[whiteBackdrop subviews] indexOfObject:[whiteBackdrop viewWithTag:998]];
//交换视图
	[whiteBackdrop exchangeSubviewAtIndex:purple withSubviewAtIndex:maroon];

//还有上翻和下翻两种 如下
typedef enum {
//没有任何效果
    UIViewAnimationTransitionNone,
    UIViewAnimationTransitionFlipFromLeft,
    UIViewAnimationTransitionFlipFromRight,
    UIViewAnimationTransitionCurlUp,
    UIViewAnimationTransitionCurlDown,
} UIViewAnimationTransition;

  使用QuartzCore做动画

 

//创建CATransition
CATransition *animation = [CATransition animation];
//设置代理
animation.delegate = self;
//设置动画过渡的时间
animation.duration = 4.0f;
//定义动画加速或减速的方式 
animation.timingFunction = UIViewAnimationCurveEaseInOut;
//animation.type 表示设置过渡的种类 如 Fade,MoveIn,Push,Reveal
switch ([(UISegmentedControl *)self.navigationItem.titleView selectedSegmentIndex]) {
		case 0:
			animation.type = kCATransitionFade;
			break;
		case 1:
			animation.type = kCATransitionMoveIn;
			break;
		case 2:
			animation.type = kCATransitionPush;
			break;
		case 3:
			animation.type = kCATransitionReveal;
		default:
			break;
	}
//设置渐变的方向,上下左右
	if (isLeft)
		animation.subtype = kCATransitionFromRight;
	else
		animation.subtype = kCATransitionFromLeft;

// Perform the animation
	UIView *whitebg = [self.view viewWithTag:10];
	NSInteger purple = [[whitebg subviews] indexOfObject:[whitebg viewWithTag:99]];
	NSInteger white = [[whitebg subviews] indexOfObject:[whitebg viewWithTag:100]];
	[whitebg exchangeSubviewAtIndex:purple withSubviewAtIndex:white];
	[[whitebg layer] addAnimation:animation forKey:@"animation"];
 

animation.type还可以用以下的赋值

 

switch (theButton.tag) {  
        case 0:  
            animation.type = @"cube";  
            break;  
        case 1:  
            animation.type = @"suckEffect";  
            break;  
        case 2:  
            animation.type = @"oglFlip";  
            break;  
        case 3:  
            animation.type = @"rippleEffect";  
            break;  
        case 4:  
            animation.type = @"pageCurl";  
            break;  
        case 5:  
            animation.type = @"pageUnCurl";  
            break;  
        case 6:  
            animation.type = @"cameraIrisHollowOpen ";  
            break;  
        case 7:  
            animation.type = @"cameraIrisHollowClose ";  
            break;  
        default:  
            break;  
    }  

  上面这个是转自这里的http://2015.iteye.com/blog/1122130

休眠一下

 

[NSThread sleepUntilDate:[NSDate dateWithTimeIntervalSinceNow:1.0f]];
 

一个简单的通过图片做的动画

 

	// Load butterfly images
	NSMutableArray *bflies = [NSMutableArray array];
	for (int i = 1; i <= 17; i++){
		[bflies addObject:[UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:[NSString stringWithFormat:@"bf_%d", i] ofType:@"png"]]];
	}
	UIImageView *butterflyView = [[UIImageView alloc] initWithFrame:CGRectMake(40.0f, 300.0f, 60.0f, 60.0f)];
	butterflyView.tag = 300;
        //设置动画的图片
	butterflyView.animationImages = bflies;
        //设置时间
	butterflyView.animationDuration = 0.75f;
	[self.view addSubview:butterflyView];
        //开始动画
	[butterflyView startAnimating];
	[butterflyView release];
 

 

预留

预留

预留

预留

预留

预留

分享到:
评论
1 楼 云端月影 2015-08-26  
       mark

相关推荐

    UIView镂空

    总结来说,"UIView镂空"是iOS开发中的一个重要技巧,通过巧妙地运用遮罩层和图形路径,可以创造出富有创意和个性化的UI设计。而项目链接中的“MFSubtractMask”可能是一个实际的示例,展示了如何在实践中应用这些...

    UIView+Utils

    总结来说,`UIView+Utils`是对`UIView`类的扩展,提供了获取和操作视图尺寸的便利方法,以及与布局、动画相关的辅助功能,大大提升了iOS开发的效率。在使用时,开发者只需引入相应的库,就可以轻松调用这些方法,...

    绘制UIView

    总结一下,这个"绘制UIView"的示例主要涵盖了以下知识点: 1. `UIView`的自定义绘图方法`draw(_ rect: CGRect)` 2. Core Graphics中的`CGContext`和`UIBezierPath` 3. 使用`UIBezierPath`创建圆弧路径 4. 视图的...

    自定义UIView子类

    总结: 通过上述步骤,我们可以轻松创建并使用自定义的UIView子类,利用XIB进行界面设计和布局,使得代码与界面分离,更易于维护。这种技术在实际开发中非常常见,尤其在需要复用或者复杂界面设计时,能够大大提高...

    iOS UIView

    #### 八、总结 `UIView`作为iOS开发中的基石之一,其重要性不言而喻。通过本文对`UIView`的基本概念、关键属性与方法、生命周期、事件处理以及动画等方面的介绍,相信读者已经对其有了更深入的理解。在未来的学习和...

    动画之CAAnimation和UIView

    总结来说,CAAnimation和UIView动画都是iOS开发中不可或缺的工具,它们共同构建了强大的动画系统。理解并熟练掌握这两种方式,将有助于你创造出更具吸引力的用户界面。通过"CAAnimationDemo"和"UIView_animate"这两...

    动画1-UIView动画

    总结来说,`UIView`动画是iOS开发者手中的强大工具,能够轻松实现各种视图动画效果,提升应用的视觉吸引力。在Xcode 6和simulator-iPhone 6上,开发者可以利用这些功能为用户创造流畅、引人入胜的交互体验。通过不断...

    使用NIB父类来创建UIVIEW

    在iOS开发中,UI设计和...总结一下,使用NIB文件作为`UIView`的父类,能够使我们的代码更加整洁,UI设计更为直观,同时也提高了代码的可复用性和维护性。这种方法在实际开发中被广泛应用,是iOS开发中的一种重要技巧。

    iOS UIView类 UIViewExt工具

    总结来说,`UIViewExt`工具类是iOS开发中的实用工具,通过扩展`UIView`类提供了丰富的便捷属性,使得获取和操作视图的坐标、尺寸等属性变得更加简单和直观,同时提高了代码的可读性和开发效率。在使用时,我们需要...

    uiview增删查数据

    总结来说,"uiview增删查数据"涵盖了数据模型的设计、数据源管理、视图的动态更新以及交互事件处理等多个方面,这些都是iOS开发中常见的实践技能。正确实现这些功能,可以使应用具有良好的用户体验并有效处理大量...

    oc和swift UIView类扩展画虚线外边框

    总结起来,为`UIView`扩展虚线外边框功能,可以提高代码的复用性和灵活性。无论是Objective-C还是Swift,都可以通过类扩展的方式轻松实现这一功能,使得在项目中添加虚线边框变得简单快捷。在实际开发中,根据需求还...

    一个在iOS中检测UIView (UIView的曝光)印象事件的工具。SwiftUI支持.zip

    总结起来,`ImpressionKit`是一个强大的工具,它使开发者能够轻松地在iOS应用中追踪和分析用户对UI元素的曝光情况。通过集成`ImpressionKit`,开发者可以获取宝贵的用户行为数据,进一步优化SwiftUI构建的界面,提升...

    Swift 2.1 为 UIView 添加点击事件和点击效果

    总结来说,通过上述方法,我们可以让`UIView`不仅能够响应点击事件,还能提供视觉反馈,增强用户体验。这在没有使用`UIButton`的场景下尤其有用,比如自定义复杂的布局或者需要定制化交互效果时。在实际开发中,可以...

    swift-一行代码画一个表格UIView分类可以很简单的画excel表格

    总结来说,通过给UIView添加分类并实现画表格的方法,可以简化在Swift应用中创建简单表格的过程,使代码更简洁,开发效率更高。在实际项目中,可以根据需求选择合适的方式来实现表格功能,平衡易用性和功能复杂度。

    swift-JMRoundedCorner-UIView设置不触发离屏渲染的圆角

    总结来说,`JMRoundedCorner`是一个针对Swift的UI控件库,旨在解决`UIView`设置圆角时可能导致的离屏渲染问题。通过自定义绘制流程,它提供了一种无离屏渲染的圆角解决方案,提高了应用性能和用户体验。对于那些重视...

    iOS中UIView实现不同方向的导角

    总结起来,iOS提供了多种方式来实现UIView不同方向的导角。对于新版本的iOS,可以直接使用`maskedCorners`属性;而对于老版本,可以利用`CAShapeLayer`和`UIBezierPath`进行自定义绘制。理解并掌握这些方法,将使你...

    swift-SnapTimer定制UIView模仿Snapchat'sstories定时器效果

    总结来说,Swift开发中的SnapTimer库通过自定义UIView和利用Core Animation、GCD实现了模仿Snapchat stories定时器的功能。它提供了一个可定制、易于集成的解决方案,使得开发者可以在自己的应用中轻松添加这种常见...

    UIView视图切换

    总结一下,实现简单的视图切换,你需要理解`UIViewController`的生命周期,掌握模态切换和导航栈切换的方法,并能够利用`UIToolbar`来创建用户交互。在实际项目中,还可以考虑使用`UIStoryboardSegue`进行界面间的...

    详解iOS开发中的转场动画和组动画以及UIView封装动画

    总结来说,iOS开发中的转场动画和组动画提供了丰富的视图切换和复合动画效果,而UIView封装的动画则简化了日常开发中的动画实现。理解并熟练运用这些动画技术,能极大地提升应用的用户体验和视觉吸引力。

    iOS应用开发中UIView添加边框颜色及设置圆角边框的方法

    总结一下,要在Objective-C中为UIView添加边框颜色和设置圆角边框,需要进行以下步骤: 1. 引入`QuartzCore`框架,导入`#import &lt;QuartzCore/QuartzCore.h&gt;`。 2. 创建或获取要修改的UIView实例。 3. 通过`layer....

Global site tag (gtag.js) - Google Analytics