还有半个多月就到春节了,年底相信很多公司都会进行年度总结以及公司发展状况总结,在这过程中难免会用到RoadMap,在这我们也使用TWaver的矢量部分绘制一个Android系统的发展历程。先看效果:


什么,最里面Android 1.0的气泡看不清?没关系,放大下ok。

先来绘制一条road:

twaver.Util.registerImage('road', {
w: 880,
h: 370,
origin:{ x: 0, y: 0 },
v: [{
shape: 'rect',
rel: true,
rect: [ 0, 0, 1, 1],
lineColor:'red',
lineWidth: 1,
visible: debug,
},{
shape: 'path',
data: 'M850,10C50,140,50,160,400,173C900,180,900,205,400,210C0,220,0,250,850,280L850,360C-50,290,-50,200,400,200C850,195,850,190,400,178C40,160,40,135,850,8z',
fill:'#E3E3E3',
lineWidth:0,
}],
});

  

 

绘制一个bubble,可以添加一些动画:

twaver.Util.registerImage('bubble', {
w: 100,
h: 120,
origin:{ x: 0, y: 0 },
scale: { x: '<%=getClient("scale")%>', y: '<%=getClient("scale")%>' },
v: [{
shape: 'rect',
rel: true,
rect: [ 0, 0, 1, 1],
lineColor:'red',
lineWidth: 1,
visible: debug,
},{
shape: 'path',
data: 'M50,100Q10,65,10,60C0,50,0,0,50,0C100,0,100,50,90,60Q90,65,50,100',
fill:'<%=getClient("color")%>',
lineWidth:0,
rotate:0,
},{
shape: 'circle',
cx: 49,
cy: 48,
r:42,
startAngle: 180,
endAngle: 360,
fill:'#EFEFEF',
lineWidth:0,
},{
shape: 'text',
text: '<%=getClient("year")%>',
x:50,
y:110,
fill:'white',
textAlign: 'center',
textBaseline: 'middle',
font: '14px "Microsoft Yahei"',
},{
shape: 'text',
text: '<%=getClient("title")%>',
x:50,
y:33,
fill:'black',
textAlign: 'center',
textBaseline: 'middle',
font: '16px "Microsoft Yahei" bold',
},{
shape: 'text',
text: '<%=getClient("description")%>',
x:50,
y:60,
fill:'white',
textAlign: 'center',
textBaseline: 'middle',
font: '10px "Microsoft Yahei"',
}],
});

  

 
 

绘制belt:

twaver.Util.registerImage('belt', {
w: 500,
h: 400,
origin:{ x: 0, y: 0 },
v: [{
shape: 'rect',
rel: true,
rect: [ 0, 0, 1, 1],
lineColor:'red',
lineWidth: 1,
visible: debug,
},{
shape: 'path',
data: 'M30,50L400,50C500,50,500,200,400,200L100,200C0,200,0,350,100,350L450,350',
lineColor:'#DDDDDD',
lineWidth:34,
},{
shape: 'path',
data: 'M30,50L30,33L15,33L30,50L15,67L30,67L30,50M449,330l15,20l-15,20',
fill:'#DDDDDD',
lineWidth:0,
},{
shape: 'path',
data: 'M100,50L400,50C500,50,500,200,400,200L100,200C0,200,0,350,100,350L380,350',
lineColor:'black',
lineWidth:1.5,
},{
shape: 'path',
data: 'M30,50L100,50M380,350L465,350',
lineColor:'black',
lineDash: [2, 3],
lineWidth:1.5,
}],
});


再添加年份以及一些文字:

