Latest News

Sunday 22 November 2009

GWT Visualization Example - Annotated Time Line Chart Tutorial

If you are a server-side Java developer such as myself, I am sure you want an easy way to create AJAX based application but pure JavaScript (ECMAScript) is not your strong skills. The beauty of JavaScript is that it runs on any web server, no need for a servlet container or anything of that sort.

So, I have been writing AJAX based UI using the GWT framework for the past year and half. I am still not a web developer but I understand enough CSS to spice up my site. Anyway, I am writing this tutorial because I think that the GWT Visualization team, even tough they did a good job, over complicates the creation of charts in their tutorial. I was trying to create an Annotated Time Line chart so I looked up my previous code I wrote for the GWT Portlet JSR-168, see here. I also decided to run a search (don't be evil, Google is your friend) to try to find different examples and hopefully some nice custom charts. First of all, based on the search result; I thought that some of examples, including Google's own, were confusing and over complex. Most examples uses AJAXLoader to load the Visualization API, but you shouldn't have to use this. This is the simplest way to create a GWT Annotated Time Line Chart.

gwt annotated time line chart

1. Using your favorite development tool with support for GWT framework, create a new Java web application, you can export the compiled JavaScript later to a non-based web application, if you use an IDEW you should code-completion support.

2. Make you sure you have included the GWT Visualization API module in your classpath.

3. In your project source code root directory, you should <AppNamexxxx>.gwt.xml file. make sure to add teh following line to it in order to make the  module available to your application.

<inherits name="com.google.gwt.visualization.Visualization"/>

4. In order to keep this tutorial short and straight to point, I have included the chart creation code in my <AppNamexxxx>EntryPoint.java class






public class MainEntryPoint implements EntryPoint
{
    
    
    /**
    * Creates a new instance of MainEntryPoint
    */
    public MainEntryPoint()
    {
        
        
    }
    
    
    
    /**
    * The entry point method, called automatically by loading a module
    * that declares an implementing class as an entry-point
    */
    public void onModuleLoad()
    {
        
        Runnable onLoadCallback = new Runnable()
        {
            
            
            public void run()
            {
                
                DataTable data = createHistoryTable(result);
                AnnotatedTimeLine.Options options = AnnotatedTimeLine.Options.create();
                options.setDisplayAnnotations(true);
                options.setDisplayZoomButtons(true);
                options.setScaleType(AnnotatedTimeLine.ScaleType.ALLFIXED);
                options.setLegendPosition(AnnotatedTimeLine.AnnotatedLegendPosition.SAME_ROW);
                AnnotatedTimeLine atl = new AnnotatedTimeLine(data, options, "600px", "200px");
                RootPanel.get().add(atl);
                
            }
            
            
            
        }      
        ;
        VisualizationUtils.loadVisualizationApi(onLoadCallback, AnnotatedTimeLine.PACKAGE);
        
    }
    
    
    
    // This method will create the Data used by the chart
    private DataTable createHistoryTable()
    {
        
        DataTable data = DataTable.create();
        data.addColumn(AbstractDataTable.ColumnType.DATE, "Date");
        data.addColumn(AbstractDataTable.ColumnType.NUMBER, "Price");
        data.addColumn(AbstractDataTable.ColumnType.NUMBER, "Low");
        data.addColumn(AbstractDataTable.ColumnType.NUMBER, "High");
        data.addRows(5);
                  
            DateTimeFormat dtf = DateTimeFormat.getFormat("yyyy-MM-dd");
            data.setValue(0, 0, dtf.parse("2009-11-21"));
            data.setValue(0, 1, 100);
            data.setValue(0, 2, 120);
            data.setValue(0, 3, 90);


            data.setValue(1, 0, dtf.parse("2009-11-22"));
            data.setValue(1, 1, 90);
            data.setValue(1, 2, 110);
            data.setValue(1, 3, 100);



            data.setValue(2, 0, dtf.parse("2009-11-23"));
            data.setValue(2, 1, 100);
            data.setValue(2, 2, 180);
            data.setValue(2, 3, 80);



            data.setValue(3, 0, dtf.parse("2009-11-20"));
            data.setValue(3, 1, 130);
            data.setValue(3, 2, 100);
            data.setValue(3, 3, 130);

          

            data.setValue(4, 0, dtf.parse("2009-11-19"));
            data.setValue(4, 1, 130);
            data.setValue(4, 2, 170);
            data.setValue(4, 3, 150);

            
        }
        return data;  
    }  
}


