iOS实现可拖动的浮动菜单

 更新时间:2022年08月08日 08:38:32   作者:shenyi0106  
这篇文章主要为大家详细介绍了iOS实现可拖动的浮动菜单,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了iOS实现可拖动的浮动菜单的具体代码,供大家参考,具体内容如下

实现一个可拖动的浮动菜单,效果如下:

这个设置图标是可以全屏拖动的,点击一下,可以出现一排设置按钮,可以用来进行功能的开关切换。

废话不多说了,上代码:

//
//  DragMenuView.h
//
//  Created by Scott on 15-7-27.
//  Copyright (c) 2015年 yshen. All rights reserved.
//
 
#import <UIKit/UIKit.h>
 
@interface DragMenuView : UIView
{
    UIButton    *m_selectBtn;
    UIView      *m_contentView;
}
 
-(id)initDragMenuView;
@end

很简单的头文件,就两个变量,一个初始化函数。

m_selectBtn是一个按钮控件,这个控件用来显示上图中那个螺丝刀和扳手的图片,它可以被任意拖动,只要点击它,就可以打开其他设置按钮。

m_contentView

initDragMenuView这个函数是这个类唯一的一个自有函数,它用来创建这个浮动菜单,并初始化浮动菜单。

下面是实现文件:

//
//  DragMenuView.m
//  
//
//  Created by Scott on 15-7-27.
//  Copyright (c) 2015年 yshen. All rights reserved.
//
 
#import <QuartzCore/QuartzCore.h>
#import "DragMenuView.h"
 
 
#define MAX_WIDTH           48
#define MAX_HEIGHT          48
#define SPLIT_SPACE         5
#define SETTING_COUNT       1
 
@implementation DragMenuView
@synthesize bRotation;
 
- (id)initDragMenuView {
    CGRect mainRect = [[UIScreen mainScreen] bounds];
    self = [super initWithFrame:CGRectMake(mainRect.size.width - MAX_WIDTH, /*mainRect.size.height / 2 - MAX_HEIGHT / 2*/50, MAX_WIDTH, MAX_HEIGHT)];
    if (self)
    {
        // Initialization code
        self.backgroundColor = [UIColor clearColor];
        
        m_selectBtn = [[UIButton alloc]initWithFrame:CGRectMake(0, 0, MAX_WIDTH, MAX_HEIGHT)];
        [m_selectBtn setBackgroundImage:[UIImage imageNamed:@"select.png"] forState:UIControlStateNormal];
        [m_selectBtn addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];
        [self insertSubview:m_selectBtn atIndex:9500];
        
        m_contentView = [[UIView alloc] initWithFrame:CGRectMake(MAX_WIDTH + SPLIT_SPACE, 0, MAX_WIDTH * SETTING_COUNT, MAX_HEIGHT)];
        m_contentView.userInteractionEnabled = YES;
        m_contentView.hidden = YES;
        //m_contentView.backgroundColor = [UIColor grayColor];
        
        UIButton *setting = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, MAX_WIDTH, MAX_HEIGHT)];
        [setting setEnabled:NO];
        [setting setSelected:NO];
        [setting setBackgroundImage:[UIImage imageNamed:@"mic.png"] forState:UIControlStateNormal];
        [setting addTarget:self action:@selector(clickVoice:) forControlEvents:UIControlEventTouchUpInside];
        [m_contentView addSubview:setting];
