前言

在网上看了别人做的模仿网易彩票的项目, 于是也跟着用自己的想法做了一篇。
写这篇博客的目的, 在于UI综合的一次小练习, 同时总结和串联其各个控件之间的应用、封装思想等。考虑到有人上不了github, 代码会在最后一次性发到百度云盘, 敬请关注

工欲善其事, 必先利其器

一、画其形:

在做该项目前, 我们先把项目的大体框架搭好。再依次迭代开发, 逐渐完善所有的功能.
首先: 观察网易彩票项目的app, 先在手机上把整个app的功能都浏览一篇。可以大体上分析出框架的结构。
分析: 很明显在一进入的界面最下面是一个UITabBar, 而上面是UINavigationBar。并且当我们点击每个UITabBarButton的时候, 会切换到不同的UINavigation, 所以该app的构架是基于UITabBarController的多个UINavigation的切换。于是我们可以通过storyBoard快速搭建出下面的界面。

至于搭建的过程, 是十分基本的技能, 不在详细说明,需要注意的是记得在SB中指定初始化的控制器
以下是在模拟器中运行的效果图

二、画其神

我们把大体的软件轮廓给勾勒了出来, 接着我们应该思考应该从哪个方面入手继续迭代这个软件, 将其内容补充完整。也就是说我们有两种选择方法,
其一、我们可以选择从最有挑战难度的方面入手, 逐步完善。其二,我们可以选择从比较简单的方面切开个口子, 逐步完善。我还是比较推崇第二种
方法, 在我看来, 人们总是偏向于构建简单的事物, 而不是复杂的事物。简单的东西不容易出错,而复杂的东西具有太多需要考虑的方面,会因此有很
大的不稳定性。所以我选择从UITabBar入手, 由于该软件中, 我们只需要图片,而不需要底部的文字信息,所以我们自定义SWPTabBar,但我们不选择继承
自UITabBar, 因为其有些特性是我们不想要的, 继承自UIView。既然自定义了SWPTabBar那么这个控件必须也要具备一些UITabBar一样的控件。在这里一个SWPTabBar
必须有对应的数量的按钮(UITabBarController的子控制器个数)。而我们正是为了自己来确定这个按钮才自定义,所以还需要在自定义SWPButton,继承自
UIButton。在创建出三个对应的类之后, 必须记得到SB中更改各个控件关联的类。这里只需要更改, UITabBarController=====>SWPTabBarController。
想想为什么?

分析: 那么接下来我们如何应用自己定义的SWPTabBar, 和SWPButton呢? 首先我们要明确一点,SWPTabBar这个控件由SWPButton这个控件构成。所以我们思考的重点是
如何封装这个控件, 方便后续程序的扩展, 比如,某天,项目需求一改,项目经理规定把SWPTabBar的栏目切换为6个,或者删掉几个,换成三个。我们要做到的效果就是,当遇到
这种需求,只需要改几行的代码,插入几行新的代码,而不用去更改项目的整个构架就可以适应这种需求。当然这只是一个主要的标准。在达到这个标准之后,我们还需要注意
一点就是尽可能的规范代码,优化代码。

切开口子,跟我慢慢来:
1. 接着我们编写SWPTabBarController给其加入自定义的SWPTabBar。这样就能显示出自定义的TabBar了。想来看看这个纯洁的控件,还没添加按钮的时候。能不能
正常的显示到SWPTabBarController的View上。代码和实现效果如下, 比较简单其自己阅读代码

@implementation SWPTabBarControllerViewController
- (void)viewDidLoad {
[super viewDidLoad]; // 添加自定义tabBar先测试下
SWPTabBar * tabBar = [[SWPTabBar alloc] init]; tabBar.frame = self.tabBar.frame; tabBar.backgroundColor = [UIColor greenColor]; [self.view addSubview: tabBar];
}
@end

