swift po 实现动态按钮2
// ButtonViewController.swift
// PopInstall
//
// Created by su on 15/12/11.
// Copyright © 2015年 tian. All rights reserved.
//
import UIKit
class ButtonViewController: UIViewController {
//状态
var hamburgerOpen = true
var hambureButton : MyButton?
var top:UIView?
var middle:UIView?
var bottom:UIView?
override func viewDidLoad() {
super.viewDidLoad()
self.view.backgroundColor = UIColor.whiteColor()
//实例化汉堡包按钮
self.hambureButton = MyButton()
self.hambureButton?.backgroundColor = UIColor.blackColor()
self.hambureButton?.frame = CGRect(x: 100, y: 100, width: 150, height: 150)
self.hambureButton?.layer.cornerRadius = 75
self.view.addSubview(hambureButton!)
self.hambureButton?.addTarget(self, action: "didTapHanburgerButton:", forControlEvents: UIControlEvents.TouchUpInside)
//三道杠的高度
let sectionWidth:CGFloat = 80.0
let sectionHeight:CGFloat = 11.0
//绘制三道杠
top = UIView(frame: CGRect(x: self.hambureButton!.bounds.size.width / 2 - sectionWidth / 2, y: 40, width: sectionWidth, height: sectionHeight))
top!.backgroundColor = UIColor.whiteColor()
top!.userInteractionEnabled = false
top!.layer.cornerRadius = sectionHeight / 2
self.hambureButton?.addSubview(top!)
middle = UIView(frame: CGRect(x: self.hambureButton!.bounds.size.width / 2 - sectionWidth / 2, y: 69, width: sectionWidth, height: sectionHeight))
middle!.backgroundColor = UIColor.whiteColor()
middle!.userInteractionEnabled = false
middle!.layer.cornerRadius = sectionHeight / 2
self.hambureButton?.addSubview(middle!)
bottom = UIView(frame: CGRect(x: self.hambureButton!.bounds.size.width / 2 - sectionWidth / 2, y: 99, width: sectionWidth, height: sectionHeight))
bottom!.backgroundColor = UIColor.whiteColor()
bottom!.userInteractionEnabled = false
bottom!.layer.cornerRadius = sectionHeight / 2
self.hambureButton?.addSubview(bottom!)
}
func didTapHanburgerButton(sender:UIButton) {
//所有pop对象的复用实例
//颜色动画
var topColor = self.top?.pop_animationForKey("topColor") as! POPSpringAnimation?
var bottomColor = self.bottom?.pop_animationForKey("bottomColor") as! POPSpringAnimation?
//角度旋转动画
var topRotate = self.top?.layer.pop_animationForKey("topRatate") as! POPSpringAnimation?
var bottomRotate = self.bottom?.layer.pop_animationForKey("bottomRotate") as! POPSpringAnimation?
//
// //位置:Y坐标 动画
var topPosition = self.top?.layer.pop_animationForKey("topPosition") as! POPSpringAnimation?
var bottonPosition = self.bottom?.layer.pop_animationForKey("bottonPosition") as! POPSpringAnimation?
if hamburgerOpen {
//三道杠变红叉叉
hamburgerOpen = false
UIView.animateWithDuration(0.2, animations: { () -> Void in
self.middle?.alpha = 0
})
// 改变上下两道杠的颜色
if topColor != nil {
topColor?.toValue = UIColor.redColor()
} else {
topColor = POPSpringAnimation(propertyNamed: kPOPViewBackgroundColor)
topColor?.toValue = UIColor.redColor()
topColor?.springBounciness = 0
topColor?.springSpeed = 18
top?.pop_addAnimation(topColor, forKey: "topColor")
}
if bottomColor != nil {
bottomColor?.toValue = UIColor.redColor()
} else {
bottomColor = POPSpringAnimation(propertyNamed: kPOPViewBackgroundColor)
bottomColor?.toValue = UIColor.redColor()
bottomColor?.springBounciness = 0
bottomColor?.springSpeed = 18
bottom?.pop_addAnimation(bottomColor, forKey: "bottomColor")
}
//旋转上下两道杠的角度
if topRotate != nil {
topRotate?.toValue = -M_PI / 4
} else {
topRotate = POPSpringAnimation(propertyNamed: kPOPLayerRotation)
topRotate?.toValue = -M_PI / 4
topRotate?.springBounciness = 11
topRotate?.springSpeed = 18
top?.layer.pop_addAnimation(topRotate, forKey: "topRatate")
}
if bottomRotate != nil {
bottomRotate?.toValue = M_PI / 4
} else {
bottomRotate = POPSpringAnimation(propertyNamed: kPOPLayerRotation)
bottomRotate?.toValue = M_PI / 4
bottomRotate?.springBounciness = 11
bottomRotate?.springSpeed = 18
bottom?.layer.pop_addAnimation(bottomRotate, forKey: "bottomRotate")
}
//改变上下两道杠的y坐标形成红色的叉叉
if topPosition != nil {
topPosition?.toValue = 29
} else {
topPosition = POPSpringAnimation(propertyNamed: kPOPLayerTranslationY)
topPosition?.toValue = 29
topPosition?.springBounciness = 11
topPosition?.springSpeed = 18
top?.layer.pop_addAnimation(topPosition, forKey: "topPosition")
}
if bottonPosition != nil {
bottonPosition?.toValue = -29
} else {
bottonPosition = POPSpringAnimation(propertyNamed: kPOPLayerTranslationY)
bottonPosition?.toValue = -29
bottonPosition?.springBounciness = 11
bottonPosition?.springSpeed = 18
bottom?.layer.pop_addAnimation(bottonPosition, forKey: "bottonPosition")
}
} else {
//红叉叉变三道杠
hamburgerOpen = true
UIView.animateWithDuration(0.2, animations: { () -> Void in
self.middle?.alpha = 1
})
// 改变上下两道杠的颜色
if topColor != nil {
topColor?.toValue = UIColor.whiteColor()
} else {
topColor = POPSpringAnimation(propertyNamed: kPOPViewBackgroundColor)
topColor?.toValue = UIColor.whiteColor()
topColor?.springBounciness = 0
topColor?.springSpeed = 18
top?.pop_addAnimation(topColor, forKey: "topColor")
}
if bottomColor != nil {
bottomColor?.toValue = UIColor.whiteColor()
} else {
bottomColor = POPSpringAnimation(propertyNamed: kPOPViewBackgroundColor)
bottomColor?.toValue = UIColor.whiteColor()
bottomColor?.springBounciness = 0
bottomColor?.springSpeed = 18
bottom?.pop_addAnimation(bottomColor, forKey: "bottomColor")
}
//旋转上下两道杠的角度
if topRotate != nil {
topRotate?.toValue = 0
} else {
topRotate = POPSpringAnimation(propertyNamed: kPOPLayerRotation)
topRotate?.toValue = 0
topRotate?.springBounciness = 11
topRotate?.springSpeed = 18
top?.layer.pop_addAnimation(topRotate, forKey: "topRatate")
}
if bottomRotate != nil {
bottomRotate?.toValue = 0
} else {
bottomRotate = POPSpringAnimation(propertyNamed: kPOPLayerRotation)
bottomRotate?.toValue = 0
bottomRotate?.springBounciness = 11
bottomRotate?.springSpeed = 18
bottom?.layer.pop_addAnimation(bottomRotate, forKey: "bottomRotate")
}
//改变上下两道杠的y坐标形成红色的叉叉
if topPosition != nil {
topPosition?.toValue = 0
} else {
topPosition = POPSpringAnimation(propertyNamed: kPOPLayerTranslationY)
topPosition?.toValue = 0
topPosition?.springBounciness = 11
topPosition?.springSpeed = 18
top?.layer.pop_addAnimation(topPosition, forKey: "topPosition")
}
if bottonPosition != nil {
bottonPosition?.toValue = 0
} else {
bottonPosition = POPSpringAnimation(propertyNamed: kPOPLayerTranslationY)
bottonPosition?.toValue = 0
bottonPosition?.springBounciness = 11
bottonPosition?.springSpeed = 18
bottom?.layer.pop_addAnimation(bottonPosition, forKey: "bottonPosition")
}
}
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/
swift po 实现动态按钮2的更多相关文章
- Atitit 动态按钮图片背景颜色与文字组合解决方案
Atitit 动态按钮图片背景颜色与文字组合解决方案 转换背景颜色,setFont("cywe_img", fontScale, 50, 5) 设置文字大小与坐标 文字分拆,使用字 ...
- android Button 切换背景,实现动态按钮和按钮颜色渐变
android Button 切换背景,实现动态按钮和按钮颜色渐变 一.添加android 背景筛选器selector实现按钮背景改变 1.右键单击项目->new->Oth ...
- VS2010,MFC动态按钮和窗体背景图片,以及是静态文字控件透明,并避免静态文字刷新出现的重叠问题
1.动态按钮的四种动作 1)正常 2)按下 3)滑过 4)失效 在MFC中,4个动作对应着四种位图bmp, 首先,将代表四种状态的位图加载入资源中,将对应的按钮设置为BitmapButton 第二,在 ...
- MFC动态按钮的创建及其消息响应(自定义消息)
动态按钮(多个)的创建: 1.在类中声明并定义按钮控件的ID #define IDC_D_BTN 10000 2.在类的OnInitDialog()函数中动态创建按钮(建立按钮对象时最好建立对象的指针 ...
- MFC动态按钮的创建及其消息响应 和 自定义消息
原文链接: http://www.cnblogs.com/gaohongchen01/p/4046525.html 动态按钮(多个)的创建: 1.在类中声明并定义按钮控件的ID #define IDC ...
- swift计算label动态宽度和高度
swift计算label动态宽度和高度 func getLabHeigh(labelStr:String,font:UIFont,width:CGFloat) -> CGFloat { let ...
- vue之小小动态按钮
Vue是前台框架,可以独立完成前后端分离式web项目渐进式的javascript框架 ,今天我们来设计一个简单的动态按钮 具体效果图如下: 点击后会变成这样: 首先我们需要下载vue.js:htt ...
- Swift - 获取、改变按钮的标题文本(UIButton点击切换title)
在开发中,我们常常需要动态地改变按钮标签文字,使用 setTitle() 函数就可以了.有时我们需要在几个标题间切换,比如下面样例所示,按钮点击后按钮文字会在"播放""暂 ...
- swift class的动态派发
一.测试代码 class BaseCallClass{ func NormalCall(){} @objc func OcCall(){} @objc dynamic func OcDynamicCa ...
随机推荐
- LINQ to SQL 建立实体类 (转)
http://www.cnblogs.com/DebugLZQ/archive/2012/11/14/2770449.html 使用LINQ to SQL时,需要首先建立用于映射数据库对象的模型,也就 ...
- 现在就开始使用AngularJS的三个重要原因
现在就开始使用AngularJS的三个重要原因 在线演示1 本地下载 如果你不熟悉什么是Angular.js的话,小编我强烈推荐你阅读 Javascript教程:AngularJS的五个超酷特性.简单 ...
- emacs之配置auto-complete
el-get-install安装auto-complete emacsConfig/auto-complete-setting.el ;这个是设置一个字母就自动完成的 (setq ac-auto-st ...
- java课程设计-坦克大战
团队课程设计博客链接 个人负责模块 枚举类.工具类.子弹类.图片素材的查找,地图制作 Git管理 包名类名的命名 详细说明 枚举类 如 单人和双人模式 工具类 将每个图片的路径使用字符串保存,便于调用 ...
- UE4 的json读写方式
转自:http://blog.csdn.net/cartzhang/article/details/41009343 JSON 的解析有很多开源库.UE4的JSON使用在代码的Public->S ...
- 通过日志查看Web Api详细运行过程
1. 通过Nuget安装System.Web.Http.Tracing. 2. 通过HttpConfiguration,注册SystemDiagnosticsTraceWriter public st ...
- RESTful API终极版序列化封装
urls: from django.conf.urls import url from app01 import views urlpatterns = [ # url(r"comment/ ...
- Python——截取web网页长图
# -*- coding: utf8 -*-import timeimport xlrdfrom selenium import webdriver def read_excel(filename): ...
- django-admin添加权限
后台manage页面: 可以通过用户直接添加权限,如果需要添加多个权限,则可以通过组,先将多个权限添加个组(总经理,秘书),在个用户添加这个组(总经理,秘书). 代码实现: 实际就是添加多对多的关系 ...
- centos7.3部署django用uwsgi和nginx[亲测可用]
现在nginx nginx version: nginx/1.10.2 uwsgi 2.0.17 django2.0.5 都已经完成完毕,那么开始 uwsgi 配置 uwsgi支持ini.xml等多种 ...