iOS - Frame 项目架构

简介: 前言iOS 常见的几种架构:标签式 Tab Menu列表式 List Menu抽屉式 Drawer瀑布式 Waterfall跳板式 Springborad陈列馆式 Gallery旋转木马式 Carousel点聚式 Plus1、标签式优点:1、清楚当前所在的入口...

前言

  • 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 抽屉式架构第三方框架实现

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

目录
相关文章
|
1天前
|
缓存 Java 测试技术
【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
14 3
【01】噩梦终结flutter配安卓android鸿蒙harmonyOS 以及next调试环境配鸿蒙和ios真机调试环境-flutter项目安卓环境配置-gradle-agp-ndkVersion模拟器运行真机测试环境-本地环境搭建-如何快速搭建android本地运行环境-优雅草卓伊凡-很多人在这步就被难倒了
|
13天前
|
人工智能 JavaScript 安全
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
57 13
【01】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-需求改为思维导图-设计数据库-确定基础架构和设计-优雅草卓伊凡商业项目实战
|
1月前
|
开发框架 前端开发 .NET
一个适用于 .NET 的开源整洁架构项目模板
一个适用于 .NET 的开源整洁架构项目模板
57 26
|
2月前
|
开发工具 Android开发 iOS开发
Android与iOS生态差异深度剖析:技术架构、开发体验与市场影响####
本文旨在深入探讨Android与iOS两大移动操作系统在技术架构、开发环境及市场表现上的核心差异,为开发者和技术爱好者提供全面的视角。通过对比分析,揭示两者如何塑造了当今多样化的移动应用生态,并对未来发展趋势进行了展望。 ####
|
2月前
|
安全 Android开发 iOS开发
深入探索iOS与Android系统架构差异及其对开发者的影响
本文旨在通过对比分析iOS和Android两大移动操作系统的系统架构,探讨它们在设计理念、技术实现及开发者生态方面的差异。不同于常规摘要仅概述内容要点,本摘要将简要触及核心议题,为读者提供对两大平台架构特点的宏观理解,铺垫
|
3月前
|
安全 Linux Android开发
深入探索Android与iOS的系统架构:一场技术较量
在当今数字化时代,智能手机操作系统的选择成为了用户和开发者关注的焦点。本文将深入探讨Android与iOS两大主流操作系统的系统架构,分析它们各自的优势与局限性,并对比两者在用户体验、开发生态和安全性方面的差异。通过本文的技术剖析,读者将对这两个平台的核心技术有更深入的理解。
|
3月前
|
IDE 安全 Android开发
深入探索Android与iOS操作系统的架构差异
本文旨在对比分析Android和iOS两大主流移动操作系统在架构设计上的根本差异。通过详细解读两者的系统架构、开发环境、以及安全性等方面,揭示它们各自的特点及优势,为开发者选择合适的平台提供参考。
|
3月前
|
监控 前端开发 数据可视化
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
@icraft/player-react 是 iCraft Editor 推出的 React 组件库,旨在简化3D数字孪生场景的前端集成。它支持零配置快速接入、自定义插件、丰富的事件和方法、动画控制及实时数据接入,帮助开发者轻松实现3D场景与React项目的无缝融合。
280 8
3D架构图软件 iCraft Editor 正式发布 @icraft/player-react 前端组件, 轻松嵌入3D架构图到您的项目,实现数字孪生
|
3月前
|
安全 Android开发 iOS开发
深入探索Android与iOS的差异:从系统架构到用户体验
在当今的智能手机市场中,Android和iOS无疑是最受欢迎的两大操作系统。本文旨在探讨这两个平台之间的主要差异,包括它们的系统架构、开发环境、安全性、以及用户体验等方面。通过对比分析,我们可以更好地理解为何不同的用户群体可能会偏好其中一个平台,以及这些偏好背后的技术原因。
|
3月前
|
前端开发 JavaScript 测试技术
Kotlin教程笔记 - 适合构建中大型项目的架构模式全面对比
Kotlin教程笔记 - 适合构建中大型项目的架构模式全面对比
55 3

热门文章

最新文章

  • 1
    【03】仿站技术之python技术,看完学会再也不用去购买收费工具了-修改整体页面做好安卓下载发给客户-并且开始提交网站公安备案-作为APP下载落地页文娱产品一定要备案-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
  • 2
    【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
  • 3
    Cellebrite UFED 4PC 7.71 (Windows) - Android 和 iOS 移动设备取证软件
  • 4
    【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
  • 5
    Flink+Paimon+Hologres,面向未来的一体化实时湖仓平台架构设计
  • 6
    DeepSeek背后的技术基石:DeepSeekMoE基于专家混合系统的大规模语言模型架构
  • 7
    十大主流联邦学习框架:技术特性、架构分析与对比研究
  • 8
    分布式系统架构8:分布式缓存
  • 9
    【上云基础系列 02-01】通过SLB+1台ECS+ESS弹性伸缩,搭建一个精简版的上云标准弹性架构(含方案及教程)
  • 10
    一文彻底讲透GPT架构及推理原理