1:Delegate运用

.h
#import <UIKit/UIKit.h>
@protocol FilterHeaderViewDelegate <NSObject>
@required
-(void)filterHeaderViewMoreBtnClicked:(id)sender;
@end extern float CYLFilterHeaderViewHeigt;
@interface FilterHeaderView : UICollectionReusableView
@property (nonatomic, weak ) id<FilterHeaderViewDelegate> delegate;
@end .m
- (void)moreBtnClicked:(id)sender {
if ([self.delegate respondsToSelector:@selector(filterHeaderViewMoreBtnClicked:)]) {
[self.delegate filterHeaderViewMoreBtnClicked:self.moreButton];
}
}
注意在.m中会有要调用上面这个方法:
[self.moreButton addTarget:self action:@selector(moreBtnClicked:) forControlEvents:UIControlEventTouchUpInside]; 而在调用这个插件的时候记得把delegate赋于self,并要把FilterHeaderViewDelegate引入到<>里;然后就可以实现这个deletage的方法;

2:实现UIButton不同状态下的显示

[btn setTitle:@"更多" forState:UIControlStateNormal];
[btn setTitle:@"收起" forState:UIControlStateSelected];
btn.titleLabel.font = [UIFont systemFontOfSize:];
[btn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
[btn setTitleColor:[UIColor blackColor] forState:UIControlStateSelected];
btn.adjustsImageWhenHighlighted = NO;
[btn setImage:[UIImage imageNamed:@"home_btn_more_normal"] forState:UIControlStateNormal];
[btn setImage:[UIImage imageNamed:@"home_btn_more_selected"] forState:UIControlStateSelected];
btn.titleEdgeInsets = UIEdgeInsetsMake(, -btn.imageView.frame.size.width-kImageToTextMargin, , btn.imageView.frame.size.width);
btn.imageEdgeInsets = UIEdgeInsetsMake(, btn.titleLabel.frame.size.width, , -btn.titleLabel.frame.size.width);

3:视图uiview增加点击事件

    if (!_TicketView) {
_TicketView=[UIView new];
_TicketView.backgroundColor=[UIColor whiteColor];
//增加点击事件

UITapGestureRecognizer* singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(handleSingleTap:)];

[_TicketView addGestureRecognizer:singleTap];

        [_BelowView addSubview:_TicketView];
} 调用:

-(void)handleSingleTap:(UITapGestureRecognizer *)sender

{

    NSLog(@"sdfsdfsdf");
}

4:在ios7中出现滚动视图UIScrollView不兼容问题,无法滚动

把contentSize定义放在viewDidLayoutSubviews中;
-(void)viewDidLayoutSubviews
{
_myScrollView.contentSize=CGSizeMake(SCREEN_WIDTH,);
}

5:对UIButton上的图标进行翻转

#define DEGREES_TO_RADIANS(angle) ((angle)/180.0 *M_PI)

调用:
_BtnMoreContent.imageView.transform = CGAffineTransformRotate(_BtnMoreContent.imageView.transform, DEGREES_TO_RADIANS());

6:创建一个背景图片,并从网络动态加载

在viewDidLoad调用:

-(void)LoadBackViewImage
{
UIImageView *bgView=[[UIImageView alloc] initWithFrame:CGRectMake(, , SCREEN_WIDTH, SCREEN_HEIGHT)]; bgView.image=[UIImage imageNamed:@"bgWeatherEmpty"]; [bgView sd_setImageWithURL:[NSURL URLWithString:self.backImageUrl] placeholderImage:[UIImage imageNamed:@"bgWeatherEmpty"] completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
dispatch_async(dispatch_get_main_queue(), ^{
bgView.image=image;
[self.view addSubview:bgView];
[self.view sendSubviewToBack:bgView];
});
}];
} 注意: UIView层次管理(sendSubviewToBack,bringSubviewToFront)
将一个UIView显示在最前面只需要调用其父视图的 bringSubviewToFront()方法。
将一个UIView层推送到背后只需要调用其父视图的 sendSubviewToBack()方法。

7:加载xib到其它视图中

创建一个UIView的xib文件,这个方程可以看网上随便一个文章,主要是把属性中的custom Class指定给创建的那个 .h文件;

