【UIKit-124-2】#import <UIKit/UIView.h>

本文深入探讨了Swift编程语言在iOS应用开发中的应用,重点讲解了如何利用自动布局实现界面的灵活调整,并通过视图层级管理优化用户体验。文章还介绍了如何通过代码实现子视图的添加、移除、交换操作,以及如何通过视图的tag属性快速定位特定控件。此外,还详细阐述了视图的重写与将要触发的事件回调机制,以及如何判断一个视图是否为当前视图的子视图。最后,文章提供了实例代码,帮助开发者更好地理解和实践这些高级视图管理技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


【层级关系】

@interface UIView(UIViewHierarchy)


@property(nonatomic,readonly) UIView       *superview;

@property(nonatomic,readonly,copy) NSArray *subviews;//遍历控件用

@property(nonatomic,readonly) UIWindow     *window;

    NSArray *views = self.view.subviews;
    
    for (NSInteger ii = 0; ii < views.count; ii++) {
        if ([[views objectAtIndex:ii] isKindOfClass:[UIButton class]]) {
                UIButton *btn = (UIButton *)[views objectAtIndex:ii];
            [btn addTarget:self action:@selector(btnAction) forControlEvents:UIControlEventTouchUpInside];
            
        }
        
    }



【添加,移除,交换层级】

- (void)removeFromSuperview;//移除

- (void)insertSubview:(UIView *)view atIndex:(NSInteger)index;//在。。位置插入

- (void)exchangeSubviewAtIndex:(NSInteger)index1 withSubviewAtIndex:(NSInteger)index2;//交换


- (void)addSubview:(UIView *)view;//添加

- (void)insertSubview:(UIView *)view belowSubview:(UIView *)siblingSubview;//在。。下面插入

- (void)insertSubview:(UIView *)view aboveSubview:(UIView *)siblingSubview;//在。。上面插入


- (void)bringSubviewToFront:(UIView *)view;//移到最顶层

- (void)sendSubviewToBack:(UIView *)view;//置于最底层

-(void)soeasy{
<span style="white-space:pre">	</span>NSLog("不写了");
}




【重写已经,将要】

- (void)didAddSubview:(UIView *)subview;//已经添加子视图

- (void)willRemoveSubview:(UIView *)subview;//将要移除子视图


- (void)willMoveToSuperview:(UIView *)newSuperview;//将要添加到父视图

- (void)didMoveToSuperview;//已经添加到父视图

- (void)willMoveToWindow:(UIWindow *)newWindow;//将要展示到屏幕

- (void)didMoveToWindow;//已经展示到屏幕

-(void)didAddSubview:(UIView *)subview{
    NSLog(@"3didAddSubview");
    
}
-(void)willRemoveSubview:(UIView *)subview{
    NSLog(@"willRemoveSubview");
    
}
- (void)willMoveToSuperview:(UIView *)newSuperview{
    NSLog(@"1willMoveToSuperview");

}
- (void)didMoveToSuperview{
    NSLog(@"2didMoveToSuperview");

}

- (void)willMoveToWindow:(UIWindow *)newWindow{
    NSLog(@"4willMoveToWindow");

}
- (void)didMoveToWindow{
    NSLog(@"5didMoveToWindow");

}




【判断是否是子视图,tag后去视图】

- (BOOL)isDescendantOfView:(UIView *)view; //判断view是否是自己否控件

    
    greenView = [[UIView alloc]initWithFrame:CGRectMake(100, 200, 100, 100)];
    greenView.backgroundColor = [UIColor greenColor];
    [self.view addSubview:greenView];
    

    if ([greenView isDescendantOfView:self.view]) {
        NSLog(@"yes");
    }



- (UIView *)viewWithTag:(NSInteger)tag;     //通过tag,获取控件

    UIButton *button = [UIButton buttonWithType:UIButtonTypeSystem];
    [button setFrame:CGRectMake(111, 111, 111, 111)];
    button.backgroundColor = [UIColor purpleColor];
    button.tag = 1000;
    [self.view addSubview:button];
    
    
    //通过tag 获取UIView,转换成UIButton,
    UIButton *btn = (UIButton *)[self.view viewWithTag:1000];
    [btn addTarget:self action:@selector(btnAction) forControlEvents:UIControlEventTouchUpInside];
    
    






【自动布局,重新布局】

- (void)setNeedsLayout;//标记需要重新布局

- (void)layoutIfNeeded;//重新布局

- (void)layoutSubviews;// 重新布局

    //假设blueView 是通过自动布局,先标记,在布局。
    
    [blueView setNeedsLayout];
    [blueView layoutIfNeeded];
    





@end

### 导入 UIKit 框架的方法 对于Objective-C项目,在源文件顶部通过预处理器指令来引入UIKit头文件,使用如下语句: ```objective-c #import <UIKit/UIKit.h> ``` 此方式确保了编译器能够识别并链接UIKit中的类和方法[^3]。 而对于Swift项目,则不需要显式地导入UIKit框架;当创建一个新的Swift文件时,默认情况下Xcode会自动处理好必要的模块导入工作。不过如果是在桥接头文件或者其他特殊场景下需要手动指定的话,可以采用`@import UIKit;`这样的语法形式完成相同目的的操作[^1]。 一旦完成了上述任一操作之后,就可以自由访问UIKit所提供的API集合,比如构建用户界面组件或是利用其内置的功能特性等。 ### 创建 UIView 的实例展示 下面给出了一段基于Objective-C语言的具体代码片段用来说明怎样借助于已经成功加载的UIKit库去建立一个简单的UIView对象,并调整它的外观样式以及将其呈现给最终使用者查看: ```objective-c // 开辟空间创建UIView对象 UIView *view = [[UIView alloc]initWithFrame:CGRectMake(100, 100, 100, 100)]; // 设置UIView对象的属性:设置背景颜色 view.backgroundColor = [UIColor redColor]; // 将创建好的UIView对象添加到Window上显示 [self.window addSubview:view]; ``` 这段代码展示了如何初始化一个矩形区域内的视图元素,设定其位置尺寸参数,改变视觉效果(这里指定了红色作为填充色),最后把它附加到了应用程序顶层容器之中以便可见[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值