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

334 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. 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
  15. Wohh just what I was looking for, regards for posting. คาสิโนเว็บUFABET

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

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

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

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

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

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

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

    ReplyDelete
  23. 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
  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 eBETGaming.

    ReplyDelete
  25. 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
  26. I conceive you have noted some very interesting points, regards for the post. Venus CasinoCasino

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

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

    ReplyDelete
  29. 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
  30. Photos available on your site even though producing attention rapidly some quantity submits. เว็บแทงบาคาร่าออนไลน์.

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

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

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

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

    ReplyDelete
  35. 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
  36. I read this article. I think You put a lot of effort to create this article. I appreciate your work. คาสิโนขั้นต่ำ10บาท

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

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

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

    ReplyDelete
  40. 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
  41. I will bookmark your site and take the feeds additionally.. Sexy gaming .

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

    ReplyDelete
  43. 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
  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. เล่นเสือมังกรบนมือถือ.

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

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

    ReplyDelete

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

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

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

    ReplyDelete
  50. 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
  51. I read this article. I think You put a lot of effort to create this article. I appreciate your work.
    ทางเข้าsagaming .
    สมัครสมาชิกsagaming .

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

    ReplyDelete
  53. 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
  54. I will bookmark your site and take the feeds additionally. คาสิโนออนไลน์

    ReplyDelete
  55. 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
  56. Wohh just what I was looking for, regards for posting. ยูฟ่าเบท . เว็บพนันufabet .

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

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

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

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

    ReplyDelete
  61. 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
  62. I conceive you have noted some very interesting points, regards for the post. กำถั่ว . Fantan .

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

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

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

    ReplyDelete
  66. 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
  67. I conceive you have noted some very interesting points, regards for the post. สมัครสมาชิคคาสิโนยูฟ่าเบท . เล่นUFA CASINO .

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

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

    ReplyDelete
  70. 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
  71. 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
  72. I unquestionably esteeming each and every piece of it and I have you bookmarked to look at new แทงบอลออนไลน์UFABET

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

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

    ReplyDelete
  75. 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
  76. I conceive you have noted some very interesting points, regards for the post. เกมยิงปลาออนไลน์ . เล่นเกมยิงปลา

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    ReplyDelete
  92. 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
  93. I read this article. I think You put a lot of effort to create this article. I appreciate your work. สมัครสมาชิกSexy Baccarat สมัครสมาชิก

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

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

    ReplyDelete
  96. 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
  97. I conceive you have noted some very interesting points, regards for the post. เล่นบาคาร่าขั้นต่ำ10บาท

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

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

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

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

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

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

    ReplyDelete
  104. 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
  105. Photos available on your site even though producing attention rapidly some quantity submits.
    เว็บแทงหวย

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

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

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

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

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

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

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

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

    ReplyDelete
  114. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also. สล็อตออนไลน์ขั้นต่ำ1บาท

    ReplyDelete
  115. This is a great web site, Good sparkling user interface and, very informative blogs. thanks. You may check our website also.เว็บUFACASINO

    ReplyDelete

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