iOS - Frame 项目架构

前言

  • iOS 常见的几种架构:

    • 标签式 Tab Menu
    • 列表式 List Menu
    • 抽屉式 Drawer
    • 瀑布式 Waterfall
    • 跳板式 Springborad
    • 陈列馆式 Gallery
    • 旋转木马式 Carousel
    • 点聚式 Plus

1、标签式

  • 优点:
    • 1、清楚当前所在的入口位置
    • 2、轻松在各入口间频繁跳转且不会迷失方向
    • 3、直接展现最重要入口的内容信息

      Frame1

  • 缺点:
    • 功能入口过多时,该模式显得笨重不实用

      Frame2

2、列表式

  • 优点:
    • 1、层次展示清晰
    • 2、可展示内容较长的标题
    • 3、可展示标题的次级内容

      Frame5

  • 缺点:
    • 1、同级内容过多时,用户浏览容易产生疲劳
    • 2、排版灵活性不是很高
    • 3、只能通过排列顺序、颜色来区分各入口重要程度

      Frame6

3、抽屉式

  • 优点:
    • 1、兼容多种模式
    • 2、扩展性好

      Frame9

  • 缺点:
    • 1、隐藏框架中其他入口
    • 2、对入口交互的功能可见性(affordance)要求高

      Frame10

      Frame11

3.1 抽屉式架构简单实现

  • ViewController.m

        #import "ViewController.h"#import "QCMainViewController.h"#import "QCDrawerViewController.h"// 设定抽屉视图的宽度#define DRAWER_VC_WIDTH ((self.view.bounds.size.width * 3) / 4)@interface ViewController ()@property (nonatomic, strong) QCMainViewController *mainVC;@property (nonatomic, strong) UINavigationController *mainNVC;@property (nonatomic, strong) QCDrawerViewController *drawerVC;@end@implementation ViewController- (void)viewDidLoad {[super viewDidLoad];// 添加主视图self.mainVC = [[QCMainViewController alloc] init];self.mainNVC = [[UINavigationController alloc] initWithRootViewController:self.mainVC];[self addChildViewController:self.mainNVC];[self.view addSubview:self.mainNVC.view];// 添加抽屉视图self.drawerVC = [[QCDrawerViewController alloc] init];self.drawerVC.view.frame = CGRectMake(-DRAWER_VC_WIDTH, 0, DRAWER_VC_WIDTH, self.view.bounds.size.height);[self addChildViewController:self.drawerVC];[self.view addSubview:self.drawerVC.view];// 抽屉视图显示/隐藏回调__weak typeof(self) weakSelf = self;self.mainVC.myBlock = ^(BOOL isPush){CGRect mainNVCFrame = weakSelf.self.mainNVC.view.bounds;CGRect drawerVCFrame = weakSelf.self.drawerVC.view.bounds;mainNVCFrame.origin.x = isPush ? DRAWER_VC_WIDTH : 0;drawerVCFrame.origin.x = isPush ? 0 : -DRAWER_VC_WIDTH;[UIView animateWithDuration:0.5 animations:^{weakSelf.mainNVC.view.frame = mainNVCFrame;weakSelf.drawerVC.view.frame = drawerVCFrame;}];};}@end
  • QCMainViewController.h

        #import <UIKit/UIKit.h>@interface QCMainViewController : UIViewController@property (nonatomic, copy) void (^myBlock)(BOOL);@end
  • QCMainViewController.m

        #import "QCMainViewController.h"@interface QCMainViewController ()@property (nonatomic, assign, getter = isPush) BOOL push;@end@implementation QCMainViewController- (void)viewDidLoad {[super viewDidLoad];self.view.backgroundColor = [UIColor yellowColor];self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"抽屉" style:UIBarButtonItemStylePlain target:self action:@selector(pushDrawer)];// 功能测试for (NSUInteger i = 0; i < 5; i++) {UIButton *btn = [[UIButton alloc] init];[self.view addSubview:btn];btn.frame = CGRectMake(20, 200 + i * 60, 100, 50);btn.tag = i +1;[btn setTitle:[NSString stringWithFormat:@"按钮 %li", i + 1] forState:UIControlStateNormal];[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal];[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];}}// 功能测试- (void)btnClick:(UIButton *)btn {NSLog(@"按钮 %li", btn.tag);}// 抽屉视图显示/隐藏- (void)pushDrawer {self.push = !self.isPush;if (self.myBlock != nil) {self.myBlock(self.isPush);}}// 触摸手势抽屉视图显示/隐藏- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {if (self.isPush) {[self pushDrawer];}}@end
  • QCDrawerViewController.m

        #import "QCDrawerViewController.h"@interface QCDrawerViewController ()@end@implementation QCDrawerViewController- (void)viewDidLoad {[super viewDidLoad];self.view.backgroundColor = [UIColor blueColor];// 功能测试for (NSUInteger i = 0; i < 5; i++) {UIButton *btn = [[UIButton alloc] init];[self.view addSubview:btn];btn.frame = CGRectMake(20, 200 + i * 60, 100, 50);btn.tag = i +1;[btn setTitle:[NSString stringWithFormat:@"功能 %li", i + 1] forState:UIControlStateNormal];[btn addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];}}// 功能测试- (void)btnClick:(UIButton *)btn {NSLog(@"功能 %li", btn.tag);}@end
  • 效果

    drawer1drawer2

