当前位置: 首页 > news >正文

LWUIT + ChartComponent 之二实现线形图(LineChart)

本文来自http://blog.csdn.net/hellogv/


本文源代码下载地址:http://download.csdn.net/source/872671
本文就不再说多余的开场白了,想看开场白?看这里:http://blog.csdn.net/hellogv/archive/2008/12/15/3521119.aspx
直接贴出实现线形图的代码:
  1. /*
  2. *LWUIT+ChartComponent,实现多种图表
  3. *作者:张国威(咪当俺系噜噜)
  4. *本例实现的是“线形图”
  5. */
  6. packagecom.sun.lwuit.uidemo;
  7. importcom.sun.lwuit.Button;
  8. importcom.sun.lwuit.Command;
  9. importcom.sun.lwuit.Font;
  10. importcom.sun.lwuit.Form;
  11. importcom.sun.lwuit.Image;
  12. importcom.sun.lwuit.Label;
  13. importcom.sun.lwuit.events.ActionEvent;
  14. importcom.sun.lwuit.events.ActionListener;
  15. importcom.sun.lwuit.layouts.FlowLayout;
  16. importorg.beanizer.j2me.charts.ChartItem;
  17. importorg.beanizer.j2me.charts.LineChart;
  18. publicclassLineChartDemoimplementsActionListener{
  19. publicFormform=newForm("LineChartDemo");
  20. privateCommandbackCommand=newCommand("Back",1);
  21. finalLineChartlineChart=newLineChart("");
  22. LineChartDemo()
  23. {
  24. //线形图说明
  25. Stringchart_str[]={"█A:你好吗","█B:早上好","█C:中午好","█D:晚上好","█E:吃宵夜","█F:睡懒觉"};
  26. //线条颜色
  27. int[][]color={{0,0,200},{0,200,0},{200,0,0},{200,0,200},{0,200,200},{200,100,200}};
  28. //线条高度
  29. int[]percent={15,10,5,20,34,16};
  30. initChartInfo(chart_str,color);
  31. lineChart.setFill(true);//填充区域
  32. intwidth=form.getWidth();
  33. intheight=form.getHeight()-140;
  34. Imageimg_hbarChart=drawLineChart(lineChart,width,height,"",color,percent);//绘制线性图
  35. Buttonbutton=newButton(img_hbarChart);
  36. //button.getStyle().setBgTransparency(1);//透明背景,会非常消耗资源,速度减慢,注意使用
  37. button.setBorderPainted(false);
  38. form.addComponent(button);
  39. form.addCommand(backCommand);
  40. form.setCommandListener(this);
  41. form.setLayout(newFlowLayout());//必须使用这种排列,FlowLayout最适合
  42. }
  43. privatevoidinitChartInfo(String[]chart_str,int[][]color)
  44. {
  45. for(inti=0;i<chart_str.length;i++)//循环
  46. {
  47. Labelchart_info=newLabel(chart_str[i]);
  48. chart_info.getStyle().setFgColor(UIDemoMIDlet.RGBtoInt(color[i][0],color[i][1],color[i][2]));
  49. form.addComponent(chart_info);
  50. }
  51. }
  52. privateImagedrawLineChart(ChartItemitem,
  53. intwidth,
  54. intheight,
  55. Stringimagefile,
  56. int[][]color,//线条颜色
  57. int[]percent)//线条高度(百分比)
  58. {
  59. item.setFont(Font.FACE_PROPORTIONAL,Font.STYLE_PLAIN,Font.SIZE_SMALL);
  60. item.setDrawAxis(true);
  61. item.setPreferredSize(width,height);//设置chart控件的大小
  62. item.setMargins(5,3,10,15);
  63. if(imagefile.length()>0)//需要使用背景时
  64. {
  65. try{
  66. javax.microedition.lcdui.Imageimg=javax.microedition.lcdui.Image.createImage(imagefile);//读取背景图
  67. item.setBackgroundImage(img);//设置背景图
  68. }catch(Exceptionex){ex.printStackTrace();}
  69. }
  70. item.showShadow(true);//使用阴影特效
  71. item.setShadowColor(20,20,20);//设置阴影颜色
  72. item.setColor(40,40,200);
  73. item.resetData();
  74. for(inti=0;i<color.length;i++)//循环线条
  75. {
  76. item.addElement(String.valueOf((char)('a'+i)),percent[i],color[i][0],color[i][1],color[i][2]);
  77. }
  78. item.setMaxValue(100);//柱体代表数值的显示范围,100%
  79. //这个是lcdui的Image
  80. javax.microedition.lcdui.Imagelcdui_img=
  81. javax.microedition.lcdui.Image.createImage(width,height);//线形图大小,图像>控件
  82. //这个是lcdui的Graphics
  83. javax.microedition.lcdui.Graphicslcdui_g=lcdui_img.getGraphics();
  84. lineChart.drawChart(lcdui_g,width-40,height-20);//这里设置的大小必须比width,height小,才能完全显示
  85. returnUIDemoMIDlet.lcdui2lwuit(lcdui_img);
  86. }
  87. publicvoidactionPerformed(ActionEventarg0){
  88. if(arg0.getCommand()==backCommand)
  89. {
  90. UIDemoMIDlet.backToMainMenu();
  91. }
  92. }
  93. }

