Today I would like to share with you an advanced knowledge of iOS
UIVIew is a view object in iOS, the base class for everything that’s on the screen, and everything that’s on the screen has to be inherited from UIVIew.
Everything you see on screen is a subclass of UIView, which is a rectangular object, it has a background color, it can be displayed, it has
hierarchy
On the first code
// // viewController.m // UIView // // Created by Cheerful Man on 2018/7/20. // Copyright © 2018 Cheerful Man. All rights reserved. // #import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, Typically, UIView is the view object in iOS. // All objects displayed on the screen are the basic class. // All objects displayed on the screen must inherit from UIView UIView * view = [[UIView alloc] init]; UIView * view = [[UIView alloc] init]; UIView * view = [UIView alloc] init]; View. frame = CGRectMake(130, 150, 150, 150); // set the backgroundColor of the view instance view.backgroundColor = [UIColor orangeColor]; // add the new view to the superview //1: display the new view on the screen //2: manage the view as a child of the superview [self.view addSubview: view]; // Whether to hide the view object //YES: do not show //NO: show, the default value is displayview. hidden = NO; Alpha = 1, 0, 0.5 view.alpha = 0.5; / / set the background color of the view of self. The backgroundColor = [UIColor yellowColor]; // delete from the superview //1: delete from the superview management //2: do not show on the screen //[view removeFromSuperview]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @endCopy the code
Run the program and you will see the following effect
So we’ve added the view to the superview.
View hierarchy
The other is the hierarchy of views, which should be taken into account when a view needs to be overridden.
The rule is, whoever is added first is at the bottom, which means that it is added in the order of the code, and whichever you add first, it will show first, so that the later overlays are added
So let’s do the last demo
// // viewController.m // UIView hierarchy // // Created by Cheerful Man on 2018/7/20. // Copyright © 2018 Cheerful Man. All rights reserved. / / / / -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - / * learning content 1. UIView subviews */ #import "viewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, Typically, UIView* view01 = [[UIView alloc] init]; view01.frame = CGRectMake(100, 100, 150, 150); view01.backgroundColor = [UIColor yellowColor]; UIView* view02 = [[UIView alloc] init]; view02.frame = CGRectMake(125, 125, 150, 150); view02.backgroundColor = [UIColor orangeColor]; UIView* view03 = [[UIView alloc] init]; view03.frame = CGRectMake(150, 150, 150, 150); view03.backgroundColor = [UIColor greenColor]; [self.view addSubview: view01] [self.view addSubview: view01] [self.view addSubview: view01]]; [self.view addSubview:view02]; [self.view addSubview:view03]; //[self.view bringSubviewToFront: view02]; //[self.view bringSubviewToFront: view02]; //[self.view bringSubviewToFront: view02]; [self.view sendSubviewToBack: view01] [self.view sendSubviewToBack: view01] [self.view sendSubviewToBack: view01] [self.view sendSubviewToBack: view01] UIView * viewFront = self.view.subviews[2]; // remove view01 from superview //[view01 removeFromSuperview]; UIView * viewBack = self.view.subviews[0]; // Create a new view and make it equal to the first view in the subviews array UIView * viewBack = self.view.subviews[0]; // We'll see the sentence printed at the bottom of the screen if(viewBack == view01){puts("Equal! ); } } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @endCopy the code
The comments are clearly written, so I won’t repeat them. Run the program and you get the following effect
The parent-child relationship of UIView
Now to summarize one more important point, the parent-child relationship of UIView, let’s go to the last picture. This is my imitation of a wechat circle of friends interface
Wechat believes that every one of us can play, so let’s think about a question first.
So let’s think about it, if we just add the avatar view to the screen, when the background slides, will the avatar also move?
Of course not. The heads are still going to be there
Only if we add the image view of the avatar to the view of the background image, when we slide, the avatar and the background image will slide together. So, let’s do another demo
#import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, Typically from a nib. UIView *view01 = [[UIView alloc] init]; view01.frame = CGRectMake(100, 100, 150, 150); view01.backgroundColor = [UIColor yellowColor]; UIView *childView = [[UIView alloc] init]; UIView *childView = [[UIView alloc] init]; childView.frame = CGRectMake(0, 0, 30, 30); childView.backgroundColor = [UIColor redColor]; // Add view01 to the view [self.view addSubview:view01]; // Pay attention!! [view01 addSubview:childView]; } - (void)didReceiveMemoryWarning { [super didReceiveMemoryWarning]; // Dispose of any resources that can be recreated. } @endCopy the code
Results the following
If we look at the code, we set the child view’s initial position to (0,0), but instead of appearing in the top left corner, it appears at the top left corner (0,0) of its superview
So what that means is that the position of the child view moves with the superview, and when we change the position of the superview, the child view moves with the superview.
This has the effect of the profile picture moving with the background in the wechat Moments.
Have the interview data that want or other data also can look for me, welcome consultation!
Have a question can go to see my home page add me to answer for you!!Click on add
The article will continue to be updated, and you can also send me a personal message to get the interview information in time. If you have any comments and suggestions, please leave me a message. Please pay attention to iOS friends! Like words to a like it! Thank you very much! Thank you very much! Thank you very much!
included