网上的 UI 总结

1.UILabel 

1) label.frame        //CGRectMake(x, y, width, height);

 2) label.text            //label.textColor 

3) label.backgroundColor        //UIColor  redColor  colorWithRed: green: blue: alpha: 

4) label.textAlignment    //UITextAlignmentCenter Left Right 

5) label.font            //UIFont familyNames  boldSystemFontOfSize:    [UIFont fontWithName: size: ]

 6) label.shadowOffset        //CGSizeMake(width, height) 

7) label.shadowColor 

8) label.lineBreakMode    //UILineBreakModeWordWrap 

9) label.numberOfLines

10) CGSize size = [string sizeWithFont: constrainedToSize: lineBreakMode:];

11) [self.window addSubview: ];

12) label.adjustsFontSizeToFitWidth = YES;

2.UIButton 

继承自UIControl, UIControl是在UIView的基础上增加了一个点击事件 

1) buttonWithType:    //初始化只有这一种方法, UIButtonTypeRoundedRect, InfoLight, InfoDark, ContactAdd, DetailDisclosure, Custom 

2) setTitle: forState:    //UIControlStateNormal, Highlighted 

3) setTitleColor: forState:  

4) setTintColor:        //按钮点击后的颜色, 只有RoundedRect有这个效果 

5) button.tag            //设置标识属性, 唯一标识一个view 

6) addTarget:self action:@selector() forControlEvents:    //在哪个事件下, 执行哪个对象的方法, UIControlEventTouchUpInside              //哪个对象调用这个@selector(buttonClick:), 这个对象就作为参数传给buttonClick: 

7) setBackgroundImage: forState:      

8) setImage: forState:

3.UIView 

所有能看的见的都是view 

CGRect frame = {CGOrigin, CGSize};    CGOrigin = {x, y}; //坐标是相对的    

CGSize = {width, height}; 

CGPoint center = {x, y}; CGRect bounds; 

CGRectContainsPoint(rect, point);    // 判断点point是否在rect内 

[self.window sendSubviewToBack: ];    bringSubviewToFront:    exchangeSubviewAtIndex: withSubviewAtIndex: insertSubview: atIndex:    insertSubview: belowSubview:    insertSubview: aboveSubview:

 view.tag    [self.view viewWithTag: ]    // 根据tag值, 得到对应的view 

view.clipsToBounds = YSE;    // 自动剪裁掉超出本身frame大小的子view的内容 

view.contentMode        // 内容填充模式 

view.autoresizesSubviews = YSE;    // 设置当前view的子view可以自动布局

 subview.autoresizingMask = UIViewAutoresizingFlexibleWidth;    // 增加多个自动布局模式, 可以使用位或运算 (|) [UIView animateWithDuration: animations:^{  } completion:^(BOOL finished){  }];    // UIView动画 

[UIScreen mainScreen]        // 获得屏幕类对象 

 currenMode [UIDevice currentDevice]    // 获得当前设备类对象  name, systemName, SystemVersion

4.UIImageView 

[UIImage imageNamed:]

 image.size.width    image.size.height 

initWithImage: imageView.image        // imageView中的image 

NSData *data = UIImagePNGRepresentation(imageView.image);    // 将PNG图片转成二进制数据 UIImageJPEGRepresentation(imageView.image, 0.5)    // 转换JPEG图片, 第二个参数为压缩比0到1之间的数 UITapGestureRecognizer    // 点击手势 

 initWithTarget: self action: @selector()   

 numberOfTapsRequired    // 点击次数 (默认为1)

  numberOfTouchesRequired    // 几只手指点击 (默认为1)  

tapGestureRecognizer.view.tag    // 被点击的view的tag 

 gesture.view        // 得到点击的视图 

 [gesture state]        // 手势的状态,

 UIGestureRecognizerStateBegan等 

 [gesture locationInView: ]    // 点击手势在视图中的位置 

addGestureRecognizer:        // 加入手势