相关文章:

  • qt怎么添加html样式,Qt中插入html样式
  • LWUIT + ChartComponent 之三实现柱体图(HBarChar)
  • 辽宁省交通高等专科学校云计算机,辽宁省交通高等专科学校教务管理系统入口http://202.199.184.12/jwc/...
  • 诫子书
  • 怎么用计算机删除历史记录,win7计算机里搜索历史记录怎么删除
  • 谷歌跌出08年美国最值得信赖20大公司排行榜
  • 计算机课翻译成英语怎么说,计算机专业课程名英文翻译.doc
  • html文件怎么迭代,迭代多个文件并使用Beautiful Soup从HTML附加文本
  • Google Pack软件包中火狐浏览器被Chrome取代
  • 从指定网址读取html文件,获取指定网址下的html页面中的图片文件
  • 买战斗机,去淘宝!
  • 熊猫如何设置html5,熊猫:如何将多个数据帧作为HTML表格引用和打印
  • 字符编码简介:ASCII,Unicode,UTF-8,GB2312
  • 计算机和用户交互的界面是显示器吗,CPU如何与显示器交互?
  • 计算机学院心理节活动主题,【阳光心理 放飞梦想】​计算机与信息工程系举办心理健康月系列活动...
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • 【347天】每日项目总结系列085(2018.01.18)
  • Apache的基本使用
  • CODING 缺陷管理功能正式开始公测
  • CSS实用技巧
  • flutter的key在widget list的作用以及必要性
  • GDB 调试 Mysql 实战(三)优先队列排序算法中的行记录长度统计是怎么来的(上)...
  • Git初体验
  • JavaScript HTML DOM
  • java中具有继承关系的类及其对象初始化顺序
  • JDK 6和JDK 7中的substring()方法
  • JS数组方法汇总
  • js写一个简单的选项卡
  • PhantomJS 安装
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • Vue UI框架库开发介绍
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 浮动相关
  • 码农张的Bug人生 - 初来乍到
  • 手写一个CommonJS打包工具(一)
  • 吐槽Javascript系列二:数组中的splice和slice方法
  • media数据库操作,可以进行增删改查,实现回收站,隐私照片功能 SharedPreferences存储地址:
  • Java性能优化之JVM GC(垃圾回收机制)
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • #图像处理
  • %@ page import=%的用法
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (附源码)ssm高校运动会管理系统 毕业设计 020419
  • (三)c52学习之旅-点亮LED灯
  • (转)Linux NTP配置详解 (Network Time Protocol)
  • (转)为C# Windows服务添加安装程序
  • ***监测系统的构建(chkrootkit )
  • .htaccess配置常用技巧
  • .Net Attribute详解(上)-Attribute本质以及一个简单示例
  • .net core webapi 部署iis_一键部署VS插件:让.NET开发者更幸福
  • .NET MVC、 WebAPI、 WebService【ws】、NVVM、WCF、Remoting
  • .NET Remoting学习笔记(三)信道
  • .net 使用ajax控件后如何调用前端脚本
  • .NET 中创建支持集合初始化器的类型
  • .NET的数据绑定