在JSP頁面中輕鬆實現資料餅圖2

來源:互聯網
上載者:User
擷取總銷售量

  在多數情況下,銷售列表中會有很多個記錄,所以訪問資料庫的快捷性和高效性顯得非常重要。現在我們只需要訪問資料庫中每一種產品的總額銷售量。
  表C中的getSales()方法與資料庫連接並返回一個數組,這個數組包含每一種產品的總額出售量。

  Listing C

////////////////////////////////////////////////////////////
//Get the sales totals from the database
////////////////////////////////////////////////////////////
public float[] getSales(int products)
{
 float[] arr = new float[products];
 Connection con;
 Statement stmt;
 ResultSet rs;
 int count = 0;
 String sql = "select productID, amount from p_sales";
 try
 {
  //Load Driver:
  Class.forName(driver);
  //Connect to the database with the url
  con = DriverManager.getConnection(dburl , dbuid , dbpwd);
  stmt = con.createStatement();
  //Get ResultSet
  rs = stmt.executeQuery(sql);
  while(rs.next())
  {
   int product = rs.getInt("productID");
   //Check that the productID is valid
   if (product >= 0 && product < products)
   {
    //Add to product total
    arr[product] += rs.getFloat("amount");
    count++;
   }
     }
  stmt.close();
  con.close();
 }
 catch (java.lang.Exception ex)
 {
  arr[0] = -1.0f;
 }
 return arr;
}

  當getSales()遍曆所有的記錄後,它只儲存的是每一種產品新的出售量:

int product = rs.getInt("productID");
arr[product] += rs.getFloat("amount");

  pieColor對象

  餅狀圖形上的每一種產品應該以不同的顏色顯示。為了達到這一目的,我們建立一個pieColor對象(如表D)所示,這一對象包含有關顏色的數組:

Color pieColorArray[] = {new Color(210,60,60), new Color(60,210,60)…}

  pieColor類定義了一個setNewColor()的方法,這一方法能夠使curPieColor和索引遞增,同時它可以檢查索引不要超過邊界範圍,即採用的方法是:如果curPieColor過大即賦0值。

  更有效是,setNewColor()迴圈每一種顏色後,並在第一種顏色下執行以下的代碼:

curPieColor++;
if(curPieColor >= pieColorArray.length)
{curPieColor = 0;}

  RenderingHints和antialiasing類

  java.awt.RenderingHints類定義了很多方法以顯示二維圖形,包括alpha_interpolation, 抖動,以及antialiasing方法。RenderingHints有助於決定圖形如何顯示以及圖形如何達到最佳處理。

  為了能以平滑顯示,可以使用antialiasing方法來處理餅狀圖形。Antialiasing是一種圖形的平滑處理方法。其演算法是選擇一個特殊象素的顏色值並取代交叉處的象素,從而能夠使線條交叉處得到平滑化。

  圖A說明了antialiasing方法的效果。可以看出使用antialiasing方法的餅狀圖形的線條交叉處變得很平滑。


圖A

  同時,還可以建立一個RenderingHints對象,並傳遞到Graphics2D setRenderingHints()方法,如下所示:

RenderingHints renderHints = new RenderingHints(RenderingHints.KEY_ANTIALIASING,
RenderingHints.VALUE_ANTIALIAS_ON);
g2d.setRenderingHints(renderHints);
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.