imageView.userInteractionEnabled = YES  // 打开imageView的交互功能

 ImageView动画, 将一组图片放到一个数组中

 imageView.animationImages = imagesArray; imageView.animationDuration = 1;    // 动画周期时间 imageView.animationRepeatCount = 5;    // 默认是无限次 startAnimating    stopAnimating5.UIViewController 分为view和controller两部分, 能看到的只有view self.view.backgroundColor self.window.rootViewController = rootViewController;    // 在window中添加主视图控制器 presentViewController: animated: YES completion:^{ }    // 窗体跳转 subViewController.modalTransitionStyle = UIModalTransitionsStyleFlipHorizontal;    // 跳转风格 dismissViewControllerAnimated: YES completion:^{ }    // 关闭对话窗口, 即返回上一个窗口 函数介绍:    1)-(id)initWithNibName: bundle:    // 将xib文件转换为nib描述文件  2)-(void)loadView            // 用于初始化nib文件里描述的控件  3)-(void)viewDidLoad            // 进一步修改self.view(即修改手写控件), 默认只执行一次, 只有当系统内存不够时, 才会自动调用viewDidUnLoad方法再次执行  4)-(void)viewWillAppear:        // 当界面当要进入时显示 (界面不可见)  5)-(void)viewDidAppear:            // 当界面已经显示时调用 (界面可见)  6)-(void)viewWillDisappear:        // 当界面将要退出时调用 (界面可见)  7)-(void)viewDidDisappear:        // 当界面已经退出后调用 (界面不可见)  8)-(void)didReceiveMemoryWarning    // 当内存不够用时, 系统自动调用此方法, 释放自己写入的内容的内存, 不会销毁  9)-(void)viewDidUnload            // 当内存不够用时, 系统自动调用此方法, 直接销毁界面6.UINavigationController window -> UINavigationController -> UIViewController -> view initWithRootViewController: rootViewController; self.window.rootViewController = navigationController; [self.navigationController pushViewController: animated: YES]    // 压入当前视图控制器, 即进入这个页面 [self.navigationController popViewControllerAnimated: YES]    // 弹出当前视图控制器, 即返回上个页面 [self.navigationController popToRootViewControllerAnimated: YES];    // 弹出导航控制器中所有视图控制器到主视图控制器 self.navigationController.viewControllers    // 得到导航控制器中所有的视图控制器对象数组, 所有的视图控制器共用一个导航控制器 [self.navigationController popToViewController: animated: YES]    // 弹出一些视图控制器, 到指定视图控制器上7.UINavigationBar self.navigationController.navigationBar.barStyle = UIBarStyleBlack;    // 设置导航条, 如果用半透明模式view.frame就是正常的 self.navigationController.navigationBar.backgroundColor    // 只有半透明模式才能设置颜色, 而且还会和黑色半透明的相融合 self.navigationController.navigationBar.frame        // 设置导航条frame, 默认高度为44 self.navigationController.navigationBar setBackgroundImage: forBarMetrics: UIBarMetricsDefault      // 设置导航条背景图片, BarMetrics是iPhone形式(人像, 景色), 图片不会拉伸压缩, 如果图片过大, 会覆盖到下面的视图控制器 self.navigationController.navigationBar.hidden = YES;    // 隐藏导航条 [self.navigationController setNavigationBarHidden: YES animated: YES]8.UINavigationItem 每一个界面都有自己对导航控制器的描述 self.navigationItem.title        // 设置标题, 居中显示 self.navigationItem.titleView        // 设置标题视图, view中的frame的x, y不会影响titleView的位置, 永远居中显示 UIBarButtonItem            // 专门用于设置导航条按钮和工具条按钮  initWithBarButtonSystemItem: UIBarButtonSystemItemCancel target: self action: @selector() // 使用系统提供按钮  initWithTitle: style: UIBarButtonItemsStylePlain target: self action: @selector()    // 自定义标题      // Plain风格会根据导航条风格变换颜色, Done风格永远为蓝色  initWithCustomView:    // 自定义view self.navigationItem.leftBarButtonItem = barButtonItem;    rightBarButtonItem  self.navigationItem.rightBarButtonItems = barButtonItemsArray    // 在导航控制器一侧加入多个按钮, 先将按钮放入数组中9.UIToolbar 只要有导航控制器就有工具条, 没有导航控制器就没有工具条, 一般工具条是隐藏的. [self.navigationController setToolbarHidden: NO animated: YES];    // 显示工具条 UIBarButtonSystemItemFlexibleSpace是加空格用的 self.toolbarItems = barButtonItemsArray    // 将按钮加到工具条上 [self.navigationController.toolbar setBackgroundImage: forToolbarPosition: UIToolbarPositionBottom barMetrics: UIBarMetricsDefault];        // forToolbarPosition当工具条在哪个位置的时候显示图片 self.navigationController.toolbar.frame    // 设置工具条位置10.UITextField 文本输入框, 背景默认为透明色, clearColor, 使用代理收起键盘textField.text    // 文本框中的内容 textField.borderStyle = UITextBorderStyleRoundedRect;        // 设置边框样式 textField.placeholder        // 设置提示文字 textField.keyboardType = UIKeyboardTypeEmailAddress;        // 设置键盘样式 textField.secureTextEntry = YES;    // 设置密文输入 textField.clearButtonMode = UITextFieldViewModeWhileEditing;    // 设置清空按钮 [textField resignFirstResponder];    // 取消第一响应者, 让文本输入框收起键盘退出编辑模式 [textField becomeFirstResponder];    // 让文本输入框成为第一响应者, 弹出键盘进入编辑模式11.UITextView textView.text        // 设置UITextView中的文字 textView.font        // 设置UITextView的字体 textView.editable = NO    // 设置textView不能编辑12.[NSNotificationCenter defaultCenter] 系统通知中心, 是观察者模式的一种体现 (在IOS中: 代理用作1对1, 通知中心用作多对多); 通知中心只有三种操作, 订阅消息, 发送消息, 取消订阅消息 [[NSNotificationCenter defaultCenter] addObserver: self selector: @selector(keyboardWillShow) name: UIKeyboardWillShowNotification object: nil]    // 键盘将要升起时, 发送一条消息给@selector(), 还有WillHide13.UISegmentedControl 将一组选项放在数组中, initWithItems: array [segmentedControl insertSegmentWithTitle: atIndex: animated: ]; segmentedControl.selectedSegmentIndex        // 选中的选项的索引 [segmentedControl titleForSegmentAtIndex: ]    // 指定索引文字的选项 segmentedControl.momentary = YES    // 默认选项选中后会一直保持选中状态, 设为YES会变为原样 UISegmentedControlStyle        // 设置控件风格, 默认为Plain [segmentedControl setTintColor: ]    // 设置色调 [segmentedControl addTarget: self action: @selector() forControlEvents: UIControlEventValueChanged];14.UISwitch frame的宽和高, 对开关没影响 [switch setOn: YES animated: YES]        // 设置开关为开状态, 默认是关 [switch addTarget: self action: @selector() forControlEvents: UIControlEventValueChanged]; switch.isOn        switch.isOff15.UISlider slider.minimumValue        // 设置最小值 slider.maximumValue        // 设置最大值 slider.value            // 设置当前默认值 setThumbImage: forState:    // 设置slider上的小滑块thumb的图片 [slider addTarget: self action: @selector() forControlEvents: UIControlEventValueChanged];    // 增加滑动事件16.UIProgressView initWithProgressViewStyle: UIProgressViewStyleDefault progressView.progress        // 设置进度条的值17.UIStepper stepper.maximumValue        // 设置最大值, 默认为0 - 100 stepper.minimumValue        // 设置最小值 stepper.stepValue        // 设置步长 addTarget: self action: @selector() forControlEvents:    UIControlEventValueChanged    // 添加点击事件18.UIActivityIndicatorView (活动等待器) initWithActivityIndicatorStyle: UIActivityIndicatorStyleWhite    // 设置模式 [activityIndicatorView startAnimating];        // 开始 [activityIndicatorView stopAnimating];        // 停止19.UITouch touch有三个函数, 点击时, 会自动调用这三个函数, 不需要初始化, 直接用这三个函数就行, touch得到的是坐标 -(void) touchesBegan: (NSSet *) touches withEvent: (UIEvent *) event {  // 在哪个view中就相对于哪个view计算坐标  CGPoint point = [[touches anyObject] locationInView: ]; } -(void) touchesMoved: (NSSet *) touches withEvent: (UIEvent *) event -(void) touchesEnded: (NSSet *) touches withEvent: (UIEvent *) event20.UIGestureRecognizer(抽象类, 手势) 1)UITapGestureRecognizer        // 点击 2)UIPinchGestureRecognizer        // 捏合  gestureRecognizer.scale            // 比例 3)UIRotationGestureRecognizer        // 旋转  [gestureRecognizer rotation]        // 弧度 4)UISwipeGestureRecognizer        // 滑动, 快速滑动, 用于监测滑动的方向  [swipe setDirection:UISwipeGestureRecognizerDirectionUp]    // 向上 5)UIPanGestureRecognizer        // 托移, 慢速移动, 用于监测偏移的量 6)UILongPressGestureRecognizer    // 长按 [A requireGestureRecognizerToFail: B]    // A手势满足条件, 不会立即触发, 等B手势确定失败后再触发A手势21.UIWebView NSURLRequest * request = [NSURLRequest requestWithURL: [NSURL URLWithString: ]];    // 新建一个request [webView loadRequest: request];    // 装载request webView.scalesPageToFit = YES;    // 自动适应到当前屏幕大小 [webView loadHTMLString: baseURL: nil]    // 装载本地HTML String// webView的各种状态都是通过delegate回调获得的  - (BOOL)webView: shouldStartLoadWithRequest: navigationType:    - (void)webViewDidStartLoad:(UIWebView *)webView;  - (void)webViewDidFinishLoad:(UIWebView *)webView;  - (void)webView:(UIWebView *)webView didFailLoadWithError: (NSError *)error;22.UITabBarController 高度为49, 视图控制器的height会从原来的460缩小到411, 每个选项卡都是相对独立的, 互不影响 viewController.title        // 设置TabBarController上的标题 viewController.tabBarItem.image        // 设置TabBarController上的图片 viewController.tabBarItem.badgeValue    // 设置选项卡微标 UITabBarItem * tabBarItem = [[UITabBarItem alloc] initWithTabBarSystemItem: tag: ]    // 使用系统自带样式选项卡, 为了能得到选项卡标题, 还应该手动设置下title. tabBarController.viewControllers = array;    // 数组中存储各种视图控制器或导航控制器 tabBarController.selectedIndex        // 设置默认选中的选项卡 tabBarController.selectedViewController 一个TabBarController中包含两个子view (第一个子view用来显示状态栏, 导航控制器, 视图控制器等; 第二个子view为选项卡) 隐藏TabBarController时需要将第二个的子view的坐标移到屏幕外, 并将第一个view的高度改为480  tabBarController.view.subviews    // 选项卡控制器中的两个子视图 tabBarController.viewControllers    // 选项卡控制器中的所有控制器 tabBarController.delegate = self;        // 设置代理-(void) tabBarController: didSelectViewController:    // 点中选项卡后会触发此代理中的方法 -(void) tabBarController: didEndCustomizingViewControllers: changed:    // 编辑结束后触发此方法23.NSUserDefaults NSUserDefaults是一中本地存储机制, 保存的内容不会消失(下次打开看程序时还会出现), 用来存储一些如对程序的设置等小型数据,  能存储的数据类型: NSString, NSNumber, NSArray, NSDictionary, NSData, NSDate,  用法类似于字典, 整个程序中有且只有一个UserDefaults. [NSUserDefaults standardUserDefaults]        // 声明, 只能用这一种方法 [userDefaults setObject: forKey: ]        // 存储数据 [userDefaults synchronize]            // 同步给系统, 否则不能保存 [userDefaults objectForKey: ]            // 读取数据 [userDefaults removeObjectForKey: ]        // 清楚保存的值24.UIScrollView scrollView.contentSize    // 只有当contentSize大于frame时才可以滚动 scrollView.showsHorizontalScrollIndicator = NO;    // 隐藏横向滚动条 scrollView.showsVerticalScrollIndicator = NO;        // 隐藏纵向滚动条 scrollView.bounces = NO;    // 取消弹性机制 scrollView.scrollEnabled = YES;    // scrollView是否可以滚动 scrollView.pagingEnabled = YES;    // 设置按页翻滚, 一页的大小就是frame的大小 scrollView.contentOffset = point;    // 设置偏移量 [scrollView setContentOffset: animated: ]  scrollView.delegate = self;        //协议中的函数:  -(void) scrollViewWillBeginDragging:            // 开始拖拽的时候调用此函数  -(void) scrollViewDidScroll:                // 滚动中调用此函数  -(void) scrollViewDidEndDragging: willDecelerate:    // 结束拖拽的时候调用此函数  -(void) scrollViewWillBeginDecelerating:        // 开始减速的时候调用此函数  -(void) scrollViewDidEndDecelerating:            // 结束减速的时候调用此函数 设置scrollView缩放  1)加上scrollView的delegate  2)设置最大放大倍数和最小缩小倍数    scrollView.maximumZoomScale = 3.0;    scrollView.minimumZoomScale = 1.0;  3)实现协议中的放大缩小方法    -(UIView *) viewForZoomingInScrollView:      return [scrollView.subviews objectAtIndex: ];    // 放大缩小哪个view就返回哪个view  4)不用去考虑contentSize的变化, 系统会自动完成25.UITableView UITableView使用的都是协议中的方法,tableView.dataSource = self;    tableView.delegate = self; [tableView reloadData]    // 刷新表单 initWithFrame: style:UITableViewStylePlain        // 设置表单的样式, 还有一个Groupes -(NSInteger) numberOfSectionsInTableView:        // 返回tableView有几个分组(默认为1) -(CGFloat) tableView:    heightForHeaderInSection:    // 设置分组的头标高度(Section用来判断是哪个分组) -(CGFloat) tableView: heightForFooterInSection:    // 设置分组的脚标的高度 -(NSInteger) tableView: numberOfRowsInSection:    // 设置一个分组中有多少行 -(CGFloat) tableView: heightForRowAtIndexPath:    // 设置每个分组(indexPath.section)中每行(indexPath.row)的行高 -(UITableViewCell *) tableView: cellForRowAtIndexPath:    // 一行有一个Cell, 每出现一行就执行一次这个方法 {  static NSString * identifier = @"cell";        // 声明一个cell的标签, 使用static即只用声明一次, 之后不再释放  UITableViewCell * cell = [tableView dequeueReusableCellWithIdentifier: identifier];    // 去cell复用池中找是否有对应标签的闲置cell, 如果找到就先手动清空原内容后再使用, 如果没有找到则实例化新的cell  if (cell == nil)  {      cell = [[[UITableViewCell alloc] initWithStyle: UITabViewCellStyleSubtitle reuseIdentifier: identifier] autorelease];    // 实例化新的cell, 并给cell打上标签  }  cell.textLabel.text        // 设置主标题          cell.detailTextLabel.text    // 设置副标题(只有在Subtitle风格下才可以显示)  cell.imageView.image        // 设置头像图片  cell.accessoryType = UITableViewCellAccessoryDetailDisclosureButton    // 设置cell右侧按钮, 只有这种模式有点击事件      (-(void) tableView: accessoryButtonTappedForRowWithIndexPath:    // 按钮的点击事件函数)  cell.selectionStyle = UITableViewCellSelectionStyleGray        // 设置cell整体被点击过后的样式 } // 自定义的cell要继承自UITableViewCell // cell本身是一个view, 在cell上面还有一个contentView, 自定义的各种控件要加在contentView上 -(NSString *) tableView: titleForHeaderInSection:    // 设置分组头标 -(NSString *) tableView: titleForFooterInSection:    // 设置分组脚标 -(void) setEditing: animated:    // TableView编辑模式, 有系统提供按钮(self.editButtonItem, 只能在导航栏上, 先调用父类的此方法, 再调用自己的此方法), 也可以自定义按钮(按钮事件中使用此方法) -(UITableViewCellEditingStyle) tableView: editingStyleForRowAtIndexPath:    // 设置对应的行是删除还是添加操作  -(void) tableView: commitEditingStyle: forRowAtIndexPath:    // 编辑下的添加, 删除    都是在数据源中操作, 添加或删除数据源, 之后再执行添加或删除动画, 刷新tableView界面  [tableView deleteRowsAtIndexPaths: [NSArray arrayWithObject:indexPath] withRowAnimation: ]  [tableView insertRowsAtIndexPaths: [NSArray arrayWithObject:indexPath] withRowAnimation: ] -(void) tableView: moveRowAtIndexPath: toIndexPath:        // 移动行, 在数据源中删除对应项, 并插入对应项 -(void) tableView: didSelectRowAtIndexPath:            // 设置每一行点击  [tableView deselectRowAtIndexPath: indexPath animated: YES]    // 设置自动反选, (取消点击)  -(void) tableView: didDeselectRowAtIndexPath:        // 设置反选时, 触发的方法, 如果在点击中设置了自动反选, 则不会触发此方法【搜索栏】UISearchBar  tableView.tableHeaderView = searchBar        // 设置searchBar的frame后, 加入到tableHeaderView中【搜索控制器】UISearchDisplayController        // 搜索控制器在搜索的时候, 会自动生成一个tableView, 此时有多个tableView, 任一个tableView都会调用上面的方法, 至于是哪个tableView调用上面的方法, 需要自己判断      [[UISearchDisplayController alloc] initWithSearchBar: searchBar contentsController: self]    // 初始化, 不要释放  searchDisplayController.searchResultsDataSource = self;  searchDisplayController.searchResultsDelegate = self; -(NSArray *) sectionIndexTitlesForTableView:        // 设置一个索引条(用数组下标和section数进行一一对应, 而不是用文字)    搜索图标 UITableViewIndexSearch -(NSInteger) tableView: sectionForSectionIndexTitle: atIndex:    // 设置索引条对应关系      [tableView scrollRectToVisible: searchBar.frame animated: YES]; return index - 1;    // 带搜索图标的对应关系26.不同视图间的传值 1)从A --> B (B是A的一个成员变量)  a.定义一个B的属性, 使用属性进行传值 (最方便)  b.重载B的init方法, 增加一个传值的参数  c.使用NSUserDefaults  d.使用AppDelegate      因为AppDelegate是一个单例类, 即在整个程序中实例化的所有对象都是同一个对象, 所以可以在AppDelegate中定义一个属性, 用来在A中存值, 在B中使用.    AppDelegate的实例化方法: AppDelegate * appDelegate = [UIApplication sharedApplication].delegate; 2)从B --> A (B是A的成员变量, 值返回传送, 此时用代理更方便)  B是发送方, A是接收方; 因此在B中写协议的内容(发送方是接收方的成员变量), 并且在B中声明一个属性, 来持有这个协议, 并调用协议中的方法; A遵守此协议, 并写出B中属性的代理者为A本身(b.delegate = self)和协议中方法的实现.27.UIPickerView 用法类似于tableView, 也有两个协议,pickerView.dataSource = self;        pickerView.delegate = self; pickerView.showsSelectionIndicator = YES; -(NSInteger)numberOfComponentsInPickerView:    -(NSInteger)pickerView: numberOfRowsInComponent: -(NSString *)pickerView: titleForRow: forComponent:28.UIDatePicker datePicker.datePickerMode = UIDatePickerModeDateAndTime; (Time, Date, CountDownTimer)        // 四种样式29.UIAlertView initWithTitle: message: delegate: self cancelButtonTitle: @"Cancel" otherButtonTitles: @"OK", nil [alertView show]    // 显示通知 UIAlertViewStyle (PlainTextInput, SecureTextInput, LoginAndPasswordInput)    // 通知的输入框样式 [alertView buttonTitleAtIndex:]        // 得到按钮的title-(void) alertView: clickedButtonAtIndex:    // 处理点击的是那个按钮  -(void)alertViewCancel:  -(void)willPresentAlertView:  -(void)didPresentAlertView:  -(void)alertView: willDismissWithButtonIndex:  -(void)alertView: didDismissWithButtonIndex:  -(BOOL)alertViewShouldEnableFirstOtherButton:30.UIActionSheet initWithTitle: delegate:self cancelButtonTitle: destructiveButtonTitle: otherButtonTitles:, nil-(void)actionSheet: clickedButtonAtIndex:    -(void)actionSheetCancel:  -(void)willPresentActionSheet:  -(void)didPresentActionSheet:    -(void)actionSheet: willDismissWithButtonIndex:    -(void)actionSheet: didDismissWithButtonIndex:(NSInteger)buttonIndex;31.iPhone文件系统 1)Home目录的结构(NSString *) NSHomeDirectory(); 或 [NSBundle mainBundle]      MyApp.app    // 项目工程的目录              Documents    // 存储图像文档等由应用程序生成的数据            // [[[NSBundle mainBundle] resourcePath] stringByAppendingPathComponent:@"Documents"]    // [NSHomeDirectory() stringByAppendingPathComponent:@"Documents"]      Library        // 存储程序的用户默认设置和其他状态信息        Caches        Preferences    tmp        // 存放临时文件, 重启iPhone时会丢失              // NSTemporaryDirectory();32.AVAudioPlayer 库文件AVFoundation.framework, 头文件[[[AVAudioPlayer alloc] initWithContentsOfURL:[NSURL fileURLWithPath:[[NSBundle mainBundle] pathForResource:@"Burning" ofType:@"mp3"]] error:nil]        // 使用url只能播放本地文件, 使用data可以播放网络资源(但须一次性加载完, 不实用)