twaver.Util.registerImage('egg', {
w: 60,
h: 60,
origin: {x:0,y:0},
v: [{
shape: 'rect',
rel: true,
rect: [ 0, 0, 1, 1],
lineColor:'red',
lineWidth: 1,
visible: debug,
},{
shape: 'circle',
rel: true,
cx: 0.5,
cy: 0.5,
r: 25,
fill:'#DDDDDD',
lineWidth:0,
},{
shape: 'circle',
rel: true,
cx: 0.5,
cy: 0.5,
r: 18,
fill:'<%=getClient("color")%>',
lineWidth:0,
},{
shape: 'text',
text: '<%=getClient("year")%>',
rel:true,
x:0.5,
y:0.5,
fill:'white',
textAlign: 'center',
textBaseline: 'middle',
font: '12px "Microsoft Yahei" bold',
}],
});

  

var createText=function(parent,title,text,x,y,left){
var node = new twaver.Follower();
node.setHost(parent);
node.setName(title);
node.setStyle('label.color','#DF013A');
node.setStyle('label.position','right.right');
if(left){
node.setStyle('label.position','right.left');
}
node.setStyle('label.font','bold 10px "Microsoft Yahei"');
node.setImage(null);
node.setLocation(x,y);
box.add(node);
var node = new twaver.Follower();
node.setHost(parent);
node.setName(text);
node.setStyle('label.color','black');
node.setStyle('label.position','right.right');
if(left){
node.setStyle('label.position','right.left');
}
node.setStyle('label.font','10px "Microsoft Yahei"');
node.setImage(null);
node.setLocation(x,y+12);
box.add(node);
};
createText(belt,'Android Bate','代表手机:HTC Dream(G1)',5,445);
createText(belt,'Android 1.0系统发布','代表手机:HTC Hero(G3)',90,365);
createText(belt,'Android 2.0系统发布','代表手机:摩托罗拉 Milestone ',185,445);
createText(belt,'Android 2.3系统发布','代表手机:三星 Galaxy II i9100 ',280,480);
createText(belt,'Android 3.0系统发布','代表手机:摩托罗拉 XOOM平板电脑',37,475);
createText(belt,'Android 4.0系统发布','代表手机:GALAXY Nexus',37,500);
createText(belt,'Android 4.1/4.2/4.3系统发布','代表手机:Nexus 7平板电脑',-65,585);
createText(belt,'Android 4.4系统发布','Nexus 4、Nexus 7、Nexus 10以及原生版HTC One、Galaxy S4SHIELD',36,684);
createText(belt,'Android 5.0系统发布','Nexus 6、Nexus 9平板及 Nexus Player ',135,605);

  

 


这样一个简单的RoadMap就制作完成了,是不是很简单。我们依然可以将矢量+动画相结合制作出更加丰富的RoadMap,后续我们也不断退出一些更加丰富的RoadMap,当然也欢迎您来一试身手,如果有需求,可以邮件联系我们。
jeff.fu@servasoft.com

