11----MMDrawerConcroller的简单使用

本文介绍了如何使用MMDrawerController框架来实现iOS应用中的侧滑菜单功能。通过从故事板加载不同控制器并配置框架参数,可以轻松实现具有自定义动画效果的侧滑菜单。


    学习的时间总是过得很快,虽然每一天的起床都很煎熬,但到教室后一天很快就过去了。时间越来越少,会的东西也越来越多,进入项目二的学习后,接触的第三方框架也越来越多,比如像项目二的大框架就是一个MMDrawerController,创建代码如下

- (void)viewDidLoad {

    [super viewDidLoad];

    // Do any additional setup after loading the view.

    

    self.view.backgroundColor = [UIColor clearColor];

    

    //从故事板(storybord)中获取控制器对象

    UIStoryboard *storybord = [UIStoryboard storyboardWithName:@"Main" bundle:nil];

    

    [[NSNotificationCenter defaultCenter]addObserver:selfselector:@selector(_setAnimation) name:kStyleNotification object:nil];

    

    //设置左边的控制器

    self.leftDrawerViewController = [storybord instantiateViewControllerWithIdentifier:@"LeftVC"];

    

    //设置中间的控制器

    self.centerViewController = [storybord instantiateViewControllerWithIdentifier:@"CenterVC"];

    

    //设置右边的控制器

    self.rightDrawerViewController = [storybord instantiateViewControllerWithIdentifier:@"RightVC"];

    

    //设置阴影

    [self setShowsShadow:YES];

    

    //设置两边的宽度

    [self setMaximumLeftDrawerWidth:160.0];

    [self setMaximumRightDrawerWidth:60.0];

    

    //设置手势的作用区域

    [self setOpenDrawerGestureModeMask:MMOpenDrawerGestureModeAll];

    [self setCloseDrawerGestureModeMask:MMCloseDrawerGestureModeAll];

    

    //配置动画的回调函数

    [self setDrawerVisualStateBlock:^(MMDrawerController *drawerController, MMDrawerSide drawerSide, CGFloat percentVisible) {

        MMDrawerControllerDrawerVisualStateBlock block;

        block = [[MMExampleDrawerVisualStateManagersharedManager]drawerVisualStateBlockForDrawerSide:drawerSide];

        if (block) {

            block(drawerController,drawerSide,percentVisible);

        }

        

    }];

 

    //设置动画

    

    [self _setAnimation];

    

    

}

//设置动画

- (void)_setAnimation

{

    //从数据中拿到选中的样式

    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];

    NSInteger style = [[defaults objectForKey:kAnimationStyle]integerValue];

    //根据样式的枚举值设置动画

    [[MMExampleDrawerVisualStateManager sharedManager] setLeftDrawerAnimationType:style];

    [[MMExampleDrawerVisualStateManager sharedManager] setRightDrawerAnimationType:style];

}


    学习的时间总是过得很快,虽然每一天的起床都很煎熬,但到教室后一天很快就过去了。时间越来越少,会的东西也越来越多,进入项目二的学习后,接触的第三方框架也越来越多,比如像项目二的大框架就是一个MMDrawerController,创建代码如下

- (void)viewDidLoad {

    [super viewDidLoad];

    // Do any additional setup after loading the view.

    

    self.view.backgroundColor = [UIColor clearColor];

    

    //从故事板(storybord)中获取控制器对象

    UIStoryboard *storybord = [UIStoryboard storyboardWithName:@"Main" bundle:nil];

    

    [[NSNotificationCenter defaultCenter]addObserver:selfselector:@selector(_setAnimation) name:kStyleNotification object:nil];

    

    //设置左边的控制器

    self.leftDrawerViewController = [storybord instantiateViewControllerWithIdentifier:@"LeftVC"];

    

    //设置中间的控制器

    self.centerViewController = [storybord instantiateViewControllerWithIdentifier:@"CenterVC"];

    

    //设置右边的控制器

    self.rightDrawerViewController = [storybord instantiateViewControllerWithIdentifier:@"RightVC"];

    

    //设置阴影

    [self setShowsShadow:YES];

    

    //设置两边的宽度

    [self setMaximumLeftDrawerWidth:160.0];

    [self setMaximumRightDrawerWidth:60.0];

    

    //设置手势的作用区域

    [self setOpenDrawerGestureModeMask:MMOpenDrawerGestureModeAll];

    [self setCloseDrawerGestureModeMask:MMCloseDrawerGestureModeAll];

    

    //配置动画的回调函数

    [self setDrawerVisualStateBlock:^(MMDrawerController *drawerController, MMDrawerSide drawerSide, CGFloat percentVisible) {

        MMDrawerControllerDrawerVisualStateBlock block;

        block = [[MMExampleDrawerVisualStateManagersharedManager]drawerVisualStateBlockForDrawerSide:drawerSide];

        if (block) {

            block(drawerController,drawerSide,percentVisible);

        }

        

    }];

 

    //设置动画

    

    [self _setAnimation];

    

    

}

//设置动画

- (void)_setAnimation

{

    //从数据中拿到选中的样式

    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults];

    NSInteger style = [[defaults objectForKey:kAnimationStyle]integerValue];

    //根据样式的枚举值设置动画

    [[MMExampleDrawerVisualStateManager sharedManager] setLeftDrawerAnimationType:style];

    [[MMExampleDrawerVisualStateManager sharedManager] setRightDrawerAnimationType:style];

}


带开环升压转换器和逆变器的太阳能光伏系统 太阳能光伏系统驱动开环升压转换器和SPWM逆变器提供波形稳定、设计简单的交流电的模型 Simulink模型展示了一个完整的基于太阳能光伏的直流到交流电力转换系统,该系统由简单、透明、易于理解的模块构建而成。该系统从配置为提供真实直流输出电压的光伏阵列开始,然后由开环DC-DC升压转换器进行处理。升压转换器将光伏电压提高到适合为单相全桥逆变器供电的稳定直流链路电平。 逆变器使用正弦PWM(SPWM)开关来产生干净的交流输出波形,使该模型成为研究直流-交流转换基本操作的理想选择。该设计避免了闭环和MPPT的复杂性,使用户能够专注于光伏接口、升压转换和逆变器开关的核心概念。 此模型包含的主要功能: •太阳能光伏阵列在标准条件下产生~200V电压 •具有固定占空比操作的开环升压转换器 •直流链路电容器,用于平滑和稳定转换器输出 •单相全桥SPWM逆变器 •交流负载,用于观察实际输出行为 •显示光伏电压、升压输出、直流链路电压、逆变器交流波形和负载电流的组织良好的范围 •完全可编辑的结构,适合分析、实验和扩展 该模型旨在为太阳能直流-交流转换提供一个干净高效的仿真框架。布局简单明了,允许用户快速了解信号流,检查各个阶段,并根据需要修改参数。 系统架构有意保持模块化,因此可以轻松扩展,例如通过添加MPPT、动态负载行为、闭环升压控制或并网逆变器概念。该模型为进一步开发或整合到更大的可再生能源模拟中奠定了坚实的基础。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值