.h
#import <UIKit/UIKit.h> @interface LKTextView : UIView
@property (strong, nonatomic) IBOutlet UILabel *lbText;
- (IBAction)bt_pressed:(id)sender;
@property (strong, nonatomic) IBOutlet UITextField *textView;
+(LKTextView*)instanceTextView;
@end .m
#import "LKTextView.h"
#import "RKTabView.h"
#import "RKTabItem.h"
@implementation LKTextView
@synthesize textView;
@synthesize lbText; +(LKTextView *)instanceTextView
{
NSArray* nibView = [[NSBundle mainBundle] loadNibNamed:@"LKTextView" owner:nil options:nil];
return [nibView objectAtIndex:];
}
-(id)initWithCoder:(NSCoder *)aDecoder
{
self = [super initWithCoder:aDecoder];
if(self)
{
//其它自个想增加到视图里的
[self initViews]; }
return self;
}
/**
* @author wujunyang, 15-04-30 16:04:03
*
* @brief 这边是运用RKTABVIEW创建一个标签的
*/
-(void)initViews
{
UIView *vi=[[UIView alloc] initWithFrame:CGRectMake(, , , )];
vi.backgroundColor=[UIColor redColor];
[self addSubview:vi]; RKTabView *titledTabsView=[[RKTabView alloc] initWithFrame:CGRectMake(, , , )];
[self addSubview:titledTabsView]; RKTabItem *mastercardTabItem = [RKTabItem createUsualItemWithImageEnabled:nil imageDisabled:[UIImage imageNamed:@"mastercard"]];
mastercardTabItem.titleString = @"MasterCard";
RKTabItem *paypalTabItem = [RKTabItem createUsualItemWithImageEnabled:nil imageDisabled:[UIImage imageNamed:@"paypal"]];
paypalTabItem.titleString = @"PayPal";
RKTabItem *visaTabItem = [RKTabItem createUsualItemWithImageEnabled:nil imageDisabled:[UIImage imageNamed:@"visa"]];
visaTabItem.titleString = @"Visa";
RKTabItem *wuTabItem = [RKTabItem createUsualItemWithImageEnabled:nil imageDisabled:[UIImage imageNamed:@"wu"]];
wuTabItem.titleString = @"Western Union";
RKTabItem *wireTabItem = [RKTabItem createUsualItemWithImageEnabled:nil imageDisabled:[UIImage imageNamed:@"wire-transfer"]];
wireTabItem.titleString = @"Wire Transfer"; //mastercardTabItem.tabState = TabStateEnabled; titledTabsView.darkensBackgroundForEnabledTabs = YES;
titledTabsView.horizontalInsets = HorizontalEdgeInsetsMake(, );
titledTabsView.titlesFontColor = [UIColor colorWithWhite:0.9f alpha:0.8f]; titledTabsView.tabItems = @[mastercardTabItem, paypalTabItem, visaTabItem, wuTabItem, wireTabItem];
}
/*
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect
{
// Drawing code
}
*/ - (IBAction)bt_pressed:(id)sender {
lbText.text = textView.text;
}
@end 然后调用视图.m: - (void)viewDidLoad
{ LKTextView* text = [LKTextView instanceTextView];
text.frame = CGRectMake(, , text.frame.size.width, text.frame.size.height);
text.textView.text = @"input ";
[self.view addSubview:text];
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
}

 8:不错的插件

AutoLayout下自动计算UITableViewCell高度的扩展FDTemplateLayoutCell    https://github.com/forkingdog/UITableView-FDTemplateLayoutCell
多视图控制器间进行切换--XLPagerTabStrip https://github.com/xmartlabs/XLPagerTabStrip
不错的标签选项卡插件 https://github.com/RafaelKayumov/RKTabView
生成@3x图片对应的@2x和@1x版本--RTImageAssets                         https://github.com/rickytan/RTImageAssets
使用:用来生成 @3x 的图片资源对应的 @2x 和 @1x 版本,只要拖拽高清图到 @3x 的位置上,然后按 Ctrl+Shift+A 即可自动生成两张低清的补全空位。当然你也可以从 @2x 的图生成 @3x 版本,如果你对图片质量要求不高的话

9:ios7和ios8关于导航栏的那些事

ios7之前的版本中UIViewController中的view在显示后会自动调整为去掉导航栏的高度的,控件会自动在导航栏以下摆放。

