服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS开发UI篇—xib的简单使用实例

iOS开发UI篇—xib的简单使用实例

2021-02-06 14:10文顶顶 IOS

本篇文章主要介绍了iOS开发UI篇—xib的简单使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

这个博客申请了有一段时间了,觉得好像是该写点什么了。这篇文章主要是关于一些xib的简单的用法,希望可以帮助到刚刚使用xib的新手们。

什么是xib? xib能做什么?

用来描述软件界面的文件。

如果没有xib,所有的界面都需要通过代码来手动创建。

有了xib以后,可以在xib中进行可视化开发,然后加载xib文件的时候,系统自动生成对应的代码来创建界面。

与xib类似的还有storyboard文件。xib和storyboard的比较,一个轻量级一个重量级。

共同点:

都用来描述软件界面。都用interface builder工具来编辑

不同点:

xib是轻量级的,用来描述局部的ui界面

storyboard是重量级的,用来描述整个软件的多个界面,并且能展示多个界面之间的跳转关系

二、xib的简单使用

1.建立xib文件iOS开发UI篇—xib的简单使用实例
建立的xib文件命名为appxib.xibiOS开发UI篇—xib的简单使用实例
2.对xib进行设置

根据程序的需要,这里把view调整为自由布局iOS开发UI篇—xib的简单使用实例
建立view模型(设置长宽等参数)iOS开发UI篇—xib的简单使用实例
调整布局和内部的控件iOS开发UI篇—xib的简单使用实例
完成后的单个view
iOS开发UI篇—xib的简单使用实例

3.使用xib文件的代码示例

yyviewcontroller.m文件代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
//
// yyviewcontroller.m
// 10-xib文件的使用
//
// created by apple on 14-5-24.
// copyright (c) 2014年 itcase. all rights reserved.
//
 
#import "yyviewcontroller.h"
#import "yyapp.h"
 
@interface yyviewcontroller ()
@property(nonatomic,strong)nsarray *app;
@end
 
@implementation yyviewcontroller
 
//1.加载数据信息
-(nsarray *)app
{
  if (!_app) {
    nsstring *path=[[nsbundle mainbundle]pathforresource:@"app.plist" oftype:nil];
    nsarray *temparray=[nsarray arraywithcontentsoffile:path];
    
    //字典转模型
    nsmutablearray *arraym=[nsmutablearray array ];
    for (nsdictionary *dict in temparray) {
      [arraym addobject:[yyapp appwithdict:dict]];
    }
    _app=arraym;
  }
  return _app;
}
 
//创建界面原型
- (void)viewdidload
{
  [super viewdidload];
  nslog(@"%d",self.app.count);
  
  //九宫格布局
  int totalloc=3;
  cgfloat appvieww=80;
  cgfloat appviewh=90;
  cgfloat margin=(self.view.frame.size.width-totalloc*appvieww)/(totalloc+1);
  
  int count=self.app.count;
  for (int i=0; i<count; i++) {
    
    int row=i/totalloc;
    int loc=i%totalloc;
    cgfloat appviewx=margin + (margin +appvieww)*loc;
    cgfloat appviewy=margin + (margin +appviewh)*row;
    yyapp *app=self.app[i];
    
    //拿出xib视图
    nsarray *apparray= [[nsbundle mainbundle]loadnibnamed:@"appxib" owner:nil options:nil];
    uiview *appview=[apparray firstobject];
    //加载视图
    appview.frame=cgrectmake(appviewx, appviewy, appvieww, appviewh);
    
    uiimageview *appviewimg=(uiimageview *)[appview viewwithtag:1];
    appviewimg.image=app.image;
    
    uilabel *appviewlab=(uilabel *)[appview viewwithtag:2];
    appviewlab.text=app.name;
    
    uibutton *appviewbtn=(uibutton *)[appview viewwithtag:3];
    [appviewbtn addtarget:self action:@selector(appviewbtnclick:) forcontrolevents:uicontroleventtouchupinside];
    appviewbtn.tag=i;
    
    [self.view addsubview:appview];
  }
}
 
