我的编程空间,编程开发者的网络收藏夹
学习永远不晚

iOS实现可拖动的浮动菜单

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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, 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];

        [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];

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

iOS实现可拖动的浮动菜单

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

iOS实现可拖动的浮动菜单

这篇文章主要为大家详细介绍了iOS实现可拖动的浮动菜单,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
2022-11-13

android怎么实现可拖动的浮动view

本篇内容主要讲解“android怎么实现可拖动的浮动view”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“android怎么实现可拖动的浮动view”吧!业务来源页面最小化后,需要出现一个浮动
2023-06-30

react怎么实现浮动菜单

react实现浮动菜单的方法:1、利用onMouseOver和onMouseLeave来监听鼠标的变化;2、在样式中设置父类及子类的position值;3、设置父类值为relative,子类值为absolute,并在菜单的css中加入“z-index:999;”;4、通过控制display来控制显示与否即可。
2023-05-14

Android如何实现单页面浮层可拖动view

这篇文章主要介绍Android如何实现单页面浮层可拖动view,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!需求是需要在一个已经存在的页面添加一个可拖动的浮层广告。使用到的技术:ViewDragHelper效果如图:
2023-05-30

react如何实现浮动菜单

本篇内容介绍了“react如何实现浮动菜单”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!react实现浮动菜单的方法:1、利用onMouse
2023-07-04

Android可拖动悬浮窗怎么实现

要实现在Android中可拖动的悬浮窗,可以按照以下步骤进行:1. 创建一个自定义的`FloatingView`类来实现悬浮窗的视图。在该类中,你可以添加任何你想要显示的视图元素,如文字、图像等。2. 在`FloatingView`类中,重
2023-08-16

iOS实现拖拽View跟随手指浮动效果

本文实例为大家分享了iOS实现拖拽View跟随手指浮动的具体代码,供大家参考,具体内容如下 效果图:1.自定义要跟随手指浮动的那个View// // OrangeView.m // 拖拽View跟随手指浮动 // // Created by
2022-05-31

如何使用Android实现单页面浮层可拖动view

这篇文章将为大家详细讲解有关如何使用Android实现单页面浮层可拖动view,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在DragframeLayout中的onTouchEvent一直接收不到触摸消息
2023-05-30

web开发中如何实现浮动菜单

这篇文章主要介绍了web开发中如何实现浮动菜单,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。代码还可进一步精简,时间关系,这里先发上来大家再优化吧,菜单项自己再添一些。
2023-06-08

android 应用内部悬浮可拖动按钮简单实现代码

本文介绍了android 应用内部悬浮可拖动按钮简单实现代码,分享给大家,具体如下:可以悬浮在activity上面,在加载fragment时悬浮按钮不会消失实现方式很简单,因为是在应用内部拖动的,只需要通过Activity获取WindowM
2023-05-30

iOS怎么使用UICollectionView实现拖拽移动单元格

这篇“iOS怎么使用UICollectionView实现拖拽移动单元格”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“iOS怎
2023-06-30

JS如何实现简单可拖动的模态框

这篇文章主要讲解了“JS如何实现简单可拖动的模态框”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JS如何实现简单可拖动的模态框”吧!简单版本效果图:实现思路:给可拖动部分添加点击事件,触发时
2023-07-02

javascript如何实现可拖动的树

这篇文章主要介绍“javascript如何实现可拖动的树”,在日常操作中,相信很多人在javascript如何实现可拖动的树问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”javascript如何实现可拖动的树
2023-07-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录