Ios中可拖动的浮动菜单实现
来源:互联网 发布:蓄水池抽样算法 编辑:程序博客网 时间:2024/06/05 20:23
实现一个可拖动的浮动菜单,效果如下:
这个设置图标是可以全屏拖动的,点击一下,可以出现一排设置按钮,可以用来进行功能的开关切换。
废话不多说了,上代码:
//// 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];
0 0
- Ios中可拖动的浮动菜单实现
- iOS自定义悬浮按钮,Objective-C可拖动的浮动按钮,iOS浮动图标,类似AssistiveTouch的浮动漂浮按钮
- android中浮动菜单的基本实现
- 鼠标可拖动的浮动层效果
- JS 弹出可拖动的浮动层
- JS实现可缩放、拖动、关闭和最小化的浮动窗口完整实例
- 在DELPHI7中不使用任何第三方控件,实现放在工具栏上可拖动的XP风格菜单.
- 在DELPHI7中不使用任何第三方控件,实现放在工具栏上可拖动的XP风格菜单.
- 噢,今天终于搞定了在IE6,Firefox中都可拖动,自动定位的浮动菜单啦!
- 浮动,可伸缩菜单
- 经典的带阴影的可拖动的浮动层
- 经典的带阴影的可拖动的浮动层
- iOS中实现视图的拖动
- 带阴影的可拖动的浮动层
- 在asp.net中实现可拖动列的table
- Eclipse RCP中编辑器右键菜单与默认可拖动属性的屏蔽方法
- (转)在DELPHI7中不使用任何第三方控件,实现放在工具栏上可拖动的XP风格菜单
- Javascript_ex_浮动菜单可做成浮动广告
- php 文件下载
- Snail—OC学习之本地数据持久化(plist)
- NGUI UIScrollView UIGrid优化最佳方案,没有之一
- Geforce显卡的级别
- Eclipse开发经典教程:常用快捷键
- Ios中可拖动的浮动菜单实现
- Windows环境下Android Studio v1.0安装教程
- Java基础——其他类对象,IO流
- HDOJ 题目1760 A New Tetris Game(DFS,博弈)
- Coding: 编写合格的REST API
- PAT (Advanced Level) 1067. Sort with Swap(0,*) (25) 只能与0交换
- 看娃娃创始人 丁力:我爱幼教,如同爱我的女儿
- hadoop 在win系统中的eclipse开发测试问题及解决
- caffe study - 数据结构(1)