/**按钮的点击事件*/
-(void)appviewbtnclick:(uibutton *)btn
{
  yyapp *apps=self.app[btn.tag];
  uilabel *showlab=[[uilabel alloc]initwithframe:cgrectmake(60, 450, 200, 20)];
  [showlab settext:[nsstring stringwithformat: @"%@下载成功",apps.name]];
  [showlab setbackgroundcolor:[uicolor lightgraycolor]];
  [self.view addsubview:showlab];
  showlab.alpha=1.0;
  
  //简单的动画效果
  [uiview animatewithduration:2.0 animations:^{
    showlab.alpha=0;
  } completion:^(bool finished) {
    [showlab removefromsuperview];
  }];
}
 
@end

运行效果:
iOS开发UI篇—xib的简单使用实例

三、对xib进行连线示例

1.连线示例

新建一个xib对应的视图类,继承自uiviewiOS开发UI篇—xib的简单使用实例
在xib界面右上角与新建的视图类进行关联iOS开发UI篇—xib的简单使用实例
把xib和视图类进行连线iOS开发UI篇—xib的简单使用实例
注意:在使用中把weak改成为强引用。否则...

2.连线后的代码示例

yyviewcontroller.m文件代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
//
// yyviewcontroller.m
// 10-xib文件的使用
//
// created by apple on 14-5-24.
// copyright (c) 2014年 itcase. all rights reserved.
//
 
#import "yyviewcontroller.h"
#import "yyapp.h"
#import "yyappview.h"
 
@interface yyviewcontroller ()
@property(nonatomic,strong)nsarray *app;
@end
 
@implementation yyviewcontroller
 
//1.加载数据信息
-(nsarray *)app
{
  if (!_app) {
    nsstring *path=[[nsbundle mainbundle]pathforresource:@"app.plist" oftype:nil];
    nsarray *temparray=[nsarray arraywithcontentsoffile:path];
    
    //字典转模型
    nsmutablearray *arraym=[nsmutablearray array ];
    for (nsdictionary *dict in temparray) {
      [arraym addobject:[yyapp appwithdict:dict]];
    }
    _app=arraym;
  }
  return _app;
}
 
//创建界面原型
- (void)viewdidload
{
  [super viewdidload];
  nslog(@"%d",self.app.count);
  
  //九宫格布局
  int totalloc=3;
  cgfloat appvieww=80;
  cgfloat appviewh=90;
  cgfloat margin=(self.view.frame.size.width-totalloc*appvieww)/(totalloc+1);
  
  int count=self.app.count;
  for (int i=0; i<count; i++) {
    
    int row=i/totalloc;
    int loc=i%totalloc;
    cgfloat appviewx=margin + (margin +appvieww)*loc;
    cgfloat appviewy=margin + (margin +appviewh)*row;
    yyapp *app=self.app[i];
    
    //拿出xib视图
    nsarray *apparray= [[nsbundle mainbundle]loadnibnamed:@"appxib" owner:nil options:nil];
    
    //注意这里的类型名!
    //uiview *appview=[apparray firstobject];
    yyappview *appview=[apparray firstobject];
    
    //加载视图
    appview.frame=cgrectmake(appviewx, appviewy, appvieww, appviewh);
     [self.view addsubview:appview];
    
    appview.appimg.image=app.image;
    appview.applab.text=app.name;
    appview.appbtn.tag=i;
    
    [ appview.appbtn addtarget:self action:@selector(appviewbtnclick:) forcontrolevents:uicontroleventtouchupinside];
    
  }
}
 
/**按钮的点击事件*/
-(void)appviewbtnclick:(uibutton *)btn
{
  yyapp *apps=self.app[btn.tag];
  uilabel *showlab=[[uilabel alloc]initwithframe:cgrectmake(60, 450, 200, 20)];
  [showlab settext:[nsstring stringwithformat: @"%@下载成功",apps.name]];
  [showlab setbackgroundcolor:[uicolor lightgraycolor]];
  [self.view addsubview:showlab];
  showlab.alpha=1.0;
  
  //简单的动画效果
  [uiview animatewithduration:2.0 animations:^{
    showlab.alpha=0;
  } completion:^(bool finished) {
    [showlab removefromsuperview];
  }];
}
 
@end

yyappview.h文件代码(已经连线)

?
1
2
3
4
5
6
7
#import <uikit/uikit.h>
 
@interface yyappview : uiview
@property (strong, nonatomic) iboutlet uiimageview *appimg;
@property (strong, nonatomic) iboutlet uilabel *applab;
@property (strong, nonatomic) iboutlet uibutton *appbtn;
@end

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

延伸 · 阅读

精彩推荐
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03