往期回顾
iOS组件化 01 - 本地私有库的使用
iOS组件化 02 - 组件中图片资源管理方案优化
1. 使用.xib
(1)创建一个自定义视图 SLCustomView
data:image/s3,"s3://crabby-images/28ef4/28ef480904552f26469ba95d80a18d48cd2dd9e5" alt=""
(2)指定代码码存放路径
data:image/s3,"s3://crabby-images/3ea43/3ea4352f49ef1edf9b72c83ffc6d5dedd3cf2ed8" alt=""
(3)创建一个XIB SLCustomView.xib
data:image/s3,"s3://crabby-images/4f16d/4f16dd034969f6dc359a91be74daf00f311f882e" alt=""
(4)指定.xib
存放路径
data:image/s3,"s3://crabby-images/cb49b/cb49b735900f3427347465ba7df1bc457dec9466" alt=""
(5)调整.xib
视图大小
data:image/s3,"s3://crabby-images/11804/118046f871da8e427dd7d93f6b5cd6009820f127" alt=""
(6)添加UIImageView
,设置约束
data:image/s3,"s3://crabby-images/a6c8f/a6c8ffc8b2d28b1dc03c69d4a19a695922b49e60" alt=""
(7)添加图片资源
data:image/s3,"s3://crabby-images/66b75/66b756641f2b460d2e98d9b9284c808c5f5c4094" alt=""
(8)在 xib
中设置 UIImageView
的 image
data:image/s3,"s3://crabby-images/6f163/6f163215d4a4df17a8531fe50d723c51a4d12c76" alt=""
上一期中,组件中使用了
.xcassets
方式管理图片资源,这里就可以体现出优势
1> 无需指定NSBundle
路径,直接使用图片名
2> 图片可以在xib
中可视化显示
3> 下面的Storyboard同上
(9)编写代码:实例化xib视图
// SLCustomView.h
#import <UIKit/UIKit.h>
NS_ASSUME_NONNULL_BEGIN
@interface SLCustomView : UIView
+ (instancetype)customView;
@end
NS_ASSUME_NONNULL_END
// SLCustomView.m
#import "SLCustomView.h"
#define SLSearchBar_BundleName @"SLBaseKit"
@implementation SLCustomView
+ (NSBundle *)currentBundle {
static NSBundle *bundle;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
bundle = [NSBundle bundleWithPath:[[NSBundle bundleForClass:self]
pathForResource:SLSearchBar_BundleName
ofType:@".bundle"]];
if (!bundle) bundle = [NSBundle mainBundle];
});
return bundle;
}
+ (instancetype)customView {
return [[self currentBundle] loadNibNamed:NSStringFromClass(self)
owner:nil
options:nil].lastObject;
}
@end
(10)修改.podspec
,指定xib资源所在路径
s.resource_bundles = {
'SLBaseKit' => ['SLBaseKit/Assets/*.{xcassets}',
'SLBaseKit/Classes/*.{xib,nib}'] # 【注意】逗号分隔符之间不要有空格
}
(11)打开终端,执行下面命令
# 根据自己的路径修改
cd SLBaseKit/SLBaseKit/Example
pod install
(12)修改测试工程的 SLViewController.m
data:image/s3,"s3://crabby-images/4831e/4831e83d03f58b7c75ca1310245398ba05faf1d1" alt=""
(13)编译测试工程,运行显示 UI
效果
data:image/s3,"s3://crabby-images/c63fc/c63fcd589cde1f37e6a9ea6151141ec190519346" alt=""
2. 使用.storyboard
(1)创建首页控制器 SLHomeVC
data:image/s3,"s3://crabby-images/aac56/aac56e07185ab4bc6063466a2d5f4d914db5520b" alt=""
(2)指定代码存放路径
data:image/s3,"s3://crabby-images/19807/198077469aa9f0df58d9c202f43eb3a9d4e6d4e6" alt=""
(3)新建一个Storyboard
data:image/s3,"s3://crabby-images/79a14/79a141fb667a76e8421761217252e4c4972a6efa" alt=""
(4)指定 Home.storyboard
存放路径
data:image/s3,"s3://crabby-images/55f97/55f97f69e38bbde407c09c6e6031b3e288cf7936" alt=""
(5)选择Home.storyboard
,添加 View Controller Scene
,并关联 SLHomeVC
data:image/s3,"s3://crabby-images/85287/85287fcf01f9323b725d11292eccc2be036c60de" alt=""
data:image/s3,"s3://crabby-images/09d98/09d985973b003191a9fd9d0d2934fa72163092ad" alt=""
(6)勾选 Is Initial View Controller
data:image/s3,"s3://crabby-images/c494e/c494e2c926c0b6b4ad6f1874352b2de8a66e4184" alt=""
(7)编写代码
// SLHomeVC.h
#import <UIKit/UIKit.h>
NS_ASSUME_NONNULL_BEGIN
@interface SLHomeVC : UIViewController
+ (instancetype)loadStoryboard;
@end
NS_ASSUME_NONNULL_END
// SLHomeVC.m
#import "SLHomeVC.h"
#define SLSearchBar_BundleName @"SLBaseKit"
@implementation SLHomeVC
+ (NSBundle *)currentBundle {
static NSBundle *bundle;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
bundle = [NSBundle bundleWithPath:[[NSBundle bundleForClass:self]
pathForResource:SLSearchBar_BundleName
ofType:@".bundle"]];
if (!bundle) bundle = [NSBundle mainBundle];
});
return bundle;
}
+ (instancetype)loadStoryboard {
UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"Home"
bundle:[self currentBundle]];
return storyboard.instantiateInitialViewController;
}
- (instancetype)init {
return [SLHomeVC loadStoryboard];
}
- (void)viewDidLoad {
[super viewDidLoad];
self.view.backgroundColor = [UIColor greenColor];
}
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
[self dismissViewControllerAnimated:YES completion:nil];
}
@end
(8)修改.podspec
,指定xib资源所在路径
s.resource_bundles = {
'SLBaseKit' => ['SLBaseKit/Assets/*.{xcassets}',
'SLBaseKit/Classes/*.{xib,nib,storyboard,storyboardc}'] # 【注意】逗号分隔符之间不要有空格
}
(9)打开终端,执行下面命令
# 根据自己的路径修改
cd SLBaseKit/SLBaseKit/Example
pod install
(10)修改测试工程的 SLViewController.m
data:image/s3,"s3://crabby-images/d2c37/d2c3789e4cf39d13aa3d6b498f31fe9517505e75" alt=""
(11)编译测试工程,运行成功通过
网友评论