在iOS7中UIViewController的wantsFullScreenLayout属性被舍弃了,所有的UIViewController创建后默认就是full Screen的,因此如果带导航栏的应用界面中的部分控件会被导航栏覆盖掉。

解决方案:可以使用ios7种UIViewController新增的属性extendLayoutIncludesOpaqueBars和edgesForExtendedLayout来解决。

其中这个属性指定了当bar使用不透明图片时,试图是否延伸至bar所在区域,默认值为NO。而edgesForExtendedLayout

其中这个属性指定了当Bar使用了不透明图片时,视图是否延伸至Bar所在区域,默认值时NO。而edgesForExtendedLayout则是表示视图是否覆盖到四周的区域,默认是UIRectEdgeAll,即上下左右四个方向都会覆盖,那么为让顶部不进行延伸到导航栏覆盖的区域,我们可以把顶部区域延伸去掉。实现代码如下:

self.extendedLayoutIncludesOpaqueBars = NO;

self.edgesForExtendedLayout = UIRectEdgeBottom | UIRectEdgeLeft | UIRectEdgeRight;

11:initWithNibName/awakeFromNib/initWithCoder区别

第一、initWithNibName这个方法是在controller的类在IB中创建,但是通过Xcode实例化controller的时候用的.
第二、initWithCoder 是一个类在IB中创建但在xocde中被实例化时被调用的.比如,通过IB创建一个controller的nib文件,然后在xcode中通过 initWithNibName来实例化这个controller,那么这个controller的initWithCoder会被调用.或者是一个view的nib文件,类似方法创建时调用initWithCoder
第三、awakeFromNib 当.nib文件被加载的时候,会发送一个awakeFromNib的消息到.nib文件中的每个对象,每个对象都可以定义自己的awakeFromNib函数来响应这个消息,执行一些必要的操作。也就是说通过nib文件创建view对象时执行awakeFromNib 第四、关于 initWithNibName 和 loadNibNamed 的区别和联系 : 关于 initWithNibName 和 loadNibNamed 的区别和联系。之所以要把这两者来一起讲,我觉的我也有点困惑,到底用那种?其实真正搞清楚了他们之间的差别,就不会这么迷惘了。因为这两个方法,根本就不是一路货色。
既然,是要说明这2个方法,那就着重将区别吧。
但是第一步,还是要罗嗦一下,他们的联系:可以使用此方法加载用户界面(xib文件)到我们的代码中,这样,可以通过操作这个加载进来的(xib)对象,来操作xib文件内容。
下面进入主题,谈区别:
. ShowViewController的initWithNibName方法
ShowViewController * showMessage = [[ShowViewController alloc]
initWithNibName:@"ShowViewController" bundle:nil];
self.showViewController = showMessage;
[showMessage release];
.VideoCellController的loadNibNamed方法
NSArray * nib = [[NSBundle mainBundle] loadNibNamed:@"Save3ViewController"
owner:self options:nil] ;
self.showViewController = [nib lastObject];
[nib objectAtIndex:]; 总结:
只看他们初始化,那可能感觉是一样的。但是如果,打开分别看xib的关系的时候,才恍然大悟,原来他们的集成类都不一样。
. initWithNibName要加载的xib的类为我们定义的视图控制器类
.加载方式不同
initWithNibName方法:是延迟加载,这个View上的控件是 nil 的,只有到 需要显示时,才会不是 nil
loadNibNamed方法:即时加载,用该方法加载的xib对象中的各个元素都已经存在。
(认真理解这句帮规:when using loadNibNamed:owner:options:, the File's Owner should be NSObject, the main view should be your class type, and all outlets should be hooked up to the view, not the File's Owner.) 第五、initWithCoder和initWithFrame的区别 nitWithoder 是当从nib文件中加载对象的时候会调用,比如你的view来自nib那么就会调用这个view的这个函数。(由框架调用)
initWithFrame (是由用户调用,来初始化对象的)