/*
        setting = [[UIButton alloc] initWithFrame:CGRectMake(MAX_HEIGHT, 0, MAX_HEIGHT, MAX_HEIGHT)];
        [setting setBackgroundImage:[UIImage imageNamed:@"mic.png"] forState:UIControlStateNormal];
        [setting addTarget:self action:@selector(clickAudio:) forControlEvents:UIControlEventTouchUpInside];
        [m_contentView addSubview:setting];
        
        setting = [[UIButton alloc] initWithFrame:CGRectMake(MAX_HEIGHT * 2, 0, MAX_HEIGHT, MAX_HEIGHT)];
        [setting setBackgroundImage:[UIImage imageNamed:@"mic.png"] forState:UIControlStateNormal];
        [setting addTarget:self action:@selector(clickAudio:) forControlEvents:UIControlEventTouchUpInside];
        [m_contentView addSubview:setting];
        
        setting = [[UIButton alloc] initWithFrame:CGRectMake(MAX_HEIGHT * 3, 0, MAX_HEIGHT, MAX_HEIGHT)];
        [setting setBackgroundImage:[UIImage imageNamed:@"mic.png"] forState:UIControlStateNormal];
        [setting addTarget:self action:@selector(clickAudio:) forControlEvents:UIControlEventTouchUpInside];
        [m_contentView addSubview:setting];
*/
        [self insertSubview:m_contentView belowSubview:m_selectBtn];
    }
    
    return self;
}
-(void)layoutMenuView:(BOOL)bShow { // 用户点击设置按钮时,需要弹出或者隐藏设置功能视图。这个视图的显示因为有边界问题,所以需要一些算法调整显示位置
    CGRect mainRect = [[UIScreen mainScreen] bounds];
    CGRect viewRect = [self frame];
    
    int x = 0, y = viewRect.origin.y, w = 0, h = MAX_HEIGHT;
    if (bShow) // 显示
    {
        w = (MAX_WIDTH * (SETTING_COUNT + 1) + SPLIT_SPACE);
        if ((viewRect.origin.x + w) > mainRect.size.width) //右边可显示区域不够显示,需要切换到左边来显示
        {
            x = viewRect.origin.x - w + MAX_WIDTH;
            self.frame = CGRectMake(x, y, w, h);
            m_contentView.frame = CGRectMake(0, 0, MAX_WIDTH * SETTING_COUNT, MAX_HEIGHT);
            m_selectBtn.frame = CGRectMake(MAX_WIDTH * SETTING_COUNT + SPLIT_SPACE, 0, MAX_WIDTH, MAX_HEIGHT);
        }
        else // 右边显示区域够了,则直接在右边显示
        {
            x = viewRect.origin.x;
            self.frame = CGRectMake(x, y, w, h);
            m_selectBtn.frame = CGRectMake(0, 0, MAX_WIDTH, MAX_HEIGHT);
            m_contentView.frame = CGRectMake(MAX_WIDTH + SPLIT_SPACE, 0, MAX_WIDTH * SETTING_COUNT, MAX_HEIGHT);
        }
    }
    else //隐藏
    {
        w = MAX_WIDTH;
        CGRect btnRect = m_selectBtn.frame;
        if (btnRect.origin.x == 0) //如果是直接右边显示的,则调整宽度即可隐藏复原
        {
            x = viewRect.origin.x;
            self.frame = CGRectMake(x, y, w, h);
        }
        else  // 如果是因为可显示区域不够,而调整到左边来显示的话,则需要调整X坐标和宽度。另外还需要重新调整子视图的位置。
        {
            x = viewRect.origin.x + (MAX_WIDTH * SETTING_COUNT + SPLIT_SPACE);
            self.frame = CGRectMake(x, y, w, h);
            m_selectBtn.frame = CGRectMake(0, 0, MAX_WIDTH, MAX_HEIGHT);
        }
    }
}
-(void)click:(id)sender { // 设置按钮的响应动作,根据当前位置和边界情况来显示设置视图
    m_contentView.hidden = !m_contentView.hidden;
    [self layoutMenuView:!(m_contentView.hidden)];
}
-(void)clickVoice:(id)sender { // 设置视图中,功能按钮的响应函数
    UIButton *btn = (UIButton*)sender;
    [btn setSelected:![btn isSelected]];
    [btn setAlpha:([btn isSelected]) ? 0.5f : 1.0f]; // 为了区分点击和未点击状态
    // do somthing......
}
@end

