擷取總銷售量
在多數情況下,銷售列表中會有很多個記錄,所以訪問資料庫的快捷性和高效性顯得非常重要。現在我們只需要訪問資料庫中每一種產品的總額銷售量。
表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); |