Starling 环形进度条实现
项目初期想实现这个效果来着,查了很多资料(包括式神的<神奇的滤镜>),也没找到完美的实现方法,,当时时间紧迫,就找了传统的进度条来代替实现。
最近偶然心血来潮,查了各方面资料,终于找到实现的方法,效果图放上。

代码1:使用Starling-graphic-extension绘制多边形,用多边形的角度变化来模拟扇形的动画(原理很简单,创意不错),percentage表示进度(0-1)。
private function drawPieMask (graphics:Graphics , percentage:Number , radius:Number = 50, x:Number = 0, y:Number = 0, rotation:Number = 0 , sides:int = 6) :void {
graphics .clear ();
graphics .beginTextureFill (_testTex );
// graphics should have its beginFill function already called by now
graphics .moveTo (x , y );
if (sides < 3 ) sides = 3; // 3 sides minimum
// Increase the length of the radius to cover the whole target
radius /= Math .cos (1 /sides * Math .PI );
// Shortcut function
var lineToRadians:Function = function (rads:Number ): void {
graphics .lineTo (Math .cos (rads ) * radius + x , Math. sin( rads) * radius + y) ;
};
// Find how many sides we have to draw
var sidesToDraw:int = Math .floor (percentage * sides );
for ( var i:int = 0; i <= sidesToDraw; i ++)
lineToRadians ((i / sides ) * (Math .PI * 2 ) + rotation) ;
// Draw the last fractioned side
if (percentage * sides != sidesToDraw )
lineToRadians (percentage * (Math .PI * 2 ) + rotation) ;
graphics .lineTo (x ,y );
graphics .endFill ();
}
参见 http://flassari.is/2009/11/pie-mask-in-as3/,附上原理swf(没看到的请刷新页面)
代码2:基础纹理的生成(可以使用图片或者动态合成)
var bmp:BitmapData = new BitmapData(256, 256, true, 0x0); //纹理的非绘制部分alpha为0
var sprite:Sprite = new Sprite();
sprite.graphics.beginFill(ColorUtil.YELLOW);
sprite.graphics.drawCircle(50, 50, 50);
bmp.draw(sprite); _testTex = Texture.fromBitmapData(bmp, false);
var img:Image = new Image(_testTex);
img.x = 0;
img.y = 600; var mask:Shape = new Shape();
mask.x = img.x;
mask.y = img.y;
container.addChild(mask);
mask.addEventListener(Event.ENTER_FRAME, function():void {
drawPieMask(mask.graphics, _testProg, 50, 50, 50, -Math.PI/2, 3);
_testProg = (_testProg + 0.01) % 1;
}); var circle:Shape = new Shape();
circle.graphics.beginFill(ColorUtil.GREEN);
circle.graphics.drawCircle(0, 0, 40);
circle.x = img.x + 50;
circle.y = img.y + 50;
container.addChild(circle);
附:测试发现release版本在ios上会有问题,现象是只能转到一个角度,然后就消失了。原因在于starling.display.graphics.Fill的isReflex函数,在release版本会出现问题,只能画边数少于等于3的多边形,把这个调用注释掉就可以了。纯2d的游戏,无所谓顺时针逆时针,能画出来就好。至于为什么在ios的release版本上有问题,这个就不清楚了。桌面release版本没有发现这个问题。
Starling 环形进度条实现的更多相关文章
- 图解CSS3制作圆环形进度条的实例教程
圆环形进度条制作的基本思想还是画出基本的弧线图形,然后CSS3中我们可以控制其旋转来串联基本图形,制造出部分消失的效果,下面就来带大家学习图解CSS3制作圆环形进度条的实例教程 首先,当有人说你能不能 ...
- iOS带动画的环形进度条(进度条和数字同步)
本篇写的是实现环形进度条,并带动画效果,要实现这些,仅能通过自己画一个 方法直接看代码 为了方便多次调用,用继承UIView的方式 .m文件 #import <UIKit/UIKit.h> ...
- iOS 开发技巧-制作环形进度条
有几篇博客写到了怎么实现环形进度条,大多是使用Core Graph来实现,实现比较麻烦且效率略低,只是一个小小的进度条而已,我们当然是用最简单而且效率高的方式来实现. 先看一下这篇博客,博客地址:ht ...
- iOS一分钟学会环形进度条
有几篇博客写到了怎么实现环形进度条,大多是使用Core Graph来实现,实现比较麻烦且效率略低,只是一个小小的进度条而已,我们当然是用最简单而且效率高的方式来实现.先看一下这篇博客,博客地址:htt ...
- Swift - 环形进度条(UIActivityIndicatorView)的用法
Swift中,除了条形进度条外,还有环形进度条,效果图如下: 1,环形进度条的基本属性 (1)Style: Large White:比较大的白色环形进度条 White:白色环形进度条 Gray:灰色环 ...
- 环形进度条的实现方法总结和动态时钟绘制(CSS3、SVG、Canvas)
缘由: 在某一个游戏公司的笔试中,最后一道大题是,“用CSS3实现根据动态显示时间和环形进度[效果如下图所示],且每个圆环的颜色不一样,不需要考虑IE6~8的兼容性”.当时第一想法是用SVG,因为SV ...
- Android简易实战教程--第十七话《自定义彩色环形进度条》
转载请注明出处:http://blog.csdn.net/qq_32059827/article/details/52203533 点击打开链接 在Android初级教程里面,介绍了shape用法 ...
- canvas绘制环形进度条
<!DOCTYPE html> <html > <head> <meta http-equiv="content-type" conten ...
- 【CSS】环形进度条
效果图 原理剖析 1.先完成这样一个半圆(这个很简单吧) 2.overflow: hidden; 3.在中间定位一个白色的圆形做遮挡 4.完成另一半 5.使用animate配合时间完成衔接 源码 &l ...
随机推荐
- HDU 5534:Partial Tree(完全背包)***
题目链接 题意 给出一个n个结点的树,给出n-1个度的权值f[],代表如果一个点的度数为i,那么它对于答案的贡献有f[i].问在这棵树最大的贡献能达到多少. 思路 对于这个图,有n*2-2个度可以分配 ...
- websocket实现群聊和单聊(转)
昨日内容回顾 1.Flask路由 1.endpoint="user" # 反向url地址 2.url_address = url_for("user") 3.m ...
- 5.秋招复习简单整理之请介绍一下List和ArrayList的区别,arrayList和HashSet区别?
第一问:List是接口,ArrayList是List的实现类. 第二问:ArrayList是List的实现类,HashSet是Set的实现类,List和Set都实现了Collection接口. Arr ...
- 魔道祖师 (作者:墨香铜臭)mobi格式下载
下载地址:[点我]电视剧陈情令原著主要讲的是五大仙门世家的故事,其中主要讲述的就是魏无羡与蓝忘机之间的故事. 前世的魏无羡万人唾骂,声名狼藉. 被情同手足的师弟带人端了老巢, 纵横一世,死无全尸. 曾 ...
- GreenPlum完全安装_GP5.11.3完整安装
1 概述 1.1 背景 1.2 目标 1.3 使用对象 2 配置系统信息 2.1 配置系统信息,做安装Greenplum的准备工作 Greenplum 数据库版本5.11.3 2.1.1 Greenp ...
- android_onSaveInstanceState_onRestoreInstanceState研究
当一个activity的状态是一个容易被系统宰掉时,比如pause或者stop状态,此时这个活动不一定已经被销毁了,那么这个activity的onSaveInstanceState方法会被系统调用(值 ...
- 微信小程序之楼层效果
今天做了一个小程序实现一个楼层效果 带大家分享下经验和api的使用吧 如图 将左边和右边各分了一个组件 目录如下 其中list页面是这个楼层效果的页面 components是组成这个页面的两个组件 ...
- STM32F072从零配置工程-基于HAL库的串口UART中断配置
先上一个采用串口直接传输的Demo: 此处的思路是完全采用HAL库来实现的,核心是运用HAL_UART_Transmit_IT和HAL_UART_Receive_IT两个函数来实现的,可以作为一个De ...
- Uncaught Error: Bootstrap dropdown require Popper.js
Bootstrap 要求Popper.js 如果安装了Popper.js还报错,肯定就是Popper的问题 https://cdn.bootcss.com/popper.js/1.12.5/umd/p ...
- python基础知识五 各类型数据方法补充,转换,分类,编码+坑中菜
3.9各类型数据方法补充,转换,分类,编码,坑中菜 3.9.1数据类型方法补充 1.str:不可变 补充方法 s1.capitalize():首字母大写 s1 = "alex" s ...