实现代码也就那么一点点,都是很简单的代码。

然后在ViewController中加上变量,并创建这个浮动菜单:

DragMenuView  *m_dragMenu;
 
    //
    // whether support floating menu
    // add by yshen on 2015-7-27
    //
    m_dragMenu = [[DragMenuView alloc]initDragMenuView];
    UIPanGestureRecognizer *gesture = [[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(viewDidDragged:)];
    [gesture setMaximumNumberOfTouches:1];
    [gesture setMinimumNumberOfTouches:1];
    [m_dragMenu addGestureRecognizer:gesture];
    [self.view insertSubview:m_dragMenu atIndex:9999];
    m_dragMenu.hidden = NO;

手势识别函数:

-(void)viewDidDragged:(UIPanGestureRecognizer*)gesture {
    if (gesture.state == UIGestureRecognizerStateChanged || gesture.state == UIGestureRecognizerStateEnded)
    {
        CGPoint offset = [gesture translationInView:self.view];
        int x = m_dragMenu.center.x + offset.x;
        int y = m_dragMenu.center.y + offset.y;
        [m_dragMenu setCenter:CGPointMake(x, y)];
        [gesture setTranslation:CGPointMake(0, 0) inView:self.view];
    }
}

浮动菜单置顶:

[self.view bringSubviewToFront:m_dragMenu];

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • iOS实现动态自适应标签

    iOS实现动态自适应标签

    这篇文章主要为大家详细介绍了iOS动态自适应标签的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • iOS仿微博导航栏动画(CoreGraphics)的实现方法

    iOS仿微博导航栏动画(CoreGraphics)的实现方法

    这篇文章主要给大家介绍了关于iOS仿微博导航栏动画(CoreGraphics)的实现方法,文章最后给出了完整的示例代码,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • 详解IOS的Automatically Sign在设备上打包

    详解IOS的Automatically Sign在设备上打包

    本篇教程主要给大家分享了IOS的Automatically Sign如何在设备上直接打包,有需要的朋友参考学习下。
    2018-01-01
  • iOS11实现App内自动连接Wi-Fi的方法

    iOS11实现App内自动连接Wi-Fi的方法

    这篇文章主要给大家介绍了关于iOS11实现App内自动连接Wi-Fi的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-10-10
  • 详解iOS AFNetworking取消正在进行的网络请求

    详解iOS AFNetworking取消正在进行的网络请求

    这篇文章主要介绍了详解iOS AFNetworking取消正在进行的网络请求,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • Objective-C Json 实例详解

    Objective-C Json 实例详解

    这篇文章主要介绍了 Objective-C Json 实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握Object-C Json的使用,需要的朋友可以参考下
    2017-10-10
  • 解析iOS10中的极光推送消息的适配

    解析iOS10中的极光推送消息的适配

    这篇文章主要介绍了解析iOS10中的极光推送消息的适配的相关资料,我们需要先安装Xcode8.0版本,接下来本文分步骤详细给大家介绍,需要的朋友可以参考下
    2016-09-09
  • iOS开发教程之UIRefreshControl使用的踩坑指南

    iOS开发教程之UIRefreshControl使用的踩坑指南

    UIRefreshControl是iOS6自带的UITableView下拉刷新控件。下面这篇文章主要给大家介绍了关于iOS开发教程之UIRefreshControl使用的踩坑指南,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2018-04-04
  • iOS开发-调用系统相机和相册获取照片示例

    iOS开发-调用系统相机和相册获取照片示例

    这篇文章主要介绍了iOS开发-调用系统相机和相册获取照片示例的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-02-02
  • IOS获取系统相册中照片的示例代码

    IOS获取系统相册中照片的示例代码

    在大家的日常开发中,经常会遇到有的app需要从系统相册中获取图片,如设置用户头像等,下面这篇文章给大家分享这个功能的实现,有需要的可以参考借鉴。
    2016-09-09

最新评论