再造轮子之网易彩票-第一季(IOS 篇 by sixleaves)的更多相关文章

  1. 再造轮子之网易彩票-第二季(IOS 篇 by sixleaves)

    02-彩票项目第二季 2.封装SWPTabBar方式一 接着我们思考如何进行封装.前面已经将过了为什么要封装, 和封装达到的效果.这里我们主要有两种封装方式,分别是站在不同的角度上看待问题.虽然角度不 ...

  2. 事件处理原理(IOS篇) by sixleaves

    前言 了解IOS事件处理的本质关键要先掌握几个概念.首先是事件的派发(Event Delivery)的过程, 一个是响应者链条如何构成. 事件的派发: Q1: 你有没有想过,如果你一个屏幕中有多个的V ...

  3. iOS菜鸟成长笔记(2)——网易彩票练习

    距离上一篇<第一个iOS应用>已经有一个多月了,今天来和大家一起学习和分享一下一个小练习<网易彩票> 首先我们向storyboard中拖入一个TabBarController和 ...

  4. iOS开发——实战总结OC篇&网易彩票开发知识点总结

    网易彩票开发知识点总结 关于网易彩票开发中遇到了不少的坑,弄了好久才弄懂,或者有些犹豫很久没用就不记得了,所以这里就总结了一下,希望以后不会忘记,就算忘记也能快速查看! /************** ...

  5. iOS 网易彩票-6设置模块三(常用小功能)

    该篇文章中,用到很多iOS开发过程中常用的小功能,当前只是将这些功能集成到网易彩票的设置中.iOS-常用小功能介绍,请参考我的另一篇文章: iOS 常用小功能 总结:http://www.cnblog ...

  6. QQ聊天界面的布局和设计(IOS篇)-第一季

    我写的源文件整个工程会再第二季中发上来~,存在百度网盘, 感兴趣的童鞋, 可以关注我的博客更新,到时自己去下载~.喵~~~ QQChat Layout - 第一季 一.准备工作 1.将假数据messa ...

  7. iOS 网易彩票-4设置模块一

    概述 基本上,每一款APP都有相应的设置模块.怎么设置才能更灵活和通用呢,这也是大家一直思考的.下面说说在网易彩票中,设置模块的设置思想. 基本上有三种方案: static cell(呆板,完全没有动 ...

  8. iOS 网易彩票-1框架搭建

    仿网易彩票,最终要做成的效果如下: 一.分层搭建 1.新建一个项目,Lottery.只支持7.1以上坚屏. 2.将素材全部图片全部拉到相应的文件夹里. 3.选中Lottery--右键Show in F ...

  9. 今年第一季全球PC出貨量同比下降5.2%

    市場調研公司Gartner上周發佈報告稱,隨著企業支出的下滑,今年第一季全球PC出貨量同比下降5.2%迪士尼美語評價.英特爾稱,第一季筆記本晶片出貨量同比增長3%,但是筆記本晶片的平均銷售價格下降了3 ...

随机推荐

  1. ibatis学习之道:ibatis的<[CDATA]>dynamic属性跟#$的应用

    ibatis的<![CDATA]>,dynamic属性和#,$的应用 <![CDATA[   ]]>的正确使用 ibatis作为一种半自动化的OR Mapping工具,其灵活性 ...

  2. 设计模式--观察者(Observer)

    GOF给出的定义: Define a one-to-many dependency between objects so that when one object changes state, all ...

  3. eclipse 添加resources 目录

    java项目需要一些配置,配置放置目录如:/src/main/resources; 如果没有这个文件夹,需要右键项目>new>source folder > Folder name ...

  4. 对easyui datagrid进行扩展,当滚动条拉直最下面就异步加载数据。

    以下方法是通用的,只要把datagrid定义为全局的即可,其他部分的代码不用进行修改! 可以把以下代码放入到一个单独的js文件,然后再需要的页面引入即可! $(function(){ try{ $(& ...

  5. linux下使用mutt发送带附件的邮件

    echo "hello"|mutt -s "world" -a hack.jpg -- name@address.com

  6. [RxJS] Basic DOM Rendering with Subscribe

    While frameworks like Angular 2 and CycleJS provides great ways to update the DOM and handle subscri ...

  7. storm启动流程

    email:chenguibin2004@126.com storm: 是一个分布式的实时流式计算框架,具有低延迟.高可用.分布式.可扩展.数据不丢失的特点, storm包含四个核心组件: Nimbu ...

  8. VS2015 添加DNX SDK

    第一次运行VS2015,添加第一个ASP.NET 5程序时会报一个错误“DNX SDK版本 “dnx-clr-win-x86.1.0.0-beta5”无法安装. 解决办法: 打开CMD :输入 @po ...

  9. js数组 函数

    js数组 filter(),map(),some(),every(),forEach(),lastIndexOf(),indexOf() 文章1:http://www.jb51.net/article ...

  10. Java------------运算符优先级速记口诀

    单目乘加位关系,逻辑三目后赋值. 单目:单目运算符+ –(负数) ++ -- 等 乘加(乘除加减):算数单目运算符* / % + - 位:位移单目运算符<< >> 关系:关系单 ...