iOS - Frame 项目架构

前言

  • iOS 常见的几种架构:

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

1、标签式

  • 优点:

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

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

2、列表式

  • 优点:

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

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

3、抽屉式

  • 优点:

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

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

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
  • 效果

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

4、瀑布式

  • 优点:

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

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

5、跳板式

  • 优点:

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

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

6、陈列馆式

  • 优点:

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

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

7、旋转木马式

  • 优点:

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

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

8、点聚式

  • 优点:

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

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

时间: 2024-07-31 22:48:40

iOS - Frame 项目架构的相关文章

iOS大型项目解耦方案有难度?BeeHive设计优化来帮助

在2017年在线技术峰会--阿里开源项目最佳实践上,来自天猫的戴鹏带来了BeeHive关于iOS大型项目解耦方案的分享.他从多人开发的问题介绍了业界的三种模块方案,将传统Init与BeeHive Module进行了比较,对BeeHive的架构进行了分析,并对Module Manager和Module的实现进行了详细介绍.   以下内容根据直播视频整理而成.   视频回顾:点击进入 Pdf下载:点击进入   在iOS大型项目中如何抽丝剥茧把对应的需要优化的地方进行优化.多人协作开发中如何避免冲突?

C语言项目开发-项目架构和编程命名规范

一个项目的流程: 1.公司市场人员与客户交流,了解客户.引导客户使用公司最优资源并产出一份市场需求文档 2.公司需求人员(BA)与客户交流,了解客户需求并产出一个软件需求文档 3.项目经理.开发小组成员.需求人员(BA)一起开一个需求评审会议,对不合理的地方,    打回给BA,再由BA与客户沟通 4.程序员接到和充分了解软件需求文档后产生软件设计文档(包括概要设计文档和详细设计文档,    涉及到数据库的还需要进行数据库的设计) 5.程序员根据设计文档进行编码.调试.打包发布.如果编写的函数库

iOS开发:GitHub上的40个iOS开源项目

 开发:GitHub上的40个iOS开源项目-"> 1. AFNetworking 在众多iOS开源项目中,AFNetworking可以称得上是最受开发者欢迎的库项目.AFNetworking是一个轻量级的iOS.Mac OS X网络通信类库,现在是GitHub上第三大Objective-C库.它建立在NSURLConnection.NSOperation等类库的基础上,让很多网络通信功能的实现变得十分简单,因此,许多iOS应用开发都会使用到它. 支持HTTP请求和基于REST的网络服务(

Github上600多个iOS开源项目分类及介绍

iOS 开源项目 . 开源框架.开源模块列举 http://github.ibireme.com/github/list/ios/

大数据日志分析项目架构

老是弹出由于您编辑时间过长,页面和服务器之间的连接已断开,请先将文章内容另外保存,再刷新本页面继续编辑让我保存页面我也是醉了,图片多没法一次上传,上传图片还一直失败,我只好都放在一个附件里面了.阿里能花点心思把网址做好一点么 共两个开发项目,git地址:https://github.com/dengziming/hongya-report.git,https://github.com/dengziming/hongya-taobaopayment.git 项目简介:大数据涉及到的业务很多很复杂,

如何用angular+bower+grunt+nodejs搭建项目架构

前端这两年技术飞速发展,各种优秀框架层出不穷.本文不是讨论各框架的比较,也不讨论为什么要用angular,而不用backbone:不讨论为什么用requirejs,而不用browserify,seajs等. 一个成熟项目架构中应该具有哪些功能 快速的项目生成器--快速生成项目主体架构,单步实现controller,单步实现view,实现根据router自动生成view,controller 静态资源的管理--基于bower css动态编译--基于sass,compass实现css嵌套写法,跨浏览

大型项目架构搭建_高内聚、低耦合(1)

软件开发中的项目的架构的终极目标就六个字: 高内聚.低耦合: 架构搭建好了,后期可维护性才能提高,在这基础上,如果还想提高项目的高效性,就只能从算法着手 如果项目中算法都已经做到极致了,还想提高项目的高效性,怎么办?(算法并不一定能处理高并发的问题) 就要用到中间件的技术了 下面我就从这三方面来搭建一个项目 假设我们有个这么需求 我公式和YC公式合作,开发一个项目,这个项目功能是用来测量东西的一个项目,我们公式在存储数据方面做得好,YC公司所以要和我们合作,要我们做一个对数据进行保存的容器,他们

使用PhoneGap命令行工具创建IOS PhoneGap项目及无证书真机调试

       在使用PhoneGap2.0及以上版本的时候,发现无法像低版本那样直接使用xcode来创建一个新的项目,只能通过PhoneGap的命令行工具来进行创建.        准备工作:        首先,准备好mac的环境和xcode的安装,地球人都知道.        然后得确定你的xcode已安装了Command Line Tools,如果不会安装的可以直接百度,上面有很多教程,这里就不多说了.        接着,下载好最新版本(我使用的是phonegap-2.4.0,此教程用于

ios开发-iOS跑项目时出错,哪位大神帮忙解答

问题描述 iOS跑项目时出错,哪位大神帮忙解答 could not cast value of type 'UIViewController' to 'todolist.ViewController'