TWaver矢量小试——Android演进路线图的更多相关文章

  1. 我的微软.net演进路线图

    原文地址:我的微软.net演进路线图 我的微软.net演进路线图 我的这几年,编程方面主要是跟在微软旗下奔跑的,主要语言是C# 集成开发环境(IDE) .NET Framework版本 介入年份 Vi ...

  2. java+android学习路线图

    java.android学习路线图  看图之前先按住Ctrl键同时滑动鼠标滚轮

  3. TMF接口标准MTOSI演进路线图

    下图为TMF接口标准MTOSI的演进路线图.MTOSI 2.1基于mTOP框架制定,MTOSI 3.0->MTOSI 4.0->MTOSI 5.0将逐步基于全新的TIP框架实现.例如,MT ...

  4. 自动换行的矢量文字(android demo)

    由于矢量字体的宽度不同,自测android字体,发现当中文字体大小为100像素时,字母s等 宽度大概在52,字母l等 宽度大概在26,这样自动换行就不可以按字符的个数计算截取每行显示的字串. 直接上代 ...

  5. Android技术路线图

    邮件问题: 老师你好,我从去年就在看你的关于Android的视频了,的确讲的不错,去年看了一段时间,寒假的时候回家重新复习了一下Java基础知识,开学的时候看到你又陆续出了一些视频,这段时间看完了,跟 ...

  6. 一个老鸟发的公司内部整理的 Android 学习路线图 Markdown 版本

    jixiaohua发了一篇一个老鸟也发了一份他给公司内部小伙伴整理的路线图.另一份 Android 开发学习路线图.可惜不是MarkDown格式的,所以jixiaohua直接上传的截图,在jixiao ...

  7. Android学习路线图

    第一阶段:Java面向对象编程 1.Java基本数据类型与表达式,分支循环. 2.String和StringBuffer的使用.正则表达式. 3.面向对象的抽象,封装,继承,多态,类与对象,对象初始化 ...

  8. 一个老鸟发的公司内部整理的 Android 学习路线图

    基础工具部分: 中文手册,我猜测是Maven中文手册,可是我并没有找到这样的资源,欢迎知道的朋友告诉我: Android部分有 『第三方库集合』,我没能找到资源地址: 书籍我大多是给的豆瓣链接,如果觉 ...

  9. Android 学习路线图(转载自https://blog.csdn.net/lixuce1234/article/details/77947405)

    程序设计 一.java (a)基本语法(如继承.异常.引用.泛型等) Java核心技术 卷I(适合入门) 进阶 Effective Java中文版(如何写好的Java代码) Java解惑 (介绍烂Ja ...

随机推荐

  1. 使用qemu

    1 获取qemu启动linux kernel的log qemu-system-x86_64 -nographic -kernel xxx -initrd xxx -append "conso ...

  2. MFC中SliderCtrl控件的使用

    在MFC中滑动条(CSliderCtrl)是个经常使用的控件,使用方法例如以下: 主要要方法有: 1.设置.取得滑动范围: void SetRange( int nMin, int nMax, BOO ...

  3. jquery uploadify在谷歌浏和火狐下无法上传的解决方案(.Net版)

    在项目紧张的进行过程中,jquery uploadify上传不兼容的问题一直没有试着去解决,只幻想着用ie的人越来越多,怎么奈何firefox4刚推出,就有4000万的下载.......仰天长叹,记生 ...

  4. POJ1584 A Round Peg in a Ground Hole 凸包判断 圆和凸包的关系

    POJ1584 题意:给定n条边首尾相连对应的n个点 判断构成的图形是不是凸多边形 然后给一个圆 判断圆是否完全在凸包内(相切也算) 思路:首先运用叉积判断凸多边形 相邻三条边叉积符号相异则必有凹陷 ...

  5. bzoj1875 [SDOI2009]HH去散步——矩阵快速幂

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1875 有个限制是不能走回头路,比较麻烦: 所以把矩阵中的元素设成边的经过次数,单向边之间就好 ...

  6. .NET Runtime version 2.0.50727.8762 - 执行引擎错误(7969097A) (80131506)

    VS2010调试IIS发布的web工程提示:无法连接到 Visual Studio 开发服务器 .NET Runtime version 2.0.50727.8762 - 执行引擎错误(7969097 ...

  7. bzoj 1715: [Usaco2006 Dec]Wormholes 虫洞【spfa判负环】

    tag是假的,用了及其诡异的方法判负环 正权无向边和负权有向边的图 #include<iostream> #include<cstdio> #include<cstrin ...

  8. 51nod1344 走格子

    1344 走格子 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题  收藏  关注 有编号1-n的n个格子,机器人从1号格子顺序向后走,一直走到n号格子,并需要从n号格 ...

  9. K Seq HihoCoder - 1046 || BZOJ4504 k个串

    这题与超级钢琴类似,然而重复的不重复计算贡献.. 那么先求出数组nxt,nxt[i]表示第i个元素之后的第一个与其相等的元素的下标,不存在则nxt[i]=0 考虑取的区间左端点为1时的情况. 将读入序 ...

  10. ACM_抢糖果

    抢糖果 Time Limit: 2000/1000ms (Java/Others) Problem Description: 今天计实班的生活委员心情大好,在永诚超市狂购了好多好多糖果,好开心~o(∩ ...