Don't forget to import all the necessary classes and voila!

I hope this will save you some time in creating your charts.



 




  • Blogger Comments
  • Facebook Comments

336 comments :

  1. The Google API Libraries for Google Web Toolkit is a collection of libraries that provide Java language bindings for popular Google JavaScript APIs. These libraries make it quick and easy for developers to use these Google JavaScript APIs with Google Web Toolkit. The libraries are supported by the Google Web Toolkit team.

    vitamin e

    ReplyDelete
  2. first of all, your code isn't working. theres a superfluid bracket and the dates aren't correct. second, it's absolutely unreadable.

    ReplyDelete
  3. This is a great blog post. Thank you very much for the fantastic insight and we really appreciate the time you took to write this. Thanks again.
    House Buyer San Antonio

    ReplyDelete
  4. The team is attentive and receptive to feedback, fostering collaboration to produce a final product that exceeds expectations
    Bay Area web site design

    ReplyDelete
  5. I am thankful to you for sharing this plethora of useful information. I found this resource utmost beneficial for me. Thanks a lot for hard work.
    คาสิโนออนไลน์UFABET
    เว็บพนันออนไลน์ufacasino
    คาสิโนออนไลน์ที่ดีที่สุด

    ReplyDelete
  6. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles
    เว็บคาสิโนออนไลน์
    เว็บพนันคาสิโนออนไลน์
    คาสิโนออนไลน์ไม่มีขั้นต่ำ

    ReplyDelete
  7. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles
    eBETเดิมพันขั้นต่ำ10บาท
    คาสิโนออนไลน์eBET
    เว็บเดิมพันออนไลน์eBET

    ReplyDelete
  8. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles
    สมัครสมาชิกAE Casino
    ทางเข้าสมัครสมาชิกAE Casino
    วิธีเข้าเล่นAE Casino

    ReplyDelete
  9. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles
    สมัครสมาชิกAE Casino
    ทางเข้าสมัครสมาชิกAE Casino
    วิธีเข้าเล่นAE Casino

    ReplyDelete
  10. I read this article. I think You put a lot of effort to create this article. I appreciate your work. อีเบท . eBETGaming . รีวิวเว็บพนันeBET

    ReplyDelete
  11. I conceive you have noted some very interesting points, regards for the post อีเบท . eBETGaming . รีวิวเว็บพนันeBET

    ReplyDelete
  12. This comment has been removed by the author.

    ReplyDelete
  13. I am thankful to you for sharing this plethora of useful information. I found this resource utmost beneficial for me. Thanks a lot for hard work.
    sa sexy gaming
    SAsexy
    sagamingดีไหม

    ReplyDelete
  14. I went to this website, and I believe that you have a plenty of excellent information, I have saved your site to my bookmarks.
    เกมสล็อตออนไลน์บนมือถือUFABET
    เดิมพันสล็อตออนไลน์

    ReplyDelete
  15. We help them as much as we can. If they need assistance with research, writing, grammar, formatting or proofreading, we provide our assistance to help them build their career. อีเบท. คาสิโนออนไลน์eBET. สมัครeBETCasino

    ReplyDelete
  16. Wohh just what I was looking for, regards for posting. คาสิโนเว็บUFABET

    ReplyDelete
  17. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เสือมังกรออนไลน์

    ReplyDelete
  18. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also แทงเสือมังกรออนไลน์.

    ReplyDelete
  19. Wohh just what I was looking for, regards for posting. Sexy Baccarat

    ReplyDelete
  20. Wohh just what I was looking for, regards for posting. เดิมพันคาสิโนSA .

    ReplyDelete
  21. I conceive you have noted some very interesting points, regards for the post.
    สมัครสมาชิกAE Casino

    ReplyDelete
  22. I conceive you have noted some very interesting points, regards for the post. AE Casinoดีมั้ย?

    ReplyDelete
  23. I will bookmark your site and take the feeds additionally เล่นAE Casinoบนมือถือ

    ReplyDelete
  24. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles
    Venus Casino
    รีวิวเว็บVenus Casino

    ReplyDelete
  25. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles eBETGaming.

    ReplyDelete
  26. We help them as much as we can. If they need assistance with research, writing, grammar, formatting or proofreading, we provide our assistance to help them build their career. รีวิวเว็บพนันeBET.

    ReplyDelete
  27. I conceive you have noted some very interesting points, regards for the post. Venus CasinoCasino

    ReplyDelete
  28. I conceive you have noted some very interesting points, regards for the post. แนะนำเว็บVenus Casino.

    ReplyDelete
  29. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เล่นวีนัสคาสิโนบนมือถือ

    ReplyDelete
  30. I went to this website, and I believe that you have a plenty of excellent information, I have saved your site to my bookmarks. ทางเข้าGold Diamond Gaming.

    ReplyDelete
  31. Photos available on your site even though producing attention rapidly some quantity submits. เว็บแทงบาคาร่าออนไลน์.

    ReplyDelete
  32. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เซ็กซี่บาคาร่า .

    ReplyDelete
  33. I read this article. I think You put a lot of effort to create this article. I appreciate your work. ไพ่เสือมังกร

    ReplyDelete
  34. Photos available on your site even though producing attention rapidly some quantity submits.
    คาสิโน AE Sexy

    ReplyDelete
  35. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also
    เว็บไซต์เล่นยูฟ่าสล็อตออนไลน์บนมือถือ
    UFA SLOT

    ReplyDelete
  36. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative. 138BET. สมัครเว็บพนัน138BET. ทางเข้าเว็บพนัน138BET.

    ReplyDelete
  37. I read this article. I think You put a lot of effort to create this article. I appreciate your work. คาสิโนขั้นต่ำ10บาท

    ReplyDelete
  38. I will bookmark your site and take the feeds additionally
    สมัครสมาชิกSexy Baccarat

    ReplyDelete
  39. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เดิมพันออนไลน์Venus Casino

    ReplyDelete
  40. I read this article. I think You put a lot of effort to create this article. I appreciate your work. คาสิโนออนไลน์บนมือถือ

    ReplyDelete
  41. I went to this website, and I believe that you have a plenty of excellent information, I have saved your site to my bookmarks.
    SA Gamingออนไลน์
    เว็บไซต์SA Gaming

    ReplyDelete
  42. I will bookmark your site and take the feeds additionally.. Sexy gaming .

    ReplyDelete
  43. I read this article. I think You put a lot of effort to create this article. I appreciate your work. SA GAMING

    ReplyDelete
  44. We help them as much as we can. If they need assistance with research, writing, grammar, formatting or proofreading, we provide our assistance to help them build their career.
    เว็บไซต์เล่นยูฟ่าสล็อตออนไลน์บนมือถือ
    เดิมพันสล็อตUFABET

    ReplyDelete
  45. We help them as much as we can. If they need assistance with research, writing, grammar, formatting or proofreading, we provide our assistance to help them build their career. เล่นเสือมังกรบนมือถือ.

    ReplyDelete
  46. I conceive you have noted some very interesting points, regards for the post. เว็บคาสิโนออนไลน์.

    ReplyDelete
  47. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เล่นคาสิโนeBET

    ReplyDelete

  48. I will bookmark your site and take the feeds additionally คาสิโนขั้นต่ำ10บาท .

    ReplyDelete
  49. I conceive you have noted some very interesting points, regards for the post.คาสิโนขั้นต่ำ10บาท

    ReplyDelete
  50. I conceive you have noted some very interesting points, regards for the post. เล่นคาสิโนSA . เดิมพันSA GAME .

    ReplyDelete
  51. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles. sa sexy gaming. SAsexy.

    ReplyDelete
  52. I read this article. I think You put a lot of effort to create this article. I appreciate your work.
    ทางเข้าsagaming .
    สมัครสมาชิกsagaming .

    ReplyDelete
  53. This comment has been removed by the author.

    ReplyDelete
  54. I am thankful to you for sharing this plethora of useful information. I found this resource utmost beneficial for me. Thanks a lot for hard work.
    เดิมพันAEขั้นต่ำ10บาท.
    AE Casinoฝาก-ถอนออโต้.
    AE Casinoเดิมพันไม่มีขั้นต่ำ.

    ReplyDelete
  55. I will bookmark your site and take the feeds additionally. คาสิโนออนไลน์

    ReplyDelete
  56. I went to this website, and I believe that you have a plenty of excellent information, I have saved your site to my bookmarks.
    ทางเข้าเว็บพนัน138BET.
    138BETTHAILAND.
    138BET.

    ReplyDelete
  57. Wohh just what I was looking for, regards for posting. ยูฟ่าเบท . เว็บพนันufabet .

    ReplyDelete
  58. I value the article.Thanks Again. Much obliged. Ufabet.ยูฟ่าเบท

    ReplyDelete
  59. Wohh just what I was looking for, regards for posting. Ufabet . ยูฟ่าเบท .

    ReplyDelete
  60. Photos available on your site even though producing attention rapidly some quantity submits. ยูฟ่าเบท . เว็บพนันufabet

    ReplyDelete
  61. I conceive you have noted some very interesting points, regards for the post. เว็บพนันufabet. เดิมพันออนไลน์ufabet.

    ReplyDelete
  62. I am thankful to you for sharing this plethora of useful information. I found this resource utmost beneficial for me. Thanks a lot for hard work. รีวิวเว็บพนันUFABET

    ReplyDelete
  63. I conceive you have noted some very interesting points, regards for the post. กำถั่ว . Fantan .

    ReplyDelete
  64. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เล่นเกมกำถั่วออนไลน์ รีวิวเว็บเกมกำถั่ว

    ReplyDelete
  65. This comment has been removed by the author.

    ReplyDelete
  66. I will bookmark your site and take the feeds additionally กำถั่ว. Fantan.

    ReplyDelete
  67. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also กำถั่วขั้นต่ำ10บาท. กำถั่วpantip.

    ReplyDelete
  68. We help them as much as we can. If they need assistance with research, writing, grammar, formatting or proofreading, we provide our assistance to help them build their career. UFABET. เว็บคาสิโนยูฟ่าเบท.

    ReplyDelete
  69. I conceive you have noted some very interesting points, regards for the post. สมัครสมาชิคคาสิโนยูฟ่าเบท . เล่นUFA CASINO .

    ReplyDelete
  70. This comment has been removed by the author.

    ReplyDelete
  71. "I read this article. I think You put a lot of effort to create this article. I appreciate your work. ufaslot
    . สล็อตออนไลน์ยูฟ่าเบท . "

    ReplyDelete
  72. I went to this website, and I believe that you have a plenty of excellent information, I have saved your site to my bookmarks. UFA SLOT. ยูฟ่าสล็อต.

    ReplyDelete
  73. I am thankful to you for sharing this plethora of useful information. I found this resource utmost beneficial for me. Thanks a lot for hard work. ufaslot . สล็อตออนไลน์ยูฟ่าเบท

    ReplyDelete
  74. I unquestionably esteeming each and every piece of it and I have you bookmarked to look at new แทงบอลออนไลน์UFABET

    ReplyDelete
  75. Photos available on your site even though producing attention rapidly some quantity submits. เล่นรูเล็ตออนไลน์ . เล่นรูเล็ต

    ReplyDelete
  76. I value the article.Thanks Again. Much obliged. 1XBET.

    ReplyDelete
  77. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles. แนะนำเว็บแทงบอล.

    ReplyDelete
  78. I conceive you have noted some very interesting points, regards for the post. เกมยิงปลาออนไลน์ . เล่นเกมยิงปลา

    ReplyDelete
  79. I read this article. I think You put a lot of effort to create this article. I appreciate your work. เดิมพันคาสิโนยูฟ่าเบท คาสิโนยูฟ่าเบท2021

    ReplyDelete
  80. I conceive you have noted some very interesting points, regards for the post. Joker Gaming .

    ReplyDelete
  81. I read this article. I think You put a lot of effort to create this article. I appreciate your work. ทางเข้ายูฟ่าเบท

    ReplyDelete
  82. I value the article.Thanks Again. Much obliged. https://ufatips.wiki/

    ReplyDelete
  83. I conceive you have noted some very interesting points, regards for the post. แทงบอลUFABET

    ReplyDelete
  84. Photos available on your site even though producing attention rapidly some quantity submits. เกมคาสิโนสด1XBET.

    ReplyDelete
  85. I value the article.Thanks Again. Much obliged. Sexy gaming

    ReplyDelete
  86. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also Sexy Baccarat

    ReplyDelete
  87. I conceive you have noted some very interesting points, regards for the post. คาสิโนออนไลน์ยูฟ่าเบท

    ReplyDelete
  88. I will bookmark your site and take the feeds additionally. UFABET.

    ReplyDelete
  89. I will bookmark your site and take the feeds additionally แทงบอลUFABET

    ReplyDelete
  90. Photos available on your site even though producing attention rapidly some quantity submits. UFABET

    ReplyDelete
  91. I conceive you have noted some very interesting points, regards for the post.
    เล่นKingmakerบนมือถือ

    ReplyDelete
  92. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also Kingmaker

    ReplyDelete
  93. I read this article. I think You put a lot of effort to create this article. I appreciate your work. แทงบอลได้เงินจริง

    ReplyDelete
  94. I am thankful to you for sharing this plethora of useful information. I found this resource utmost beneficial for me. Thanks a lot for hard work. เล่นสล็อตบนมือถือ

    ReplyDelete
  95. I read this article. I think You put a lot of effort to create this article. I appreciate your work. สมัครสมาชิกSexy Baccarat สมัครสมาชิก

    ReplyDelete
  96. I unquestionably esteeming each and every piece of it and I have you bookmarked to look at new stuff you post. สมัครสมาชิกUFABET

    ReplyDelete
  97. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also. บาคาร่าออนไลน์

    ReplyDelete
  98. This is very Amazing and Very Informative Artical we get alot of Informations from this artical we really appreciate your team work keep it up and keep posting such a informative articles. ทางเข้าUFABET

    ReplyDelete
  99. I conceive you have noted some very interesting points, regards for the post. เล่นบาคาร่าขั้นต่ำ10บาท

    ReplyDelete
  100. I will bookmark your site and take the feeds additionally.รีวิวเว็บเล่นบาคาร่า

    ReplyDelete
  101. I conceive you have noted some very interesting points, regards for the post. แทงไฮโลขั้นต่ำ10บาท

    ReplyDelete
  102. We provide best services to all class of clients. PGSLOT GAME

    ReplyDelete
  103. I unquestionably esteeming each and every piece of it and I have you bookmarked to look at new เล่นเกมรูเล็ตออนไลน์

    ReplyDelete
  104. Wohh just what I was looking for, regards for posting.
    Roulette online

    ReplyDelete
  105. I conceive you have noted some very interesting points, regards for the post . Joker Gaming

    ReplyDelete
  106. I read this article. I think You put a lot of effort to create this article. I appreciate your work.
    Spade gaming Slot Online

    ReplyDelete
  107. Photos available on your site even though producing attention rapidly some quantity submits.
    เว็บแทงหวย

    ReplyDelete
  108. We provide best services to all class of clients. แทงบอลเต็งUFABET

    ReplyDelete
  109. I read this article. I think You put a lot of effort to create this article. I appreciate your work.
    แทงไฮโลเว็บไหนดี

    ReplyDelete
  110. I will bookmark your site and take the feeds additionally.แทงไฮโลเว็บไหนดี

    ReplyDelete
  111. We provide best services to all class of clients.
    สมัครUFABET

    ReplyDelete
  112. Wohh just what I was looking for, regards for posting.
    ไพ่เสือมังกร

    ReplyDelete
  113. Photos available on your site even though producing attention rapidly some quantity submits. สมัครเล่นยูฟ่าเบทบนมือถือ

    ReplyDelete
  114. I conceive you have noted some very interesting points, regards for the post. สมัครสมาชิกufabet

    ReplyDelete
  115. Photos available on your site even though producing attention rapidly some quantity submits.ไฮโลออนไลน์

    ReplyDelete

Item Reviewed: GWT Visualization Example - Annotated Time Line Chart Tutorial Description: Rating: 5 Reviewed By: Unknown
Scroll to Top