iOS 网易彩票-5设置模块二
产品推荐
产品推荐使用的是UICollectionView控件,UICollectionView 和 UICollectionViewController 类是iOS6 新引进的API,用于展示集合视图,布局更加灵活,可实现多列布局,用法类似于UITableView 和 UITableViewController 类。
思路:
- 模型:建立一个MJProduct模型,存放产品的相关信息(标题、图标)
- 视图:创建xib,继承于UICollectionViewCell
- 控制器:创建MJProductViewController,继承于UICollectionViewController
- 数据读取通过product.json文件
模型创建
MJProduct.h
#import <Foundation/Foundation.h> @interface MJProduct : NSObject
/** 标题 */
@property (nonatomic, copy) NSString *title;
/** 图标 */
@property (nonatomic, copy) NSString *icon; -(instancetype)initWithDict:(NSDictionary *)desc;
+(instancetype)productWithDict:(NSDictionary *)desc;
@end
MJProduct.m
//
// MJProduct.m
// Lottery
//
// Created by jiangys on 15/9/7.
// Copyright (c) 2015年 weconex. All rights reserved.
// #import "MJProduct.h" @implementation MJProduct -(instancetype)initWithDict:(NSDictionary *)desc
{
if (self=[super init]) {
self.title=desc[@"title"];
self.icon=desc[@"icon"];
}
return self;
} +(instancetype)productWithDict:(NSDictionary *)desc
{
return [[self alloc] initWithDict:desc];
} @end
视图xib创建
新建一个xib,分别拉入
CollectionViewCell,Class指定MJProductCell,Size选Freeform,大小80*80
ImageView ,大小55*50
Label,字体11px,大小80*24,居然显示
MJProductCell.h
//
// MJProductCell.h
// Lottery
//
// Created by jiangys on 15/9/7.
// Copyright (c) 2015年 weconex. All rights reserved.
// #import <Foundation/Foundation.h>
@class MJProduct; @interface MJProductCell : UICollectionViewCell
/** 产品模型 */
@property (nonatomic, strong) MJProduct *product;
@end
MJProductCell.m
//
// MJProductCell.m
// Lottery
//
// Created by jiangys on 15/9/7.
// Copyright (c) 2015年 weconex. All rights reserved.
// #import "MJProductCell.h"
#import "MJProduct.h"
@interface MJProductCell() @property (weak, nonatomic) IBOutlet UIImageView *iconView;
@property (weak, nonatomic) IBOutlet UILabel *nameLabel; @end @implementation MJProductCell -(void)awakeFromNib
{
//设置图片圆角
self.iconView.layer.cornerRadius=;
self.iconView.clipsToBounds=YES;
} -(void)setProduct:(MJProduct *)product
{
_product=product;
self.iconView.image=[UIImage imageNamed:product.icon];
self.nameLabel.text=product.title;
}
@end
分别为imageview和Label拖线到MJProductCell.m中。
控制器实现
我们编写的product.json格式如下:
[
{
"title": "网易电影票",
"id": "com.netease.movie",
"url": "http://itunes.apple.com/app/id583784224?mt=8",
"icon": "movie",
"customUrl": "movieticket163"
},
{
"title": "网易新闻",
"id": "com.netease.news",
"url": "http://itunes.apple.com/app/id425349261?mt=8",
"icon": "newsapp",
"customUrl": "newsapp"
},
{
"title": "网易公开课",
"id": "com.netease.videoHD",
"url": "http://itunes.apple.com/app/id415424368?mt=8",
"icon": "open",
"customUrl": "ntesopen"
},
{
"title": "网易电视指南",
"id": "com.netease.tvguide",
"url": "http://itunes.apple.com/app/id480095986",
"icon": "tvguide",
"customUrl": "tvguide"
},
{
"title": "网易阅读",
"id": "com.netease.iphonereader",
"url": "http://itunes.apple.com/app/id462186890?mt=8",
"icon": "reader",
"customUrl": ""
},
{
"title": "网易云相册",
"id": "com.netease.cloudphotos",
"url": "http://itunes.apple.com/app/id451931841?mt=8",
"icon": "cloudphotos",
"customUrl": ""
},
{
"title": "网易手机邮",
"id": "com.netease.RPMMS-UI",
"url": "http://itunes.apple.com/app/id371634015?mt=8",
"icon": "shoujiyou",
"customUrl": ""
},
{
"title": "网易微博",
"id": "com.netease.microblogging",
"url": "http://itunes.apple.com/app/id383629309?mt=8",
"icon": "newb",
"customUrl": "microblogging"
},
{
"title": "有道词典",
"id": "youdaoPro",
"url": "http://itunes.apple.com/app/id353115739?mt=8",
"icon": "youdao",
"customUrl": "yddictProapp"
},
{
"title": "饭饭",
"id": "fanfan",
"url": "https://itunes.apple.com/cn/app/fan-fan/id487503086?mt=8",
"icon": "fanfan",
"customUrl": ""
},
{
"title": "有道笔记",
"id": "com.youdao.note.iphone",
"url": "http://itunes.apple.com/app/id450748070?mt=8",
"icon": "youdaonote",
"customUrl": ""
},
{
"title": "恵恵",
"id": "cn.huihui.Guide",
"url": "https://itunes.apple.com/cn/app/hui-hui-gou-wu-jin-nang-shang/id650705207?mt=8&ls=1",
"icon": "huihui",
"customUrl": ""
}
]
MJProductViewController.h
//
// MJProductViewController.h
// Lottery
//
// Created by jiangys on 15/9/7.
// Copyright (c) 2015年 weconex. All rights reserved.
// #import <UIKit/UIKit.h> @interface MJProductViewController : UICollectionViewController @end
MJProductViewController.m
//
// MJProductViewController.m
// Lottery
//
// Created by jiangys on 15/9/7.
// Copyright (c) 2015年 weconex. All rights reserved.
// #import "MJProductViewController.h"
#import "MJProduct.h"
#import "MJProductCell.h" @interface MJProductViewController ()
@property(nonatomic,strong) NSArray *products;
@end @implementation MJProductViewController static NSString * const reuseIdentifier = @"Cell"; -(NSArray *)products
{
if (_products==nil) {
// JSON文件的路径
NSString *path=[[NSBundle mainBundle] pathForResource:@"products.json" ofType:nil];
// 加载JSON文件
NSData *data=[NSData dataWithContentsOfFile:path];
// 将JSON数据转换成NSArray
NSArray *dictArray=[NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil];
// 将字典转为模型
NSMutableArray *productArray=[NSMutableArray array];
for (NSDictionary *dict in dictArray) {
MJProduct *p=[MJProduct productWithDict:dict];
[productArray addObject:p];
}
_products=productArray;
}
return _products;
} -(instancetype)init
{
// 1.流水布局
UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc] init];
// 2.每个cell的尺寸
layout.itemSize = CGSizeMake(, );
// 3.设置cell之间的水平间距
layout.minimumInteritemSpacing = ;
// 4.设置cell之间的垂直间距
layout.minimumLineSpacing = ;
// 5.设置四周的内边距
layout.sectionInset = UIEdgeInsetsMake(layout.minimumLineSpacing, , , );
return [super initWithCollectionViewLayout:layout]; } - (void)viewDidLoad {
[super viewDidLoad]; // 1.注册cell(告诉collectionView将来创建怎样的cell)
UINib *nib=[UINib nibWithNibName:@"MJProductCell" bundle:nil];
[self.collectionView registerNib:nib forCellWithReuseIdentifier:@"Product"]; self.collectionView.backgroundColor=[UIColor whiteColor];
// Register cell classes
//[self.collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:reuseIdentifier]; // Do any additional setup after loading the view.
} - (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
} /*
#pragma mark - Navigation // In a storyboard-based application, you will often want to do a little preparation before navigation
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender {
// Get the new view controller using [segue destinationViewController].
// Pass the selected object to the new view controller.
}
*/ #pragma mark <UICollectionViewDataSource> - (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section {
return self.products.count;
} - (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath { MJProductCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"Product" forIndexPath:indexPath];
// 传递模型
cell.product=self.products[indexPath.item];
return cell;
} // 代理,选中
-(void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath
{
MJProduct *p=self.products[indexPath.item];
NSLog(@"点击了 %@",p.title);
} @end
效果:
帮助
要实现的效果:
思路:
1.帮助列表使用加载json文件
2.显示帮助说明的页面,使用加载html显示
html.json文件
[
{
"title" : "如何领奖?",
"html" : "help.html",
"id" : "howtoprize"
},
{
"title" : "如何充值?",
"html" : "help.html",
"id" : "howtorecharge"
},
{
"title" : "如何提现?",
"html" : "help.html",
"id" : "howtowithdraw"
},
{
"title" : "如何购彩?",
"html" : "help.html",
"id" : "howtobuy"
},
{
"title" : "如何连续多期买同一注号码?",
"html" : "help.html",
"id" : "whatisfollowandtimes"
},
{
"title" : "如何跟别人合资买彩票?",
"html" : "help.html",
"id" : "howtogroupbuy"
},
{
"title" : "如何快速支付?",
"html" : "help.html",
"id" : "howtoquickpay"
},
{
"title" : "如何投注双色球",
"html" : "ssq_howto.html"
},
{
"title" : "如何投注大乐透",
"html" : "dlt_howto.html"
},
{
"title" : "如何投注11选5",
"html" : "y11_howto.html"
},
{
"title" : "如何投注广东11选5",
"html" : "gdy11_howto.html"
},
{
"title" : "如何投注老11选5",
"html" : "jxy11_howto.html"
},
{
"title" : "如何投注好运11选5",
"html" : "lk11_howto.html"
},
{
"title" : "如何投注快3",
"html" : "k3_howto.html"
},
{
"title" : "如何投注快2",
"html" : "k2_howto.html"
},
{
"title" : "如何投注竞彩足球",
"html" : "jczq_howto.html"
},
{
"title" : "如何投注竞彩篮球",
"html" : "jclq_howto.html"
},
{
"title" : "如何投注足球单场",
"html" : "bjdc_howto.html"
},
{
"title" : "如何投注3D",
"html" : "x3d_howto.html"
},
{
"title" : "如何投注老时时彩",
"html" : "ssc_howto.html"
},
{
"title" : "如何投注七星彩",
"html" : "qxc_howto.html"
},
{
"title" : "如何投注七乐彩",
"html" : "qlc_howto.html"
},
{
"title" : "如何投注排列5",
"html" : "pl5_howto.html"
},
{
"title" : "如何投注排列3",
"html" : "pl3_howto.html"
},
{
"title" : "如何投注快乐8",
"html" : "kl8_howto.html"
},
{
"title" : "如何投注新时时彩",
"html" : "jxssc_howto.html"
},
{
"title" : "如何投注胜负彩",
"html" : "sfc_howto.html"
},
{
"title" : "如何投注任选九",
"html" : "f9_howto.html"
}
]
建立显示帮助列表模型
MJHtml.h
#import <Foundation/Foundation.h> @interface MJHtml : NSObject
/** ID */
@property (nonatomic, copy) NSString *ID;
/** 网页标题 */
@property (nonatomic, copy) NSString *title;
/** 网页文件名 */
@property (nonatomic, copy) NSString *html; -(instancetype)initWithDict:(NSDictionary *)dict;
+(instancetype)htmlWithDict:(NSDictionary *)dict;
@end
MJHtml.m
#import "MJHtml.h" @implementation MJHtml -(instancetype)initWithDict:(NSDictionary *)dict
{
if (self=[super init]) {
self.html=dict[@"html"];
self.title=dict[@"title"];
self.ID=dict[@"id"];
}
return self;;
} +(instancetype)htmlWithDict:(NSDictionary *)dict
{ return [[self alloc]initWithDict:dict];
} @end
建立一个列表controller,显示帮助列表,继承于MJBaseSettingViewController
MJHelpViewController.h
#import "MJBaseSettingViewController.h" @interface MJHelpViewController : MJBaseSettingViewController @end
MJHelpViewController.m
//
// MJHelpViewController.m
// Lottery
//
// Created by apple on 15/9/13.
// Copyright (c) 2015年 weconex. All rights reserved.
// #import "MJHelpViewController.h"
#import "MJHtml.h"
#import "MJSettingItem.h"
#import "MJSettingArrowItem.h"
#import "MJSettingGroup.h"
#import "MJHtmlViewController.h"
#import "MJNavigationController.h" @interface MJHelpViewController ()
@property(nonatomic,strong)NSMutableArray *htmls;
@end @implementation MJHelpViewController -(NSMutableArray *)htmls
{
if (_htmls==nil) { // 不加这一句代码,htmls数据加载不出来
_htmls = [NSMutableArray array]; // json文件路径
NSString *path=[[NSBundle mainBundle] pathForResource:@"help.json" ofType:nil]; // 加载json文件
NSData *data=[NSData dataWithContentsOfFile:path]; // 将JSON数据转为NSArray
NSArray *dictArray=[NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableContainers error:nil]; // 将字典转为模型
for (NSDictionary *dict in dictArray) {
MJHtml *html=[MJHtml htmlWithDict:dict];
[_htmls addObject:html];
}
}
return _htmls; } - (void)viewDidLoad {
[super viewDidLoad]; // 创建所有的item
NSMutableArray *items=[NSMutableArray array];
for (MJHtml *html in self.htmls) {
MJSettingItem *item=[MJSettingArrowItem itemWithTitle:html.title destVcClass:nil];
[items addObject:item];
} // 创建组
MJSettingGroup *group=[[MJSettingGroup alloc] init];
group.items=items;
[self.data addObject:group];
} // 重写跳转方法
-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
MJHtmlViewController *htmlVc = [[MJHtmlViewController alloc] init];
// 页面传值
htmlVc.html = self.htmls[indexPath.row];
//使用自定义导航栏
MJNavigationController *nav = [[MJNavigationController alloc] initWithRootViewController:htmlVc];
[self presentViewController:nav animated:YES completion:nil];
} @end
最后,就是加载UIWebView,显示帮助信息
MJHtmlViewController.h
#import <UIKit/UIKit.h>
@class MJHtml; @interface MJHtmlViewController : UIViewController /** hmtl模型 */
@property (nonatomic, strong) MJHtml *html;
@end
MJHtmlViewController.m
#import "MJHtmlViewController.h"
#import "MJHtml.h" @interface MJHtmlViewController ()<UIWebViewDelegate> @end @implementation MJHtmlViewController -(void)loadView
{
self.view=[[UIWebView alloc] init];
} - (void)viewDidLoad {
[super viewDidLoad]; //设置标题
self.title=self.html.title; UIWebView *webView=(UIWebView *)self.view;
webView.delegate=self; // 创建URL
NSURL *url=[[NSBundle mainBundle] URLForResource:self.html.html withExtension:nil]; //创建请求
NSURLRequest *request=[NSURLRequest requestWithURL:url]; // 发送请求加载网页
[webView loadRequest:request]; // 设置左上角的关闭按钮
self.navigationItem.leftBarButtonItem=[[UIBarButtonItem alloc] initWithTitle:@"关闭" style:UIBarButtonItemStylePlain target:self action:@selector(close)];
} -(void)close
{
[self dismissViewControllerAnimated:YES completion:nil];
} /**
* 网页加载完毕的时候调用
*/
-(void)webViewDidFinishLoad:(UIWebView *)webView
{
// 跳到id对应的网页标签 // 1.拼接Javacript代码
NSString *js = [NSString stringWithFormat:@"window.location.href = '#%@';", self.html.ID];
// 2.执行JavaScript代码
[webView stringByEvaluatingJavaScriptFromString:js];
} @end
系统源码下载:点击下载
iOS 网易彩票-5设置模块二的更多相关文章
- iOS 网易彩票-6设置模块三(常用小功能)
该篇文章中,用到很多iOS开发过程中常用的小功能,当前只是将这些功能集成到网易彩票的设置中.iOS-常用小功能介绍,请参考我的另一篇文章: iOS 常用小功能 总结:http://www.cnblog ...
- iOS 网易彩票-4设置模块一
概述 基本上,每一款APP都有相应的设置模块.怎么设置才能更灵活和通用呢,这也是大家一直思考的.下面说说在网易彩票中,设置模块的设置思想. 基本上有三种方案: static cell(呆板,完全没有动 ...
- iOS 网易彩票-1框架搭建
仿网易彩票,最终要做成的效果如下: 一.分层搭建 1.新建一个项目,Lottery.只支持7.1以上坚屏. 2.将素材全部图片全部拉到相应的文件夹里. 3.选中Lottery--右键Show in F ...
- iOS 网易彩票-3常见设置
Navigation导航设置 为了统一管理导航控制器,需要自定义导航控制器MJNavigationController,继承于UINavigationController.分别设置5个Navigati ...
- iOS 网易彩票-2框架搭建-代码重构
在上一篇中,我们基本已经把整个框架都搭建出来了,下面进行代码重构一下. 思路: 导航按钮,按下时,会变灰,那是系统自带了,通过自定义UIButton,实现按下按钮立即切换效果. MJTabBarCon ...
- iOS菜鸟成长笔记(2)——网易彩票练习
距离上一篇<第一个iOS应用>已经有一个多月了,今天来和大家一起学习和分享一下一个小练习<网易彩票> 首先我们向storyboard中拖入一个TabBarController和 ...
- iOS开发——实战总结OC篇&网易彩票开发知识点总结
网易彩票开发知识点总结 关于网易彩票开发中遇到了不少的坑,弄了好久才弄懂,或者有些犹豫很久没用就不记得了,所以这里就总结了一下,希望以后不会忘记,就算忘记也能快速查看! /************** ...
- 再造轮子之网易彩票-第一季(IOS 篇 by sixleaves)
前言 在网上看了别人做的模仿网易彩票的项目, 于是也跟着用自己的想法做了一篇.写这篇博客的目的, 在于UI综合的一次小练习, 同时总结和串联其各个控件之间的应用.封装思想等.考虑到有人上不了githu ...
- WPF仿网易云音乐系列(二、歌单创建窗口+登录设置模块)
老衲牺牲午休时间写博客,都快把自己感动了,-_-!! 之前上一篇随笔,我看了下评论,有部分人说WPF已经凉凉了,这个我觉得,这只是一个达到自己目的的工具而已,只要自己能用这个工具,得心应手的做出自己想 ...
随机推荐
- spy-debugger 前端调试工具
一站式页面调试.抓包工具.远程调试任何手机浏览器页面,任何手机移动端webview(如:微信,HybirdApp等).支持HTTP/HTTPS,无需USB连接设备. Language: Engl ...
- 邮件MIME格式分析
http://www.cnblogs.com/crystalray/articles/3302427.html 邮件mime格式 参考: rfc4021,Registration of Mail an ...
- linux mint 安装 SecureCRT
最喜欢的ssh工具莫过于SecureCRT了,功能强大,方便易用.最近安装了mint17.1(基于ubuntu),就想安装一个SecureCRT来使用. [此SecureCRT仅作测试使用,不做商业用 ...
- requests源码分析
0.前言 (1) 拆部分reques中感兴趣t的轮子 (2)对一些感兴趣的pythonic写法做一些归纳 1.用object.__setattr__来初始化构造函数 反正我之前就是直接实例对象时把所有 ...
- Minix中的字符判定ctype.c
minix中关于如何判定一个字符的类型,如大写.小写.数字…… 如果采用传统的方法,如判断一个字母大写的方法: if(c>='A' && c<'Z') return tru ...
- windows网卡共享网络时,报Internet连接共享访问被启用时,出现了一个错误。(null)
今天笔者在自己电脑上作试验时,准备将无线网络连接共享给VMnet1时报Internet连接共享访问被启用时,出现了一个错误.(null)错误: 经上网查询到问题原因:没有启用 Windows Fire ...
- windows下的zookeeper安装
先在官网下载安装包(https://www.apache.org/dyn/closer.cgi/zookeeper/),单机安装非常简单,只要获取到 Zookeeper 的压缩包并解压到某个目录如:C ...
- PHP生成页面二维码解决办法?详解
随着科技的进步,二维码应用领域越来越广泛,今天我给大家分享下如何使用PHP生成二维码,以及如何生成中间带LOGO图像的二维码. 具体工具: phpqrcode.php内库:这个文件可以到网上下载,如果 ...
- python模块路径
Python会在以下路径中搜索它想要寻找的模块: 1. 程序所在的文件夹 2. 标准库的安装路径 3. 操作系统环境变量PYTHONPATH所包含的路径 将自定义库的路径添加到Python的库路径中去 ...
- 7.22 python面试题
2018-7-22 16:32:24 把面试题敲完了,,好强悍! Python 10期考试题 1.常用字符串格式化有那些?并说明他们的区别 # format 直接调用函数 # %s 语法塘 # %r ...