WYS APP
UI图:http://modao.io/app/H8eZCQdV1pskjQ7z8bLh
四个tab:我要赛、赛事、运动吧、个人中心
赛事页面
1、主要是个NavigationController
2、赛事主页面:SaiShiXinXiEventViewController
UITableView实现
- 点击整块,跳转到赛事详情页
- 点击星星,表示对赛事感兴趣
- 点击分享,分享赛事(预计要用第三方分享sdk)
- 点击筛选,弹出下拉筛选栏,筛选后刷新页面数据
- 点击城市,跳转到城市页
3、城市页:SaiShiXinXiCityViewController
UITableView实现
4、赛事详情页:SaiShiXinXiEventDetailViewController
UITableView实现
- 包含:图片、标题、价格、报名状态、位置、时间、主办方、活动介绍、查看图文详情、已报名赛友、感兴趣赛友、评论、推荐、立即报名
- 点击位置,跳转到地图页
- 点击查看图文详情,跳转到图文详情页
- 点击已报名赛友,跳转已报名赛友列表页
- 点击感兴趣赛友,跳转感兴趣赛友列表页
- 点击我要评论,跳转到评论列表页
- 点击立即报名,跳转到提交订单页
5、地图页:SaiShiXinXiMapViewController
预计要接入地图sdk
6、图文详情页:SaiShiXinXiImageTextDetailViewController
取PC端url,是个webview
7、已报名赛友列表页:SaiShiXinXiRegisteredPlayerListViewController
UITableView实现
8、感兴趣赛友列表页:SaiShiXinXiInterestedPlayerListViewController
UITableView实现
9、评论列表页:SaiShiXinXiCommentListViewController
UITableView实现
底部还一个添加评论
10、提交订单页:SaiShiXinXiOrderSubmitViewController
- 包含:标题、地址、时间、票价信息、参加人员、添加人员按钮、总价、提交按钮
- 点击参加人员的删除按钮,可删除
- 点击添加人员按钮,弹出填写报名信息浮层页,填写完信息后点击确定,可添加人员
- 点击提交按钮,跳转到手机验证页
11、手机验证页:SaiShiXinXiMobileVerificationViewController
验证成功后,弹出报名成功浮层页
问题:支付页?
2015.6.11
从赛事信息主页点击城市按钮,在城市页选择一个城市后跳转回主页面,这时候需要将选择的城市信息回传回来
http://blog.csdn.net/mad1989/article/details/7919504
网上搜了有三种方法:
1、建一个model来专门保存城市信息
2、notification实现
3、delegate实现
这里说一下第二种notification的实现方式
第一步:在发送数据的视图页面,注册+发送通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"cityNotification" object:@"testNotification"];
第二步:在接收数据的视图页面,接收通知
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(notificationHandle:) name:@"cityNotification" object:nil];
}
- (void)notificationHandle:(NSNotification *)notification {
self.selectedCity.title = [notification object];
}
2015.6.12
在自定义 UITableViewCell 时,通常在 初始化操作中加入subview,然后在 layoutSubviews 中定义 subview 的 frame
- (instancetype)initWithReuseIdentifier:(NSString *)reuseIdentifier {
self = [super initWithReuseIdentifier:reuseIdentifier]; if (self) { self.backgroundView.backgroundColor = [UIColor lightGrayColor]; _titleLabel = [[UILabel alloc] init];
_titleLabel.font = [UIFont systemFontOfSize:kEventInfomationTitleFontSize];
_titleLabel.text = @"2015年“中国移动4G杯”大理千人环洱海自行车赛";
_titleLabel.textColor = [UIColor whiteColor]; [self.contentView addSubview:_titleLabel];
} return self;
} - (void)layoutSubviews {
[super layoutSubviews]; CGFloat width = CGRectGetWidth(self.contentView.bounds); {
self.titleLabel.frame = CGRectMake(, , width-, );
[self.titleLabel sizeToFit];
}
}
sizeToFit意思是,如果label中的文字长度没有达到宽度的话,会自动缩短宽度以适配文字的长度;
问题:如何设置tableview的分割线为不可见
解答:
self.tableView.separatorStyle = UITableViewCellSeparatorStyleNone;
2015.6.13
经验:
UIView对象,如果用纯代码形式创建,调用的是 initWithFrame;
如果是在xib活着storyboard中创建,此时 initWithFrame 方法不会被调用,此时如果需要重新设置UIView的各项属性,可以在 initWithCoder 中设置;
问题:
如何设置 UITableViewCell 为不可选中状态
解答:
[cell setSelectionStyle:UITableViewCellSelectionStyleNone];
原来这种 selecetionStyle有None、Blue、Grey、Default,但在7.0系统之后,只有None和Default两种;
经验:
现在price、location、time、cup、type五种cell都是自定义的,其实有很多重复代码
考虑把图标和文字部分在一个cell的基类实现;
特别之处再另外添加,比如:
price的右侧,有个报名中的图标,可以考虑新建一个stateLabel,将之作为cell.accessoryView;
location的右侧,有个小箭头,这个应该可以系统实现;
cup文字的末尾,有个小图标表示政、体、企等,可以做个图标加上去;
问题:
在自定义的TableViewCell中加了一个属性 imageView,提示错误如下:
Auto property synthesis will not synthesize property 'imageView' because it is 'readwrite' but it will be synthesized 'readonly' via another property
解答:
错误原因是,imageView的名字起的和系统属性一样了,而这个属性是 readonly的
只要换个名字就行啦
问题:
在cell上加了一个button,背景色设为橘黄色,点击cell的颜色设为灰色,目前点击之后,button的背景色也会变成灰色,我想让它保持不变,如何设置?
解答:
// 设置背景色
typeButton.backgroundColor = [UIColor orangeColor]; // 替换为 // 设置一张带颜色的图片作为背景
[typeButton setBackgroundImage:[UIImage imageWithColor:[UIColor orangeColor]] forState:UIControlStateNormal];
其中 imageWithColor 是用少鸿提供的 category
问题:
如何设置UILabel的文本居中?
解答:
titleLabel.textAlignment = NSTextAlignmentCenter;
2015.6.14
问题:
我想让赛事详情页底部的tabbar消失,之前用的方法是:
SaiShiXinXiEventDetailVC *edVC = [[SaiShiXinXiEventDetailVC alloc] init];
edVC.hidesBottomBarWhenPushed = YES;
[self.navigationController pushViewController:edVC animated:YES];
但是没有生效;
考虑到EventList是storyboard实现的,于是又在storyboard中设置
但还是没有生效;
解答:
问题:
UITableViewCell的分割线左边有一块是空白的,如何改成从头开始的?
解答:
// viewDidLoad 中加上如下
- (void)viewDidLoad {
[super viewDidLoad]; if ([self.tableView respondsToSelector:@selector(setSeparatorInset:)]) {
[self.tableView setSeparatorInset:UIEdgeInsetsZero];
} if ([self.tableView respondsToSelector:@selector(setLayoutMargins:)]) {
[self.tableView setLayoutMargins:UIEdgeInsetsZero];
}
} // 修改willDisplayCell
- (void)tableView:(UITableView *)tableView willDisplayCell:(UITableViewCell *)cell forRowAtIndexPath:(NSIndexPath *)indexPath { if ([cell respondsToSelector:@selector(setSeparatorInset:)]) {
[cell setSeparatorInset:UIEdgeInsetsZero];
} if ([cell respondsToSelector:@selector(setLayoutMargins:)]) {
[cell setLayoutMargins:UIEdgeInsetsZero];
}
}
文档 by xuyang
1、赛事详情页
- M:nil
- V:
- 基类:SaiShiXinXiTableViewCell
- 信息基类:SaiShiXinXiEventInfomationBaseCell
- 头图:SaiShiXinXiEventInfomationImageCell
- 标题:SaiShiXinXiEventInfomationTitleCell
- 活动介绍:SaiShiXinXiEventIntructionTextCell
- 赛友头像:SaiShiXinXiPlayerHeadPhotoCell
- 评论列表:SaiShiXinXiCommentListCell
- 推荐:SaiShiXinXiRecommendDetailCell
- C:SaiShiXinXiEventDetailVC
2、城市选择页
- M:SaiShiXinXiCityModel
- V:nil
- C:SaiShiXinXiCityTableViewController
WYS APP的更多相关文章
- App开发:模拟服务器数据接口 - MockApi
为了方便app开发过程中,不受服务器接口的限制,便于客户端功能的快速测试,可以在客户端实现一个模拟服务器数据接口的MockApi模块.本篇文章就尝试为使用gradle的android项目设计实现Moc ...
- Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记
以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...
- Android请求网络共通类——Hi_博客 Android App 开发笔记
今天 ,来分享一下 ,一个博客App的开发过程,以前也没开发过这种类型App 的经验,求大神们轻点喷. 首先我们要创建一个Andriod 项目 因为要从网络请求数据所以我们先来一个请求网络的共通类. ...
- 【原创分享·支付宝支付】HBuilder打包APP调用支付宝客户端支付
前言 最近有点空余时间,所以,就研究了一下APP支付.前面很早就搞完APP的微信支付了,但是由于时间上和应用上的情况,支付宝一直没空去研究.然后等我空了的时候,发现支付宝居然升级了支付逻辑,虽然目前还 ...
- SQLSERVER走起 APP隆重推出
SQLSERVER走起 APP隆重推出 为方便大家查看本微信公众以前推送的文章,QQ群里面的某位SQLSERVER重度爱好者开发了<SQLSERVER走起>的APP 以供大家一起交流 网页 ...
- 从中间件的历史来看移动App开发的未来
在移动开发领域我们发现一个很奇怪的现象:普通菜鸟新手经过3个月的培训就可以拿到 8K 甚至上万的工作:在北京稍微有点工作经验的 iOS 开发,就要求 2 万一个月的工资.不知道大家是否想过:移动应用开 ...
- 搞个这样的APP要多久?
这是一个“如有雷同,纯属巧合”的故事,外加一些废话,大家请勿对号入座.开始了…… 我有些尴尬地拿着水杯,正对面坐着来访的王总,他是在别处打拼的人,这几年据说收获颇丰,见移动互联网如火如荼,自然也想着要 ...
- app开发外包注意事项,2017最新资讯
我们见过很多创业者,栽在这app外包上.很多创业者对于app外包这件事情不是特别重视,以为将事情交给app外包公司就完事了,实际上不是的.无论是从选择app外包公司还是签订合同.售后维护等各方面都有许 ...
- 【Win 10 应用开发】在App所在的进程中执行后台任务
在以往版本中,后台任务都是以独立的专用进程来运行,因此,定义后台任务代码的类型都要位于 Windows 运行时组件项目中. 不过,在14393中,SDK 作了相应的扩展,不仅支持以前的独立进程中运行后 ...
随机推荐
- laravel SQL语句
DB::table('表名')->get(); //查询表里的所有数据 DB::table('表名')->where()->find(需要查询的条数); 查询单或多条数据 ...
- sed 删除指定行
参考:http://blog.sina.com.cn/s/blog_4ba5b45e0102e7l2.html
- get 和 post 请求的区别(转)
转自 http://www.cnblogs.com/hyddd/archive/2009/03/31/1426026.html http://www.nowamagic.net/librarys/ve ...
- jvm 字节码查看
javap -c -v HelloWorldDemo.class >HelloWorld.txt
- Codeforces Round #402 (Div. 2) A
Description In Berland each high school student is characterized by academic performance — integer v ...
- 网络流--Dinic(自用,勿看)
注意:这是一篇个人学习笔记,如果有人因为某些原因点了进来并且要看一下,请一定谨慎地阅读,因为可能存在各种奇怪的错误,如果有人发现错误请指出谢谢! https://www.luogu.org/probl ...
- 使用express+mongoDB搭建多人博客 学习(2)路由与模板
修改index.js路由规则: var express = require('express'); var router = express.Router(); /* GET home page. * ...
- h5画圆
下面一段代码是,h5的画圆,半圆,四分之一圆等效果 <!DOCTYPE html> <html lang="en"> <head> <me ...
- 设置Eclipse可以Debug模式调试JDK源码,并显示局部变量的值
最近突然萌发了研究JDK源码的想法,所以就想到了在自己常用的Eclipse上可以调试JDK源码. 整个设置过程也很简单: 首先你要安装好JDK(我的JDK安装路径根目录是D:\Java\jdk-8u9 ...
- Java语言中自动生成随机数
参考原文:http://zhidao.baidu.com/link?url=nB3BT69wmUAiSPfKGgK5Q7HOFFP9AIE04AthreRd9yYcwKhUQsQRWlMdMhW1Qm ...