player.volume                // 设置音量, 在0到1之间

player.numberOfLoops = 2;        // 播放次数

player.currentTime = 15.0;        // 播放开始的时间

[player prepareToPlay]        // 加入播放队列, 一次只播放一首, 想同时播放多首, 要在不同的声道播放

[player play]

[player stop]

33.MPMoviePlayerController

库文件MediaPlayer.framework,

[[MPMoviePlayerController alloc] initWithContentURL: ]    // 这个url既可以播放本地也可以播放网络资源

moviePlayer.movieControlStyle = MPMovieControlModeDefault;    // 设置控制器样式

moviePlayer.scalingMode = MPMovieScalingModeAspectFit;    // 屏幕宽高比例

// MPMovieScalingModeNone            不做任何缩放

// MPMovieScalingModeAspectFit       适应屏幕大小,保持宽高比

// MPMovieScalingModeAspectFill      适应屏幕大小,保持宽高比,可裁剪

// MPMovieScalingModeFill            充满屏幕,不保持宽高比

[moviePlayer play];

[moviePlayer stop];

34.多语言环境

要添加需要的语言, 系统会根据所使用系统的语言, 自动使用对应的语言

1)系统自动生成两份XIB文件, 对应着中英文写内容

2)手动添加几份Strings File的文件, 对应着分别放入语言文件夹中, en.lproj或zh-Hans.lproj

文件以键值对的形式存在, "key" = "value";(不使用OC字符串, 以分号结尾)

NSLocalizedStringFromTable(@"key", @"fileName", nil);    // 调用时使用, 第一个参数为要获得的关键字, 第二个参数为关键字所在的文件的名字, 文件都是以".strings"结尾的

当文件名为NSLocalizable.strings时, 表示是系统缺省的名字, 使用方法NSLocalizedString(@"key", @"value");

推荐阅读更多精彩内容