IOS开发基础知识--碎片12的更多相关文章

  1. IOS开发基础知识碎片-导航

    1:IOS开发基础知识--碎片1 a:NSString与NSInteger的互换 b:Objective-c中集合里面不能存放基础类型,比如int string float等,只能把它们转化成对象才可 ...

  2. IOS开发基础知识--碎片14

    1:ZIP文件压缩跟解压,使用ZipArchive 创建/添加一个zip包 ZipArchive* zipFile = [[ZipArchive alloc] init]; //次数得zipfilen ...

  3. IOS开发基础知识--碎片19

    1:键盘事件顺序 UIKeyboardWillShowNotification // 键盘显示之前 UIKeyboardDidShowNotification // 键盘显示完成后 UIKeyboar ...

  4. IOS开发基础知识--碎片33

    1:AFNetworking状态栏网络请求效果 直接在AppDelegate里面didFinishLaunchingWithOptions进行设置 [[AFNetworkActivityIndicat ...

  5. IOS开发基础知识--碎片42

    1:报thread 1:exc_bad_access(code=1,address=0x70********) 闪退 这种错误通常是内存管理的问题,一般是访问了已经释放的对象导致的,可以开启僵尸对象( ...

  6. IOS开发基础知识--碎片50

      1:Masonry 2个或2个以上的控件等间隔排序 /** * 多个控件固定间隔的等间隔排列,变化的是控件的长度或者宽度值 * * @param axisType 轴线方向 * @param fi ...

  7. IOS开发基础知识--碎片3

    十二:判断设备 //设备名称 return [UIDevice currentDevice].name; //设备型号,只可得到是何设备,无法得到是第几代设备 return [UIDevice cur ...

  8. IOS开发基础知识--碎片11

    1:AFNetwork判断网络状态 #import “AFNetworkActivityIndicatorManager.h" - (BOOL)application:(UIApplicat ...

  9. IOS开发基础知识--碎片16

    1:Objective-C语法之动态类型(isKindOfClass, isMemberOfClass,id) 对象在运行时获取其类型的能力称为内省.内省可以有多种方法实现. 判断对象类型 -(BOO ...

随机推荐

  1. .NET平台开源项目速览(10)FluentValidation验证组件深入使用(二)

    在上一篇文章:.NET平台开源项目速览(6)FluentValidation验证组件介绍与入门(一) 中,给大家初步介绍了一下FluentValidation验证组件的使用情况.文章从构建间的验证器开 ...

  2. 新作《ASP.NET Web API 2框架揭秘》正式出版

    我觉得大部分人都是“眼球动物“,他们关注的往往都是目光所及的东西.对于很多软件从业者来说,他们对看得见(具有UI界面)的应用抱有极大的热忱,但是对背后支撑整个应用的服务却显得较为冷漠.如果我们将整个“ ...

  3. (第六天)DOM

    概念 文档对象模型(DOM)是表示和操作HTML和XML文档内容的基础API. 选取文档元素 (1)通过ID选取元素 var id = document.getElementById("se ...

  4. android标题栏上面弹出提示框(二) PopupWindow实现,带动画效果

    需求:上次用TextView写了一个从标题栏下面弹出的提示框.android标题栏下面弹出提示框(一) TextView实现,带动画效果,  总在找事情做的产品经理又提出了奇葩的需求.之前在通知栏显示 ...

  5. 应用程序框架实战二十九:Util Demo介绍

    上文介绍了我选择EasyUi作为前端框架的原因,并发放了最新Demo.本文将对这个Demo进行一些介绍,以方便你能够顺利运行起来. 这个Demo运行起来以后,是EasyUi的一个简单CRUD操作,数据 ...

  6. php模拟数据库常用操作效果

    test.php <?php header("Content-type:text/html;charset='utf8'"); error_reporting(E_ALL); ...

  7. iOS chart 图表完美解决方案 基于swift

    如果打算在app中使用图标功能,这个框架基本能够满足90%的需求 下边是作者的框架的下载地址 ,基于swift2.0 https://github.com/danielgindi/ios-charts ...

  8. 原创:经验分享:微信小程序外包接单常见问题及流程

    从九月底内测到现在已经三个半月.凌晨一点睡觉已经习以为常,也正是这样,才让无前端经验的我做微信小程序开发并不感到费劲.最近才开始接微信小程序的外包项目,目前已经签下了五份合同,成品出了两个.加上转给朋 ...

  9. VS2013预览版安装 体验截图

    支持与msdn帐号链接: 不一样的团队管理: 新建项目:

  10. 在Visual Studio 2012中使用VMSDK开发领域特定语言(一)

    前言 本专题主要介绍在Visual Studio 2012中使用Visualization & Modeling SDK进行领域特定语言(DSL)的开发,包括两个部分的内容.在第一部分中,将对 ...