3.2 抽屉式架构第三方框架实现

  • 第三方框架 GitHub 地址

  • 效果

    drawer6drawer7

4、瀑布式

  • 优点:
    • 1、浏览时产生流畅体验

      Frame17

  • 缺点:
    • 1、缺乏对整体内容的体积感,容易发生空间位置迷失
    • 2、浏览一段时间后,容易产生疲劳感

      Frame18

5、跳板式

  • 优点:
    • 1、清晰展现各入口
    • 2、容易记住各入口位置,方便快速找到

      Frame3

  • 缺点:
    • 1、无法在多入口间灵活跳转,不适合多任务操作
    • 2、容易形成更深的路径
    • 3、不能直接展现入口内容
    • 4、不能显示太多入口次级内容

      Frame4

6、陈列馆式

  • 优点:
    • 1、直观展现各项内容
    • 2、方便浏览经常更新的内容

      Frame15

  • 缺点:
    • 1、不适合展现顶层入口框架
    • 2、容易形成界面内容过多,显得杂乱
    • 3、设计效果容易呆板

      Frame16

7、旋转木马式

  • 优点:
    • 1、单页面内容整体性强
    • 2、线性的浏览方式有顺畅感、方向感

      Frame7

  • 缺点:
    • 1、不适合展示过多页面
    • 2、不能跳跃性地查看间隔的页面,只能按顺序查看相邻的页面
    • 3、由于各页面内容结构相似,容易忽略后面的内容

      Frame8

8、点聚式

  • 优点:
    • 1、灵活
    • 2、展示方式有趣
    • 3、使界面更开阔

      Frame12

  • 缺点:
    • 1、隐藏框架中其他入口
    • 2、对入口交互的功能可见性(affordance)要求高

      Frame13

      Frame14

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/260663.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows 10下,anaconda (conda) 虚拟环境的创建,jupyter notebook如何使用虚拟环境

手把手教您创建conda 虚拟环境 1 安装好anaconda后&#xff0c;会出现如下所示&#xff0c;这些都是anaconda集成啦&#xff0c;不需要再安装了。我们在如下所指的anaconda Prompt右键&#xff0c;以管理员运行 2 打开后&#xff0c;这就是prompt&#xff0c;我们输入pyth…

python下载文件传到服务器_python实现FTP文件传输的方法(服务器端和客户端)

用python实现FTP文件传输&#xff0c;包括服务器端和客户端&#xff0c;要求 &#xff08;1&#xff09;客户端访问服务器端要有一个验证功能 &#xff08;2&#xff09;可以有多个客户端访问服务器端 &#xff08;3&#xff09;可以对重名文件重新上传或下载 FTP&#xff08;F…

oracle数据库主键自增序列_Oracle数据库序列详解

前言&#xff1a;做过web开发的人员基本上都知道&#xff0c;数据库表中的主键值有的时候我们会用数字类型的并且自增。这样mysql、sql server中的都可以使用工具创建表的时候很容易实现。但是oracle中没有设置自增的方法&#xff0c;一般情况我们会使用序列和触发器来实现主键…

一步步学习微软InfoPath2010和SP2010--第十三章节--SharePoint视图和仪表板(9)--基于表单库的仪表板...

现在你已经知道了如何将服务台网站和表单与自定义视图放在一起&#xff0c;最后一步是使用SharePoint创建仪表板&#xff0c;以呈现表单中的信息的基本报表。表单设计者经常致力于表单以至于他们忘记了SharePoint的力量来聚合表单的属性&#xff0c;并建立KIPs和其他类型的报表…

SQL常用语句积累

SQL 常用语句积累&#xff1a;一、 SQL 基本语句SQL 分类&#xff1a;DDL —数据定义语言 (Create &#xff0c; Alter &#xff0c; Drop &#xff0c; DECLARE)DML —数据操纵语言 (Select &#xff0c; Delete &#xff0c; Update &#xff0c; Insert)DCL —数据控制语言 …

vscode 里 Import “numpy“ count not be resolved

问题如下&#xff1a; 我们分析一下这个问题&#xff0c;这里的问题。问题的翻译是&#xff1a;导入"numpy"不能被解决。 这可能有几个问题&#xff0c;1&#xff1a;vscode的python插件没有安装&#xff0c;2: vscode的python的解析器没有设置好。 按照这个思路&…

xdocument查找节点值_二叉查找树(java)

一棵二叉查找树(BST)是一颗二叉树&#xff0c;其中每个节点都含有一个Comparable的键且每个节点的键(以及相关的值)都大于其左子树中的任意节点的键而小于右子树的任意结点的键。数据表示和链表一样&#xff0c;我们嵌套定义了一个私有类来表示二叉查找树上的一个节点。每个节点…

三角形 画_CAD入门基础第3节:直角三角形的圆及如何修剪

这个软件&#xff0c;仔细想想&#xff0c;无非就两个命令&#xff0c;一是直线命令&#xff0c;二&#xff0c;就是圆。直线&#xff0c;无非也就是两种&#xff0c;一&#xff0c;是水平直线和垂直于水平直线的竖线&#xff0c;二&#xff0c;就是各种斜线。第一种直线&#…

【转】系统缓存全解析二:动态缓存(4)-第三方分布式缓存解决方案 Memcache(2)...

缓存系统MemCached的Java客户端优化历程&#xff08;转载自http://code.google.com/p/memcache-client-forjava/。&#xff09;Memcached是一种集中式Cache&#xff0c;支持分布式横向扩展。这里需要解释说明一下&#xff0c;很多开发者觉得Memcached是一种分布式缓存系统&…

windows 10下搭建pyspark与遇到的一些问题的解决方法

目录windows 10 下 搭建 pyspark所需要的工具过程与步骤windows 10 下 搭建 pyspark 所需要的工具 Java JDK 1.8.0 spark-2.2.0-bin-hadoop2.7 hadoop-2.7.3 winutils.exe 还需要有python环境&#xff0c;我用的是Anaconda 3&#xff08;默认你已经装好此环境&#xff09;。…

Linux VNC server 安装配置

1.安装vnc server[rootpxe ~]# yum install tigervnc-server -y2.设置 vnc server 开机启动[rootpxe ~]# chkconfig vncserver on3.修改vncserver 配置文件[rootpxe ~]# vi /etc/sysconfig/vncservers在配置文件后添加以下内容VNCSERVERS"2:root"VNCSERVERARGS[2]&qu…

为什么用python写爬虫_python-做爬虫,如何避免牢狱之灾

随着数据资源的爆炸式增长&#xff0c;网络爬虫的应用场景和商业模式变得更加广泛和多样&#xff0c;网络爬虫技术为数据收集者提供了极大的便利&#xff0c;也给专业网络爬虫公司带来巨大的收益。但是与之相伴的是许多人好奇的一件事——爬虫是否违法&#xff1f; 关于这个问题…

vue跳转页面增加等待_vue跳转页面方法

1. router-link1. 不带参数 //name,path都行, 建议用name // 注意&#xff1a;router-link中链接如果是/开始就是从根路由开始&#xff0c;如果开始不带/&#xff0c;则从当前路由开始。 2.带参数 // params传参数 (类似post)// 路由配置 path: "/home/:id"…

开发HTML5手机游戏的5个注意要点--手机开发前景-- 转

过去2年&#xff0c;我们都见证手机和社交游戏的兴起&#xff1a;两大游戏类型既各自发展&#xff0c;同时也开始互相渗透&#xff0c;融入HTML5技术。 手机社交游戏有自己的用户基础&#xff0c;日益蓬勃发展。 这个新兴游戏类型兼容网页社交游戏和本土应用的优点&#xff0c;…

栈(顺序存储)C++模板实现

#include <iostream> using namespace std;template <typename T> class stack{private:int top; //栈顶指针int maxLen; //栈最大长度T *data; //用数组来创建栈public:stack(int top_ -1 , int maxLen_ 10):top(top_),maxLen(maxLen_){data new T[maxLen]; …

java线程池参数含义

转载自 http://blog.csdn.net/zhouhl_cn/article/details/7392607 感谢分享 项目中开发通常不会直接使用ThreadPoolExecutor&#xff0c;而是通过Executors.newFixedThreadPool()这种简易写法&#xff0c;创建适合自己项目的线程池。但是了解最基本的线程池ThreadPoolExecutor是…

第5章 Python 数字图像处理(DIP) - 图像复原与重建1 - 高斯噪声

本章主要讲图像复原与重建&#xff0c;首先是了解一下各种噪声的特点与模型&#xff0c;还有形成的方法。一些重点的噪声&#xff0c;如高斯噪声&#xff0c;均匀噪声&#xff0c;伽马噪声&#xff0c;指数噪声&#xff0c;还有椒盐噪声等。 本章主要的噪声研究方法主要是加性噪…

十进制 转换 2-10 进制,int的扩展方法

public static int ConvertToBase(this int i, int baseToConvertTo){if (baseToConvertTo < 2 || baseToConvertTo > 10){throw new ArgumentException("无法完成转换" baseToConvertTo.ToString());}int resault 0; //存放结果int iterations 0; //十进…

c语言将一个已知头结点的单链表逆序_C语言实现单链表逆序与逆序输出实例

单链表的逆序输出分为两种情况&#xff0c;一种是只逆序输出&#xff0c;实际上不逆序&#xff1b;另一种是把链表逆序。本文就分别实例讲述一下两种方法。具体如下&#xff1a;1.逆序输出实例代码如下&#xff1a;#include#include#includeusing namespace std;typedef struct…

JavaScript之apply()和call()的区别

我 在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示 例,总算是看的有点眉目了,在这里我做如下笔记,希望和大家分享.. 如有什么不对的或者说法不明确的地方希望读者多多提一些意见,以便共同提高.. 主要我是…