<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 32,  comments - 3,  trackbacks - 0
      2010年7月20日

    發現現在幾乎所有的網站都對url中的漢字和特殊的字符,進行了urlencode操作,也就是:

    http://hi.baidu.com/%BE%B2%D0%C4%C0%CF%C8%CB/creat/blog/

    這個樣子,中間%形式的,肯定就是我的登錄用戶名稱了吧。

    為什么對這些字符進行了u的編碼形式,是為了字符編碼(gbk、utf8)還是為了不出現特殊的字符在url中?都知道要轉,但是轉了的真正好處呢。查看了網上的很多資料,也沒有找到更加準確的說法。

    url轉義其實也只是為了符合url的規范而已。因為在標準的url規范中中文和很多的字符是不允許出現在url中的。

    看一下php的urlencode的說明了。

    urlencode — 編碼 URL 字符串

    string urlencode ( string $str )

    返回字符串,此字符串中除了 -_. 之外的所有非字母數字字符都將被替換成百分號(%)后跟兩位十六進制數,空格則編碼為加號(+)。此編碼與 WWW 表單 POST 數據的編碼方式是一樣的,同時與 application/x-www-form-urlencoded 的媒體類型編碼方式一樣。由于歷史原因,此編碼在將空格編碼為加號(+)方面與 RFC1738 編碼(參見 rawurlencode())不同。此函數便于將字符串編碼并將其用于 URL 的請求部分,同時它還便于將變量傳遞給下一頁。

    標準的英文說明是:

    "...Only alphanumerics [0-9a-zA-Z], the special characters "$-_.+!*'()," [not including the quotes - ed], and reserved characters used for their reserved purposes may be used unencoded within a URL."

    那哪些字符是需要轉化的呢?

    1. ASCII 的控制字符

    這些字符都是不可打印的,自然需要進行轉化。

    2. 一些非ASCII字符

    這些字符自然是非法的字符范圍。轉化也是理所當然的了。

    3. 一些保留字符

    很明顯最常見的就是“&”了,這個如果出現在url中了,那你認為是url中的一個字符呢,還是特殊的參數分割用的呢?

    4. 就是一些不安全的字符了。

    例如:空格。為了防止引起歧義,需要被轉化為“+”。

    明白了這些,也就知道了為什么需要轉化了,而轉化的規則也是很簡單的。

    按照每個字符對應的字符編碼,不是符合我們范圍的,統統的轉化為%的形式也就是了。自然也是16進制的形式。

    和字符編碼無關

    通過urlencode的轉化規則和目的,我們也很容易的看出,urleocode是基于字符編碼的。同樣的一個漢字,不同的編碼類型,肯定對應不同的urleocode的串。gbk編碼的有gbk的encode結果。

    apache等服務器,接受到字符串后,可以進行decode,但是還是無法解決編碼的問題。編碼問題,還是需要靠約定或者字符編碼的判斷解決。

    因此,urleocode只是為了url中一些非ascii字符,可以正確無誤的被傳輸,至于使用哪種編碼,就不是eocode所關心和解決的問題了。

    編碼問題,不是urlencode所要解決的。
    轉自:http://apps.hi.baidu.com/share/detail/32230450

    參考資料:

    http://www.blooberry.com/indexdot/html/topics/urlencoding.htm

    http://cn.php.net/manual/zh/function.urlencode.php

     

     

     

    posted @ 2011-08-10 13:16 donghang73 閱讀(10423) | 評論 (0)編輯 收藏

    在文件夾選項里改了驅動器或文件夾的圖標,發現雙擊打開硬盤變成了搜索

    解決方法:

    運行
    regsvr32 /i shell32.dll

    解決!

    posted @ 2011-08-05 10:27 donghang73 閱讀(242) | 評論 (0)編輯 收藏
    //首先在HEAD區加入要引用的JS
    <head>
    <script type="text/javascript" src="FCKEditor/fckeditor.js"></script> 
    <script type="text/javascript" language="javascript">
    function check()
    {
       // 取得FCKEditor的值,GetInstance(arg),這里的參數arg是FCKeditor實例名;
       //如聲明FCKeditor用var oFCKeditor = new FCKeditor('FCKEditor1',500,200,'Board'),則此時arg就是FCKEditor1;
            var checkContent1 =FCKeditorAPI.GetInstance("FCKEditor1").GetXHTML();
            if (checkContent1 == "")
            {
               strErr += '評論內容不能為空!\n\n';
        alert(strErr);
            }
    }
    </script>
    </head>
    <%-- 把這段寫在需要顯示FCKEditor編輯框的地方 --%>
    <div class="FCKeditor">
    <script type="text/javascript">
        var sBasePath = "FCKEditor/";
        var oFCKeditor = new FCKeditor('FCKEditor1',500,200,'Board'); //實例名為FCKEditor1
        oFCKeditor.BasePath = sBasePath ;
        oFCKeditor.Create() ;
    </script>
    </div>
    <%-- 用于提交內容的按鈕,響應點擊事件為 check() --%>
    <input id="Button1" value="button" type="button" onclick="check()" />
    轉自:http://hi.baidu.com/myaspdotnet/blog/item/0b73cd3f0ab9f3c77c1e714a.html
    posted @ 2011-05-27 22:21 donghang73 閱讀(229) | 評論 (0)編輯 收藏

    Google code 獲取密碼頁打不開的解決辦法

    # Project members authenticate over HTTPS to allow committing changes. 
    svn checkout https://yourprj.googlecode.com/svn/trunk/ yourprj --username youraccount

    When prompted, enter your generated googlecode.com password.

     

    在文件 C:\Windows\System32\drivers\etc\hosts 中加入 66.249.89.99 code.google.com

    posted @ 2011-04-17 17:25 donghang73 閱讀(1413) | 評論 (0)編輯 收藏

    1. 進入http://code.google.com/ 用Google帳戶登錄(推薦使用gmail郵箱)。然后點擊>Project Hosting
    2. 進入>> http://code.google.com/hosting/ 然后點擊>Create a new project
    3. 填入信息:
          寫入項目名,描述,兩個選擇項(不太明白啥意思)選第一個就好使,寫入標簽,點擊確定。就可以了
    4. 提交成功后,選擇菜單的Source(其中有https上傳協議路徑需要拷貝一份,還有一個上傳密碼)。
    5. 打開MyEclipse,打開需要上傳的項目,點鼠標右鍵->team->share Project->svn,寫入https路徑,下一步,輸入Google賬號和上傳密碼,起個名,finish。
    6.如果一切順利,會自動生成一個項目目錄,可以查看所有項目文件。然后進入搭建項目界面,點鼠標右鍵->team->commit。然后開始上傳項目。
    7.哦了,搭建完成。
    8.如果想查看自己的項目,可以用瀏覽器登陸https的路徑,輸入Google賬號和上傳密碼,如果成功就可以看到含有項目名稱的目錄。

    PS:
    需要注意的是,Google的SVN是強制開源的哦,如果不想開源又沒服務器的朋友開源選擇svnhost
    再PS:
    http地址是自讀權限的,供游客下載代碼,https是我們更新代碼的時候使用的

    轉自:http://hi.baidu.com/%C0%AF%B1%CA%B9%A4%D7%F7%CA%D2/blog/item/d6f6c6d7707d81d0a044df5f.html

    posted @ 2011-04-17 17:12 donghang73 閱讀(14578) | 評論 (2)編輯 收藏

    <property name="hibernate.hbm2ddl.auto" value="update" />

    Hibernate Reference Documentation解釋如下:
    hibernate.hbm2ddl.auto Automatically validate or export schema DDL to the database when the SessionFactory is created. With create-drop, the database schema will be dropped when the SessionFactory is closed explicitly.  eg. validate | update | create | create-drop

    這個參數的作用主要用于:自動創建|更新|驗證數據庫表結構。
    如果沒有此方面的需求建議不設置此屬性,默認是不對數據庫結構作任何改變

    其它幾個參數的意思:
    validate     
    每次加載hibernate時,驗證創建數據庫表結構,只會和數據庫中的表進行比較,不會創建新表,但是會插入新值。

    create
    每次加載hibernate時都會刪除上一次的生成的表,然后根據你的model類再重新來生成新表,哪怕兩次沒有任何改變也要這樣執行,這就是導致數據庫表數據丟失的一個重要原因。

    create-drop
    每次加載hibernate時根據model類生成表,但是sessionFactory一關閉,表就自動刪除。

    update
    最常用的屬性,第一次加載hibernate時根據model類會自動建立起表的結構(前提是先建立好數據庫),以后加載hibernate時根據 model類自動更新表結構,即使表結構改變了但表中的行仍然存在不會刪除以前的行。要注意的是當部署到服務器后,表結構是不會被馬上建立起來的,是要等 應用第一次運行起來后才會。

    posted @ 2011-04-17 16:53 donghang73 閱讀(560) | 評論 (0)編輯 收藏
         摘要: Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --> 1 <?xml version="1.0" encoding="ISO-8859-1"?>    2&nb...  閱讀全文
    posted @ 2011-04-16 17:18 donghang73 閱讀(2749) | 評論 (0)編輯 收藏

    Java中使用的路徑,分為兩種:絕對路徑和相對路徑。歸根結底,Java本質上只能使用絕對路徑來尋找資源。所有的相對路徑尋找資源的方法,都不過是一些便利方法。不過是API在底層幫助我們構建了絕對路徑,從而找到資源的!

    在開發Web方面的應用時, 經常需要獲取 服務器中當前WebRoot的物理路徑。

    如果是Servlet , Action , Controller, 或則Filter , Listener , 攔截器等相關類時, 我們只需要獲得ServletContext, 然后通過ServletContext.getRealPath("/")來獲取當前應用在服務器上的物理地址。

    如果在類中取不到ServletContext時, 有兩種方式可以做到:

    1. 利用Java的類加載機制 調用 XXX.class.getClassLoader().getResource(""); 方法來獲取到ClassPath , 然后處理獲得WebRoot目錄,這種方式只能是該class在WebRoot/WEB-INF/classes下才能生效, 如果該class被打包到一個jar文件中, 則該方法失效。這時就應該用下面一種方式。

    2. spring框架的思路, 在WEB-INF/web.xml中 , 創建一個webAppRootKey的param, 指定一個值(默認為webapp.root)作為鍵值, 然后通過Listener , 或者Filter , 或者Servlet 執行String webAppRootKey = getServletContext().getRealPath("/"); 并將webAppRootKey對應的webapp.root 分別作為Key , Value寫到System Properties系統屬性中。之后在程序中通過System.getProperty("webapp.root")來獲得WebRoot的物理路 徑。

    根據第二種的思路,我們還可以再擴展一下。不過對于在部署在一臺服務器中的應用來說,若還不是你所需請再往下看。

    下面是一些得到classpath和當前類的絕對路徑的一些方法。你可使用其中的一些方法來得到你需要的資源的絕對路徑:

    1. DebitNoteAction.class.getResource("")

    得到的是當前類FileTest.class文件的URI目錄。不包括自己!

    如:file:/D:/eclipse/springTest/WebRoot/WEB-INF/classes/

    atacarnet/src/com/evi/modules/atacarnet/action/

    2. DebitNoteAction.class.getResource("/")

    得到的是當前的classpath的絕對URI路徑。

    如:file:/D:/eclipse/springTest/WebRoot/WEB-INF/classes/

    3. Thread.currentThread().getContextClassLoader().getResource("")

    得到的也是當前ClassPath的絕對URI路徑

    如:file:/D:/eclipse/springTest/WebRoot/WEB-INF/classes/

    4. DebitNoteAction.class.getClassLoader().getResource("") 或ClassLoader.getSystemResource("")

    得到的也是當前ClassPath的絕對URI路徑。

    如:file:/D:/eclipse/springTest/WebRoot/WEB-INF/classes/

    5. 取得服務器相對路徑

    System.getProperty("user.dir")

    例如:E:\apache-tomcat-5.5.16\apache-tomcat-5.5.16\bin

    我推薦使用Thread.currentThread().getContextClassLoader().getResource("")來得到當前的classpath的絕對路徑的URI表示法

    6. 取得項目中的絕對路徑

    一般用request.getRealPath("/")或request.getRealPath("/config/")

    但現在不提倡使用request.getRealPath("/")了,大家可試用ServletContext.getRealPath("/")方法得到Web應用程序的根目錄的絕對路徑

    要取得src的文件非常容易,因為src是默認的相對目錄,比如你說要取得src下com目錄的test.java文件,你只需要這樣就夠了

    File f = new File(com/test.java);

    但如果我要取得不在src目錄或者WebRoot目錄下的文件呢,而是要從src或者WebRoot同級的目錄中取呢,比如說doc吧

    我的硬方法是這樣實現的:

    String path = this.getServletContext().getRealPath("/");

    Properties p = new Properties();

    p.load(new FileInputStream(new File(path.substring(0,(path.lastIndexOf("\\WebRoot ") + 1)) + "doc/db.properties")));

    System.out.println(p.getProperty("driverName"));

    轉自:http://blog.csdn.net/c5153000/archive/2011/03/23/6272195.aspx

    posted @ 2011-04-15 17:25 donghang73 閱讀(822) | 評論 (0)編輯 收藏
    啥也不說了,看圖吧
    posted @ 2011-03-02 16:12 donghang73 閱讀(385) | 評論 (0)編輯 收藏
     

        有很多時候,我們刪除文件,系統會提示找不到指定的文件。但是你可以看到文件在硬盤里面,這個問題需要怎么解決呢?一般情況下,我們可以使用軟件解決。不過推薦使用DOS命令,找不到指定文件通常使用一下方法解決。
      1、新建一個文本文檔,寫入(直接復制粘貼)下列命令:
      DEL /F /A /Q \\?\%1  
          RD /S /Q \\?\%1
      
       
    2、另存為:刪除OK.bat
      3、建好后,把要刪除的文件或者目錄直接拖放到這個bat文件圖標上就可以刪除了,一切OK!
      ------------------------------------------------------------------------------------------------

      在說另種方法,提供刪除方法(以刪除c "xxxxxx..."文件夾為例),在執行刪除動作時,提示文件夾無法刪除,找不到指定路徑
      解決方法:由于該文件夾真正的名稱為"xxxxxx..."" 所以我們就必須寫對文件名.
      操作:開始運行輸入“cmd”回車——輸入“C: ”回車輸入 RMDIR    空格 C:"xxxxxx..."    空格 /S 空格 /Q    回車即可刪除。
      注意:需要刪除其他類似文件,把盤符和xxxxxx...改為你電腦里面的盤符和文件名即可!
      或新建記事本,在記事本寫入:RMDIR 空格文件夾" /S /Q    保存(保存前把文件夾改為你要刪除文件夾的名稱)退出把記事本的后綴名改成“bat”(如:新建文本文檔.txt   改成新文本文檔 .bat)然后剪切到你要刪除文件夾所在的目錄,最后點擊你粘貼過來的文件-->運行就OK
          ==================================================

    posted @ 2011-03-02 15:57 donghang73 閱讀(453) | 評論 (0)編輯 收藏
    一、windows中虛擬Linux

    1.Linux安裝增強功能

    2.VirtualBox 分配數據空間

    3.Linux中建共享文件夾掛載的目錄(如mkdir /mnt/share)

    4.linux掛載共 享文件夾(sudo mount –t vboxsf [設置的共享文件夾名稱]  /mnt/share)

    二、Linux中虛擬windows

    1.windows安裝增強功能

    2.VirtualBox分配數據空間

    3.windows 中我的電腦右鍵-映射網絡驅動器-瀏覽-選中分配的共享文件夾

    posted @ 2010-08-09 23:12 donghang73 閱讀(216) | 評論 (0)編輯 收藏
         摘要: 最近用到了JFreeChart,現將實例代碼貼出來,大家可以參考一下,代碼中如有錯誤或可以改進的地方,還請大家指正。 通過下面的代碼,可以很清晰地看出JFreeChart的結構,核心即為chart, plot, XXXAxis, renderer,了解了它們的常用方法后, 會發現其實JFreeChart使用起來是很簡單方便的。廢話不多說了,還是直接看示例吧。   1.柱狀圖 ...  閱讀全文
    posted @ 2010-07-25 22:44 donghang73 閱讀(4477) | 評論 (1)編輯 收藏
    1,apache_2.0.63-win32-x86-no_ssl.msi
    下載:http://apache.mirror.phpchina.com/httpd/binaries/win32/apache_2.0.63-win32-x86-no_ssl.msi
    2,svn-1.4.5-setup.exe
    下載地址:http://subversion.tigris.org/files/documents/15/39559/svn-1.4.5-setup.exe
    當然,你也可以選擇安裝TortoiseSVN.但是我沒有裝,因為我的源碼管理都是用netbeans完成的.

    好了,準備的兩個軟件都下載下來以后,就可以開始安裝了.
    首先安裝apache,一般來說直接點下一步就可以了,在設置domain以及host的時候,設置為localhost就可以了,Email你可以填你自己的Email,也可以隨便填一個.安裝apache要注意的是,你的電腦上80端口不能被占用, 否則你的http服務是啟動不起來的,我就遇到過這事,因為我用了skype,它在本機上打開了80和443端口來監聽,搞得我一開始裝不好,總是啟動不起來,后來才發現是skype占用了80端口,于是把skype的設置改了以后,重裝apache才成功.裝好apache以后,這個時候,它已經在運行了,你可以在瀏覽器的地址欄輸入http://localhost看看,是否安裝成功,如果安裝成功的話,這個時候瀏覽器里面應該是可以看到一個頁面的.
    然后,再安裝svn-1.4.5-setup.exe,也很簡單,一步一步點下步就可以了, 在安裝的過程中,它會默認選中一些選項,其中就有一個是是否對apache的HTTP服務器提供支持的選項,這個默認是勾上的,不要去反選它,其它的你可以反選掉.然后svn就宣布安裝成功了.你可以到CMD下面去試一下svn這個命令,如果有輸出,則說明安裝成功了,如果提示svn 不是內部或外部命令,也不是可運行的程序或批處理文件。那就說明沒有裝好.或者沒有把這個命令加入到path中,所以最好的辦法是到svn的安裝目錄下的 bin里面去看一下.
    兩者都裝好了以后,就開始配置,當然,配置也是最重要的.
    首先要建立一個數據倉庫,我們假設建在E盤,數據倉庫最好不要建在C盤,因為C盤重裝系統以后就格了.我們先在E盤下面建立一個目錄叫svnroot,然后在svnroot下面再建立一個我們專門放我們工程的目錄,比如叫MyProject.于是我們在E盤下面就有了這個一個文件夾:E:\svnroot\MyProject, 然后我們用svnadmin的命令,使這個文件夾變成我們的數據倉庫,命令如下:
    svnadmin create E:\svnroot\MyProject
    如果運行成功的話,什么也沒有輸出,這個時候,我們再來到MyProject文件夾下面,我們會發現多了幾個文件夾和文件,我們打開conf文件夾,然后再打開svnserve.conf文件,找到如下行# password-db = passwd,然后把它前面的#去掉,表示MyProject是需要密碼驗證的.但是我們密碼設在哪里呢,這個時候我們再打開conf文件夾下面的 passwd文件,用文本編輯器打開,在[users]下面加上我們需要啟動的人員的用戶和密碼,比如
    [users]
    hadeslee=hadeslee1234
    tom=123456

    這個的話,我們就啟動了兩個用戶,一個叫hadeslee,密碼是hadeslee1234,一個叫tom,密碼是123456.然后我們保存passwd文件.然后,我們再建一個文件,叫access.auth,這個文件是設置訪問權限的,里面內容如下:
    [MyProject:/]
    hadeslee = rw
    [MyProject:/module1]
    tom=rw
    hadeslee=rw

    這表示,MyProject下面的所有子目錄hadeslee都是有權限讀寫的,但是tom只有權限讀寫此項目下面的module1目錄,這個各自的訪問權限就分的更細致了.有關于MyProject文件夾下面的設置,我們就告一段落了,我們現在開始設置apache,使它能和subvertion一起工作.

    首先來到Subersion的安裝目錄,進入它的bin目錄,我們會發現如下兩個文件:
    mod_authz_svn.so
    mod_dav_svn.so

    我們把這兩個文件復制一下,粘帖到 apache的安裝目錄下的modules文件中,然后我們再打開apache安裝目錄下的conf文件夾,打開httpd.conf文件.增加如下兩行:
    LoadModule dav_svn_module modules/mod_dav_svn.so
    LoadModule authz_svn_module modules/mod_authz_svn.so

    注意,由于dav_svn需要dav_module的支持,所以要確保下面這一行沒有被注釋,并且保證在dav_svn之前加載:
    LoadModule dav_module modules/mod_dav.so
    然后模塊的設置就完成了,下面我們要設置SVN的目錄,以使我們的apache能知道訪問不同的URL的時候,它去哪里尋找這個URL所對應的SVN目錄.
    httpd.conf文件中,增加如下內容:
    <Location /svn/MyProject>
    DAV svn
    SVNPath E:/svnroot/MyProject

    AuthzSVNAccessFile E:/svnroot/MyProject/conf/access.auth
    Satisfy Any
    Require valid-user

    AuthType Basic
    AuthName "Subversion repositories"
    AuthUserFile  E:/svnroot/MyProject/conf/users.auth
    Require valid-user
    </Location>


    添加完上面這些,我們會發現access.auth是我們剛才新建的,可是users.auth我們并沒有新建啊.怎么就把它加進去了.不要急,現在我們就來生成users.auth文件.

    進入 apache的安裝目錄的bin文件夾,輸入如下命令:

    D:\Program Files\Apache Group\Apache2\bin>htpasswd -cb users.auth hadeslee hadeslee1234
    Automatically using MD5 format.
    Adding password for user hadeslee

    D:\Program Files\Apache Group\Apache2\bin>

    我們就會發現在bin目錄生成了users.auth,我們可以看到,hadeslee用戶名已經被添加進去了,密碼是用MD5加密過的.然后我們還要增加用戶呢,可以用如下方法:
    D:\Program Files\Apache Group\Apache2\bin>htpasswd -b users.auth tom 123456
    Automatically using MD5 format.
    Adding password for user tom

    D:\Program Files\Apache Group\Apache2\bin>


    只是在生成密碼的時候,小了一個c的參數,因為c表示重新生成一個這樣的文件,我們第一次的時候是要加的,后面我們要添加用戶的時候,就不用這個c了.然后打開users.auth,會發現兩個用戶都已經在里面了,這個時候,我們把users.auth移到E:/svnroot/MyProject/conf/里面去,使我們上面的設置生效.

    這個時候,我們的設置就完成了.可以在瀏覽器里面輸入http://localhost/svn/MyProject試試看.

    如果以后我們還要加入其它的項目呢,可以有兩點解決方式
    1,把以后的項目也導入到我們的MyProject的倉庫中,這個的話,就不用改什么配置了
    2,新建一個數據倉庫,然后只要按上面的步驟,把新的<Location...>設置放到 httpd.conf里面就可以了.
    當然,驗證文件,訪問權限文件,還有訪問SVN的密碼都要自己按上面的方法再設一遍.

    祝大家能夠設置成功:)

    轉自:http://www.tkk7.com/hadeslee/archive/2008/03/12/185788.html
    posted @ 2010-07-25 22:17 donghang73 閱讀(224) | 評論 (0)編輯 收藏
    1、下載jadclipse插件
    注意:jadclipse_3.1.0.jar版本,該版本支持eclipse3.1M6~3.2M2
          jadclipse_3.2.0.jar版本,該版本支持eclipse3.2M3和eclipse3.2M4.
          jadclipse_3.2.4.jar版本,該版本支持eclipse3.2M5~3.3M5
          jadclipse_3.3.0.jar版本,該版本支持eclipse3.3M6及以上

    2、下載jad.exe,并將下載好的jad.exe拷貝到jre的bin的目錄下,或者把jad的執行文件的絕對路徑加入到環境變量PATH中。

    3、配置jadClipse,在在%ECLIPSE_HOME%\目錄下建立myplugins\jadclipse\eclipse\plugins的目錄結構,將jadclipse_3.3.0.jar(用于Eclipse3.5)放到plugins目錄下面,再在%ECLIPSE_HOME%\links目錄下面建立jadclipse.link的文件(名字可以隨便取),jadclipse.link的內容為:path=..\\jadclipse(注意一定要雙反斜杠"\\")

    4、重新啟動eclipse,查看 window->preferences->java->jadClipse,如果出現jadClipse則說明上述配置成功,否則檢查上述配置。

    5、Path to decomplier:指定反編譯工具的jad文件所在的位置。(可以指定為jre的bin的目錄下的jad.exe)

    6、把*.class文件的associated editors設置為jadClipse Class File Viewer做為默認項


    另:批量反編譯
    在cmd中,進入到class文件所在路徑下,輸入命令:jad -o -r -s java -d src *.class
           參數的含義:
           -o:覆蓋舊文件,而且不用提示確認。
           -r:重新加載生成包結構。
           -s:定義輸出文件的擴展名。jad為默認擴展名,我們反編譯后當然是要.java源文件了。
           -d:輸出文件的目錄。src表示反編譯后的所有文件都放在src目錄下。
           *.class:指定解析該文件夾下的所有以.class結尾的文件,即解析class文件
    posted @ 2010-07-22 22:05 donghang73 閱讀(1023) | 評論 (0)編輯 收藏

    myeclipseUTF-8設置

       如果要使插件開發應用能有更好的國際化支持,能夠最大程度的支持中文輸出,則最好使 Java文件使用UTF-8編碼。然而,Eclipse工作空間(workspace)的缺省字符編碼是操作系統缺省的編碼,簡體中文操作系統 (Windows XPWindows 2000簡體中文)的缺省編碼是GB18030,在此工作空間中建立的工程編碼是GB18030,工程中建立的java文件也是GB18030。如果要使 新建立工程、java文件直接使UTF-8則需要做以下工作:

     

    1windows->Preferences...打開"首選項"對話框,左側導航樹,導航到general->Workspace,右 Text file encoding,選擇Other,改變為UTF-8,以后新建立工程其屬性對話框中的Text file encoding即為UTF-8


    2windows->Preferences...打開"首選項"對話框,左側導航樹,導航到general->Content Types,右側Context Types樹,點開Text,選擇Java Source File,在下面的Default encoding輸入框中輸入UTF-8,點Update,則設置Java文件編碼為UTF-8。其他java應用開發相關的文件 如:propertiesXML等已經由Eclipse缺省指定,分別為ISO8859-1UTF-8,如開發中確需改變編碼格式則可以在此指定。


    3經過上述兩步,新建java文件即為UTF-8編碼,Eclipse編譯、運行、調試都沒問題,但是做RCP應用的Product輸出時、或者插件 輸出時,則總是出錯,要么不能編譯通過(輸出時要重新compile)、要么輸出的插件運行時中文顯示亂碼。此時需要再RCP應用、或插件Plugin 程的build.properties中增加一行,javacDefaultEncoding.. = UTF-8。讓輸出時編譯知道java源文件時UTF-8編碼。這個設置需要保證所有的java源文件時UTF-8編碼格式,如果不全是,可以參考 Eclipse幫中(Plug-in Development Environment Guide > Reference > Feature and Plug-in Build configuration),建議全部java源文件是UTF-8編碼。

       如果插件開發、RCP應用開發原來基于其他編碼,如GB18030,想轉換為UTF-8,則首先,做以上工作;然后通過查找編碼轉換工具,如基于 iconv的批量轉換工具,將原編碼轉換為UTF-8編碼,注意只轉換java源文件,其他類型文件可能已經是比較合適的編碼了;將原工程屬性中的 Text file encoding,從原編碼改為UTF-8即可。

    posted @ 2010-07-20 22:03 donghang73 閱讀(7960) | 評論 (0)編輯 收藏

    JFreeChart類:
    void setAntiAlias(boolean flag)    字體模糊邊界
    void setBackgroundImage(Image image)   背景圖片
    void setBackgroundImageAlignment(int alignment) 背景圖片對齊方式(參數常量在org.jfree.ui.Align類中定義)
    void setBackgroundImageAlpha(float alpha) 背景圖片透明度(0.0~1.0)
    void setBackgroundPaint(Paint paint)   背景色
    void setBorderPaint(Paint paint)   邊界線條顏色
    void setBorderStroke(Stroke stroke)   邊界線條筆觸
    void setBorderVisible(boolean visible)   邊界線條是否可見

    -----------------------------------------------------------------------------------------------------------

    TextTitle類:
    void setFont(Font font)     標題字體
    void setPaint(Paint paint)    標題字體顏色
    void setText(String text)    標題內容

    -----------------------------------------------------------------------------------------------------------

    StandardLegend(Legend)類:
    void setBackgroundPaint(Paint paint)   圖示背景色
    void setTitle(String title)    圖示標題內容
    void setTitleFont(Font font)    圖示標題字體
    void setBoundingBoxArcWidth(int arcWidth) 圖示邊界圓角寬
    void setBoundingBoxArcHeight(int arcHeight) 圖示邊界圓角高
    void setOutlinePaint(Paint paint)   圖示邊界線條顏色
    void setOutlineStroke(Stroke stroke)   圖示邊界線條筆觸
    void setDisplaySeriesLines(boolean flag) 圖示項是否顯示橫線(折線圖有效)
    void setDisplaySeriesShapes(boolean flag) 圖示項是否顯示形狀(折線圖有效)
    void setItemFont(Font font)    圖示項字體
    void setItemPaint(Paint paint)    圖示項字體顏色
    void setAnchor(int anchor)    圖示在圖表中的顯示位置(參數常量在Legend類中定義)

    -----------------------------------------------------------------------------------------------------------

    Axis類:
    void setVisible(boolean flag)    坐標軸是否可見
    void setAxisLinePaint(Paint paint)   坐標軸線條顏色(3D軸無效)
    void setAxisLineStroke(Stroke stroke)   坐標軸線條筆觸(3D軸無效)
    void setAxisLineVisible(boolean visible) 坐標軸線條是否可見(3D軸無效)
    void setFixedDimension(double dimension) (用于復合表中對多坐標軸的設置)
    void setLabel(String label)    坐標軸標題
    void setLabelFont(Font font)    坐標軸標題字體
    void setLabelPaint(Paint paint)    坐標軸標題顏色
    void setLabelAngle(double angle)`   坐標軸標題旋轉角度(縱坐標可以旋轉)
    void setTickLabelFont(Font font)   坐標軸標尺值字體
    void setTickLabelPaint(Paint paint)   坐標軸標尺值顏色
    void setTickLabelsVisible(boolean flag)   坐標軸標尺值是否顯示
    void setTickMarkPaint(Paint paint)   坐標軸標尺顏色
    void setTickMarkStroke(Stroke stroke)   坐標軸標尺筆觸
    void setTickMarksVisible(boolean flag)   坐標軸標尺是否顯示

    ValueAxis(Axis)類:
    void setAutoRange(boolean auto)    自動設置數據軸數據范圍
    void setAutoRangeMinimumSize(double size) 自動設置數據軸數據范圍時數據范圍的最小跨度
    void setAutoTickUnitSelection(boolean flag) 數據軸的數據標簽是否自動確定(默認為true)
    void setFixedAutoRange(double length)   數據軸固定數據范圍(設置100的話就是顯示MAXVALUE到MAXVALUE-100那段數據范圍)
    void setInverted(boolean flag)    數據軸是否反向(默認為false)
    void setLowerMargin(double margin)   數據軸下(左)邊距
    void setUpperMargin(double margin)   數據軸上(右)邊距
    void setLowerBound(double min)    數據軸上的顯示最小值
    void setUpperBound(double max)    數據軸上的顯示最大值
    void setPositiveArrowVisible(boolean visible) 是否顯示正向箭頭(3D軸無效)
    void setNegativeArrowVisible(boolean visible) 是否顯示反向箭頭(3D軸無效)
    void setVerticalTickLabels(boolean flag) 數據軸數據標簽是否旋轉到垂直
    void setStandardTickUnits(TickUnitSource source) 數據軸的數據標簽(可以只顯示整數標簽,需要將AutoTickUnitSelection設false)

    NumberAxis(ValueAxis)類:
    void setAutoRangeIncludesZero(boolean flag) 是否強制在自動選擇的數據范圍中包含0
    void setAutoRangeStickyZero(boolean flag) 是否強制在整個數據軸中包含0,即使0不在數據范圍中
    void setNumberFormatOverride(NumberFormat formatter) 數據軸數據標簽的顯示格式
    void setTickUnit(NumberTickUnit unit)   數據軸的數據標簽(需要將AutoTickUnitSelection設false)

    DateAxis(ValueAxis)類:
    void setMaximumDate(Date maximumDate)   日期軸上的最小日期
    void setMinimumDate(Date minimumDate)   日期軸上的最大日期
    void setRange(Date lower,Date upper)   日期軸范圍
    void setDateFormatOverride(DateFormat formatter) 日期軸日期標簽的顯示格式
    void setTickUnit(DateTickUnit unit)   日期軸的日期標簽(需要將AutoTickUnitSelection設false)
    void setTickMarkPosition(DateTickMarkPosition position) 日期標簽位置(參數常量在org.jfree.chart.axis.DateTickMarkPosition類中定義)

    CategoryAxis(Axis)類:
    void setCategoryMargin(double margin)   分類軸邊距
    void setLowerMargin(double margin)   分類軸下(左)邊距
    void setUpperMargin(double margin)   分類軸上(右)邊距
    void setVerticalCategoryLabels(boolean flag) 分類軸標題是否旋轉到垂直
    void setMaxCategoryLabelWidthRatio(float ratio) 分類軸分類標簽的最大寬度

    -----------------------------------------------------------------------------------------------------------

    Plot類:
    void setBackgroundImage(Image image)   數據區的背景圖片
    void setBackgroundImageAlignment(int alignment) 數據區的背景圖片對齊方式(參數常量在org.jfree.ui.Align類中定義)
    void setBackgroundPaint(Paint paint)   數據區的背景圖片背景色
    void setBackgroundAlpha(float alpha)   數據區的背景透明度(0.0~1.0)
    void setForegroundAlpha(float alpha)   數據區的前景透明度(0.0~1.0)
    void setDataAreaRatio(double ratio)   數據區占整個圖表區的百分比
    void setOutLinePaint(Paint paint)   數據區的邊界線條顏色
    void setOutLineStroke(Stroke stroke)   數據區的邊界線條筆觸
    void setNoDataMessage(String message)   沒有數據時顯示的消息
    void setNoDataMessageFont(Font font)   沒有數據時顯示的消息字體
    void setNoDataMessagePaint(Paint paint)   沒有數據時顯示的消息顏色

    CategoryPlot(Plot)類:
    void setDataset(CategoryDataset dataset) 數據區的2維數據表
    void setColumnRenderingOrder(SortOrder order) 數據分類的排序方式
    void setAxisOffset(Spacer offset)   坐標軸到數據區的間距
    void setOrientation(PlotOrientation orientation) 數據區的方向(PlotOrientation.HORIZONTAL或PlotOrientation.VERTICAL)
    void setDomainAxis(CategoryAxis axis)   數據區的分類軸
    void setDomainAxisLocation(AxisLocation location) 分類軸的位置(參數常量在org.jfree.chart.axis.AxisLocation類中定義)
    void setDomainGridlinesVisible(boolean visible) 分類軸網格是否可見
    void setDomainGridlinePaint(Paint paint) 分類軸網格線條顏色
    void setDomainGridlineStroke(Stroke stroke) 分類軸網格線條筆觸
    void setRangeAxis(ValueAxis axis)   數據區的數據軸
    void setRangeAxisLocation(AxisLocation location) 數據軸的位置(參數常量在org.jfree.chart.axis.AxisLocation類中定義)
    void setRangeGridlinesVisible(boolean visible) 數據軸網格是否可見
    void setRangeGridlinePaint(Paint paint)   數據軸網格線條顏色
    void setRangeGridlineStroke(Stroke stroke) 數據軸網格線條筆觸
    void setRenderer(CategoryItemRenderer renderer) 數據區的表示者(詳見Renderer組)
    void addAnnotation(CategoryAnnotation annotation) 給數據區加一個注釋
    void addRangeMarker(Marker marker,Layer layer) 給數據區加一個數值范圍區域

    PiePlot(Plot)類:
    void setDataset(PieDataset dataset)   數據區的1維數據表
    void setIgnoreNullValues(boolean flag)   忽略無值的分類
    void setCircular(boolean flag)    餅圖是否一定是正圓
    void setStartAngle(double angle)   餅圖的初始角度
    void setDirection(Rotation direction)   餅圖的旋轉方向
    void setExplodePercent(int section,double percent) 抽取的那塊(1維數據表的分類下標)以及抽取出來的距離(0.0~1.0),3D餅圖無效
    void setLabelBackgroundPaint(Paint paint) 分類標簽的底色
    void setLabelFont(Font font)    分類標簽的字體
    void setLabelPaint(Paint paint)    分類標簽的字體顏色
    void setLabelLinkMargin(double margin)   分類標簽與圖的連接線邊距
    void setLabelLinkPaint(Paint paint)   分類標簽與圖的連接線顏色
    void setLabelLinkStroke(Stroke stroke)   分類標簽與圖的連接線筆觸
    void setLabelOutlinePaint(Paint paint)   分類標簽邊框顏色
    void setLabelOutlineStroke(Paint paint)   分類標簽邊框筆觸
    void setLabelShadowPaint(Paint paint)   分類標簽陰影顏色
    void setMaximumLabelWidth(double width)   分類標簽的最大長度(0.0~1.0)
    void setPieIndex(int index)    餅圖的索引(復合餅圖中用到)
    void setSectionOutlinePaint(int section,Paint paint) 指定分類餅的邊框顏色
    void setSectionOutlineStroke(int section,Stroke stroke) 指定分類餅的邊框筆觸
    void setSectionPaint(int section,Paint paint) 指定分類餅的顏色
    void setShadowPaint(Paint paint)   餅圖的陰影顏色
    void setShadowXOffset(double offset)   餅圖的陰影相對圖的水平偏移
    void setShadowYOffset(double offset)   餅圖的陰影相對圖的垂直偏移
    void setLabelGenerator(PieSectionLabelGenerator generator) 分類標簽的格式,設置成null則整個標簽包括連接線都不顯示
    void setToolTipGenerator(PieToolTipGenerator generator) MAP中鼠標移上的顯示格式
    void setURLGenerator(PieURLGenerator generator)   MAP中鉆取鏈接格式

    PiePlot3D(PiePlot)類:
    void setDepthFactor(double factor)   3D餅圖的Z軸高度(0.0~1.0)

    MultiplePiePlot(Plot)類:
    void setLimit(double limit)    每個餅圖之間的數據關聯(詳細比較復雜)  
    void setPieChart(JFreeChart pieChart)   每個餅圖的顯示方式(見JFreeChart類個PiePlot類)

    -----------------------------------------------------------------------------------------------------------

    AbstractRenderer類:
    void setItemLabelAnchorOffset(double offset)     數據標簽的與數據點的偏移
    void setItemLabelsVisible(boolean visible)     數據標簽是否可見
    void setItemLabelFont(Font font)      數據標簽的字體
    void setItemLabelPaint(Paint paint)      數據標簽的字體顏色
    void setItemLabelPosition(ItemLabelPosition position)    數據標簽位置
    void setPositiveItemLabelPosition(ItemLabelPosition position)   正數標簽位置
    void setNegativeItemLabelPosition(ItemLabelPosition position)   負數標簽位置
    void setOutLinePaint(Paint paint)      圖形邊框的線條顏色
    void setOutLineStroke(Stroke stroke)      圖形邊框的線條筆觸
    void setPaint(Paint paint)       所有分類圖形的顏色
    void setShape(Shape shape)       所有分類圖形的形狀(如折線圖的點)
    void setStroke(Stroke stroke)       所有分類圖形的筆觸(如折線圖的線)
    void setSeriesItemLabelsVisible(int series,boolean visible)   指定分類的數據標簽是否可見
    void setSeriesItemLabelFont(int series,Font font)    指定分類的數據標簽的字體
    void setSeriesItemLabelPaint(int series,Paint paint)    指定分類的數據標簽的字體顏色
    void setSeriesItemLabelPosition(int series,ItemLabelPosition position) 數據標簽位置
    void setSeriesPositiveItemLabelPosition(int series,ItemLabelPosition position) 正數標簽位置
    void setSeriesNegativeItemLabelPosition(int series,ItemLabelPosition position) 負數標簽位置
    void setSeriesOutLinePaint(int series,Paint paint)    指定分類的圖形邊框的線條顏色
    void setSeriesOutLineStroke(int series,Stroke stroke)    指定分類的圖形邊框的線條筆觸
    void setSeriesPaint(int series,Paint paint)     指定分類圖形的顏色
    void setSeriesShape(int series,Shape shape)     指定分類圖形的形狀(如折線圖的點)
    void setSeriesStroke(int series,Stroke stroke)     指定分類圖形的筆觸(如折線圖的線)

    AbstractCategoryItemRenderer(AbstractRenderer)類:
    void setLabelGenerator(CategoryLabelGenerator generator)   數據標簽的格式
    void setToolTipGenerator(CategoryToolTipGenerator generator)   MAP中鼠標移上的顯示格式
    void setItemURLGenerator(CategoryURLGenerator generator)   MAP中鉆取鏈接格式
    void setSeriesLabelGenerator(int series,CategoryLabelGenerator generator) 指定分類的數據標簽的格式
    void setSeriesToolTipGenerator(int series,CategoryToolTipGenerator generator) 指定分類的MAP中鼠標移上的顯示格式
    void setSeriesItemURLGenerator(int series,CategoryURLGenerator generator) 指定分類的MAP中鉆取鏈接格式

    BarRenderer(AbstractCategoryItemRenderer)類:
    void setDrawBarOutline(boolean draw)      是否畫圖形邊框
    void setItemMargin(double percent)      每個BAR之間的間隔
    void setMaxBarWidth(double percent)      每個BAR的最大寬度
    void setMinimumBarLength(double min)      最短的BAR長度,避免數值太小而顯示不出
    void setPositiveItemLabelPositionFallback(ItemLabelPosition position) 無法在BAR中顯示的正數標簽位置
    void setNegativeItemLabelPositionFallback(ItemLabelPosition position) 無法在BAR中顯示的負數標簽位置

    BarRenderer3D(BarRenderer)類:
    void setWallPaint(Paint paint)    3D坐標軸的墻體顏色

    StackedBarRenderer(BarRenderer)類:
    沒有特殊的設置

    StackedBarRenderer3D(BarRenderer3D)類:
    沒有特殊的設置

    GroupedStackedBarRenderer(StackedBarRenderer)類:
    void setSeriesToGroupMap(KeyToGroupMap map)將分類自由的映射成若干個組(KeyToGroupMap.mapKeyToGroup(series,group))

    LayeredBarRenderer(BarRenderer)類:
    void setSeriesBarWidth(int series,double width) 設定每個分類的寬度(注意設置不要使某分類被覆蓋)

    WaterfallBarRenderer(BarRenderer)類:
    void setFirstBarPaint(Paint paint)   第一個柱圖的顏色
    void setLastBarPaint(Paint paint)   最后一個柱圖的顏色
    void setPositiveBarPaint(Paint paint)   正值柱圖的顏色
    void setNegativeBarPaint(Paint paint)   負值柱圖的顏色

    IntervalBarRenderer(BarRenderer)類:
    需要傳IntervalCategoryDataset作為數據源

    GanttBarRenderer(IntervalBarRenderer)類:
    void setCompletePaint(Paint paint)   完成進度顏色
    void setIncompletePaint(Paint paint)   未完成進度顏色
    void setStartPercent(double percent)   設置進度條在整條中的起始位置(0.0~1.0)
    void setEndPercent(double percent)   設置進度條在整條中的結束位置(0.0~1.0)

    StatisticBarRenderer(BarRenderer)類:
    需要傳StatisticCategoryDataset作為數據源

    LineAndShapeRenderer(AbstractCategoryItemRenderer)類:
    void setDrawLines(boolean draw)    是否折線的數據點之間用線連
    void setDrawShapes(boolean draw)   是否折線的數據點根據分類使用不同的形狀
    void setShapesFilled(boolean filled)   所有分類是否填充數據點圖形
    void setSeriesShapesFilled(int series,boolean filled) 指定分類是否填充數據點圖形
    void setUseFillPaintForShapeOutline(boolean use) 指定是否填充數據點的Paint也被用于畫數據點形狀的邊框

    LevelRenderer(AbstractCategoryItemRenderer)類:
    void setItemMargin(double percent)   每個分類之間的間隔
    void setMaxItemWidth(double percent)   每個分類的最大寬度

    CategoryStepRenderer(AbstractCategoryItemRenderer)類:
    void setStagger(boolean shouldStagger)   不同分類的圖是否交錯

    MinMaxCategoryRenderer(AbstractCategoryItemRenderer)類:
    void setDrawLines(boolean drawLines)   是否在每個分類線間畫連接線
    void setGroupPaint(Paint groupPaint)   一組圖形連接線的顏色
    void setGroupStroke(Stroke groupStroke)   一組圖形連接線的筆觸
    void setMaxIcon(Icon maxIcon)    最大值的ICON
    void setMinIcon(Icon minIcon)    最小值的ICON
    void setObjectIcon(Icon objectIcon)   所有值的ICON

    AreaRender(AbstractCategoryItemRenderer)類:
    沒有特殊的設置

    StackedAreaRender(AreaRender)類:
    沒有特殊的設置

    posted @ 2010-07-20 20:35 donghang73 閱讀(2740) | 評論 (0)編輯 收藏
             JFreeChart并不存在多個不同的類來生成不同的圖形。所有的圖形都是具體類JFreeChart的實例化對象,初始化JFreeChart對象的時候通過指定不同的Plot實現類就可以顯示出不同的圖形。不同的Plot實現類具有不同的Renderer對象、Axis對象、Dataset對象。

           JFreeChart提供工廠類ChartFactory方便使用者生成各種不同的圖形。ChartFactory類的各個工廠方法中實現對具體Plot的指定以及對類JFreeChart構造函數的調用。

        下面以常用圖形說一下常用的使用流程(大部分的操作講的并不全面,比如JFreeChart可能提供了很多增加、修改數據的方式,下文中可能只列舉一種)。

    1柱狀圖

    1)平面柱狀圖

        生成柱狀圖操作:

    JFreeChartchart=ChartFactory.createBarChart(String title,//圖標題

    String categoryAxisLabel,//x軸標題

    String valueAxisLabel,//y軸標題

    CategoryDataset dataset,//數據源

    PlotOrientation orientation,//顯示方向

    Boolean legend,//是否顯示圖例

    Boolean tooltips,//是否顯示tooltip

    Boolean urls)//是否指定url

    平面柱狀圖的Plot對象是CategoryPlot類型。CategoryPlot對象的x軸是CategoryAxis對象,y軸是NumberAxis對象,繪制單元是BarRenderer對象,數據源是CategoryDataset對象。

    獲取CategoryPlot對象操作為:

    CategoryPlot plot = (CategoryPlot)chart.getPlot();或者

    CategoryPlot plot = chart.getCategoryPlot();

    獲取繪制單元操作:

           BarRenderer renderer = (BarRenderer)plot.getRenderer();

    獲取x軸的操作:

    CategoryAxis xAxis = (CategoryAxis)plot.getDomainAxis();

    獲取y軸操作:

    NumberAxis yAxis = (NumberAxis)plot.getRangeAxis();

    獲取數據源:

    CategoryDataset dataset = plot.getDataset();

        柱狀圖可以接受一切CategoryDataset類型的數據源,下面講解一下常用的CategoryDataset類型DefaultCategoryDataset的使用方式

    實例化:

    DefaultCategoryDataset dataset = new DefaultCategoryDataset();

    增加數據

    dataset.addValue(doublevalue,ComparablerowKey,ComparablecolumnKey);

    刪除數據:

           dataset.removeValue(ComparablerowKey,ComparablecolumnKey);

        或者

           dataset.removeColumn(intcolumnIndex);

        或者

           dataset.removeColumn(ComparablecolumnKey);

        對行同樣有上述兩種刪除方式,不在列舉。

    修改數據:

           dataset.setValue(doublevalue,ComparablerowKey,ComparablecolumnKey);

    查詢數據:

    plot對象、繪制單元、x軸、y軸的顯示特性修改不再一一介紹。

    23D柱狀圖

        對應的工廠方法為createBarChart3D,該方法的參數與平面柱狀圖相同。3D柱狀圖的Plot對象是CategoryPlot類型。CategoryPlot對象的x軸是CategoryAxis3D對象,y軸是NumberAxis3D對象,繪制單元是BarRenderer3D對象,數據源是CategoryDataset對象。

        具體使用以及操作與平面柱狀圖雷同,不在詳述。

    2餅狀圖

    (1)平面餅狀圖

    生成平面餅狀圖:

    JFreeChartchart=ChartFactory.createPieChart(String title,//圖標題

    PieDataset dataset,//數據源

    Boolean legend,//是否顯示圖例

    Boolean tooltips,//是否顯示tooltip

    Boolean urls)//是否指定url

    平面餅狀圖的Plot對象是PiePlot類型。PiePlot對象沒有x軸對象、y軸對象、繪制單元對象,數據源是PieDataset對象。

    獲取PiePlot對象操作為:

    PiePlot plot = (PiePlot)chart.getPlot();

    獲取數據源:

    PieDataset dataset = plot.getDataset();

    餅狀圖可以接受一切PieDataset類型的數據源,下面講解一下常用的PieDataset類型DefaultPieDataset的使用方式

    實例化:

        DefaultPieDatasetdataset=newDefaultPieDataset();

    增加修改操作:

        dataset.setValue(Comparablekey,doublevalue);

    刪除操作:

        dataset.remove(Comparablekey);

    查詢操作:

        dataset.getKey(intitem);

    或者

    dataset.getValue(intitem);

    (1)3D餅狀圖

        對應的工廠方法為createPieChart3D,參數與平面餅狀圖相同。與平面餅狀圖的差別在于Plot對象是PiePlot3D類型,不再詳述。

    3多重餅狀圖

    1)多重平面餅狀圖

    生成多重平面餅狀圖:

    JFreeChartchart=ChartFactory.createMultiplePieChart (String title,//圖標題

    CategoryDataset dataset,//數據源

    TableOrder order,//指定提取數據的方式(按行或者按列)

    Boolean legend,//是否顯示圖例

    boolean tooltips,//是否顯示tooltip

    boolean urls)   //是否指定url

    多重平面餅狀圖的Plot對象是MultiplePiePlot類型。MultiplePiePlot對象沒有x軸對象、y軸對象、繪制單元對象,數據源是CategoryDataset對象。MultiplePiePlot對象中可以含有多個子JFreeChart對象,子JFreeChart對象是上面講過的餅狀圖對象。

    獲取MultiplePiePlot對象操作為:

    MultiplePiePlot plotMain = (MultiplePiePlot)chart.getPlot();

    獲取子JFreeChart的操作為:

           JfreeChart childChart = plotMain.getPieChart();

    獲取數據源:

    CategoryDataset dataset = plotMain.getDataset();

    2)多重3D餅狀圖

        對應的工廠方法為createMultiplePieChart3D,該方法的參數與多重平面餅狀圖相同。多重3D餅狀圖的Plot對象是MultiplePiePlot類型。MultiplePiePlot對象中可以含有多個子JFreeChart對象,子JFreeChart對象是上面講過的3D餅狀圖對象。

    4線圖

    1)平面線圖

        生成平面線圖:

    JFreeChartchart=ChartFactory.createLineChart(String title,//圖標題

    String categoryAxisLabel,//x軸標題

    String valueAxisLabel,//y軸標題

    CategoryDataset dataset,//數據源

    PlotOrientation orientation,//顯示方向

    Boolean legend,//是否顯示圖例

    Boolean tooltips,//是否顯示tooltip

    Boolean urls);//是否指定url

    平面線圖除了的Plot對象中繪制單元對象是LineAndShapeRenderer對象,其他一切組成對象與平面柱狀圖相同。

    獲取Renderer操作:

    LineAndShapeRenderer renderer = (LineAndShapeRenderer)plot.getRenderer();

    其他參考平面柱狀圖。

    23D線圖

    對應工廠方法為createLineChart3D,參數與createLineChart相同。3D線圖的組成對象除了繪制單元對象是LineAndShapeRenderer3D對象,其他一切組成對象與3D柱狀圖相同。

    5時序圖

    生成時序圖:

    JfreeChartchart = ChartFactory.createTimeSeriesChart(String title,//圖標題

    String timeAxisLabel,//x軸標題

    String valueAxisLabel,//y軸標題

    XYDataset dataset,//數據源

    Boolean legend,//是否顯示圖例

    Boolean tooltips,//是否顯示tooltip

    Boolean urls);//是否指定url

    時序圖的Plot對象是XYPlot類型。XYPlot對象的x軸是DateAxis對象,y軸是NumberAxis對象,繪制單元是XYLineAndShapeRenderer對象,數據源是XYDataset對象。

    Plot對象的獲取操作:

           XYPlot plot = (XYPlot)chart.getPlot();

    X軸對象的獲取操作:

           DateAxis xAxis = (DateAxis)plot.getDomainAxis();

    Y軸對象的獲取操作:

           NumberAxis yAxis = (NumberAxis)plot.getRangeAxis();

    Renderer對象的獲取操作:

           XYItemRenderer renderer = plot.getRenderer();

    時序圖可以接受一切XYDataset類型的數據源,下面講解一下常用的XYDataset類型TimeSeriesCollection的使用方式。

    實例化:

           TimeSeriesCollection dataset = newTimeSeriesCollection();

    添加數據操作:

           dataset.addSeries(TimeSeries);//后面講解TimeSeries對象

    刪除數據操作:

           dataset.removeSeries(intindex);

    查詢數據操作:

           dataset.getSeries(intseries);

    TimeSeries對象操作

    實例化:

           TimeSeries ts = TimeSeries(Stringname,ClasstimePeriodClass);

    增加數據操作:

           ts.add(RegularTimePeriod period,double value);

    刪除數據操作:

           ts.delete(RegularTimePeriod period);

    修改數據操作:

           ts.update(RegularTimePeriod period,Number value);

    查詢數據操作:

        ts.getValue(RegularTimePeriodperiod);

    RegularTimePeriodJFreeChart提供的時間模板類,它有很多具體的時間類,比如:MinuteSecondHourDay……等,不再詳述。

    posted @ 2010-07-20 20:33 donghang73 閱讀(1225) | 評論 (0)編輯 收藏

     

    1簡介

    JFreeChartSourceForge.net上的一個開源項目,它的源碼和API都可以免費獲得。JFreeChart的功能非常強大,可以實現餅圖(二維和三維),柱狀圖(水平,垂直),線圖,點圖,時序圖,甘特圖,股票行情圖,混和圖,溫度計圖,刻度圖等常用商用圖表,圖形可以導出成PNGJPEG格式,同時還可以與PDFEXCEL關聯,支持對圖形的放大、縮小,支持常見圖形的3D顯示。

    2圖形對象的處理

    2.1 JFreeChart對象

    JFreeChart可以生成很多圖形對象,它的工廠類提供了33個工廠方法用于生成不同的圖形對象(具體的工廠方法可以參見JFreeChartAPI手冊或者源碼中的ChartFactory)。JFreechart對圖形對象的抽象具體化。圖形對象(JFreeChart),由Title(主標題)SubTitle(子標題)Plot(圖形的繪制結構)等幾個主要對象組成。各個組成部分如下圖所示:
       
        
    這是一個JFreeChart對象,上面的“chart標題”是Title對象,中間區域是Plot對象(包括繪圖區域和坐標軸區域),下面的區域是LegendTitle對象,LegendTitle是一種SubTitle對象。

    每個JFreeChart對象只能有1Title對象,1Plot對象,可以有多個SubTitle對象。JFreeChart對象可以進行的操作有:背景的設置(背景顏色、背景圖片、透明度等)、邊框的設置(是否可見、筆畫、Paint等)、渲染方式的設置、標題對象的設置、子標題對象的增刪查操作。(本文中的所有操作都不提供代碼級的介紹,可參見API手冊或者源碼)

    2.2 主標題對象

    主標題對象是TextTitle類型,可以進行的操作有:背景設置、字體設置(字體類型、顏色、內容、對齊方式等操作)、tooltip設置、URL設置。

    2.3 Plot對象

    Plot對象是圖形的繪制結構對象。JFreeChart中含有很多不同的Plot對象,每一種圖形對象中的Plot對象都在實例化的時候創建。所有的Plot共有的操作有:背景設置(背景顏色、背景圖片、透明度等)、前景透明度設置、無數據存在情況的設置(顯示的字符內容、顯示的字體、顯示的Paint)、放大縮小比例的設置,大部分Plot對象還有設置Datset、設置Renderer對象操作。

    JFreeChart中有18Plot抽象類的具體實現類。Plot的具體實現類主要由以下重要對象組成:Renderer對象(圖形的繪制單元——繪圖域),Datset(圖形的數據源),DomainAxis(區域軸,相當于x軸),RangeAxis(范圍軸,相當于y軸)。

    不同的Plot對象組成方式不盡相同,有的不含有Renderer對象,比如CompassPlotContourPlotMultiplePiePlotPiePlot等,有的不含有DomainAxisRangeAxis對象,另外除了FastScatterPlot類都含有Datset對象,FastScatterPlot使用float的二維數組充當數據源。尤其說明一點,餅狀圖相關的Plot對象(MultiplePiePlotPiePlotPiePlot3DRingPlot)中都不含有Renderer對象、DomainAxis對象、RangeAxis對象。

    一般來說,Datset對象存儲數據模型,Renderer對象存儲顯示模型,Plot對象根據Datset對象、Renderer對象完成畫圖操作。


        仍以上面的圖形講解
    Plot對象的組成。
    上圖的中間區域是是一個XYPlot對象。其中的折線部分即是圖形的繪制單元Renderer對象。X軸是DomainAxisy軸是RangeAxis,其中Datset對象屬于數據模型范疇,是UI不可見對象。該圖中的plot背景色、網格線的各種設置可以通過XYPlot對象本身完成。

        下面講解Renderer對象、Axis對象(X軸、y軸都屬于Axis對象),Datset對象在后續章節中專門講解。

    2.3.1 Renderer對象

    Renderer對象是圖形的繪制單元。JFreeChart提供了兩個接口CategoryItemRendererXYItemRenderer、以及1個抽象類AbstractRenderer供具體的Renderer類實現,給出了將近50種具體實現類。

    一般來說Renderer對象可進行的操作有:對itemlabel(下圖中的柱狀圖上的紅色數字即為itemlabel的示例)的默認設置(itemlabel的產生方式、是否可見、字體、Paint、正反向itemlabel的位置設置等)、繪制圖形的邊框默認設置(Paint、筆畫、是否可見等)、繪制圖形的默認設置(形狀、筆畫、是否可見、對應的圖例中是否可見等,折線圖還有線條是否可見、折點圖形是否可見、折點圖形是否填充、折點圖形的形狀、對應的圖例中線條是否可見、圖形是否可見、整體是否可見等)、以及對指定itemlabel的設置、指定繪制圖形的設置。可以說和具體繪制的圖形相關的屬性都可以通過Renderer對象設置。

    不同的Renderer的實現類實現了不同的顯示方式,在含有Renderer對象的JFreeChart對象中,Renderer對象決定了JFreeChart對象的顯示方式。例如:柱狀圖的Plot對象中默認的Renderer對象是CategoryItemRenderer對象,通過設置Plot對象的Renderer對象LineAndShapeRenderer,則柱狀圖變為線圖。使用中一般不需要顯式的實例化一個Renderer對象,一般通過JFreeChart對象的Plot對象調用現有的Renderer對象進行重新設置等操作。

    2.3.2 Axis對象

    JFreeChart提供了兩種類型的坐標軸:CategoryAxis(等級軸)和ValueAxis(值軸),ValueAxis又有3個子類:DateAxis(時間軸)、NumberAxis(數字軸)、PeriodAxis(時期軸)。這些坐標軸還有更詳細的子類,不再一一列舉

    Axis對象可進行的操作有:標題的設置(內容、字體、Paint、顯示角度等)、坐標線的設置(筆畫、Paint、是否可見等)、刻度線的設置(是否可見、筆畫、Paint、位于繪圖區域的長度、位于繪圖區域外的長度等)、刻度標示的設置(筆畫、Paint、字體、與軸的距離等)、坐標軸范圍設置等。

    CategoryAxis對象還可以進行的操作有:刻度標示間距設置(最小間距、最大間距、指定間距)等。

    ValueAxis對象可進行的操作有:軸端設置(顯示的圖形形狀)、范圍設置(是否自動產生范圍、自動產生的最小范圍、最大范圍、指定確定范圍、指定范圍大小等)、間隔設置(是否自動產生間隔、指定間隔)等。

    DateAxis對象還有對時間刻度顯示格式的設置操作。

    2.4 子標題對象

        子標題對象是Title類型的對象,一個JFreeChart可以有多個子標題對象。JFreeChart提供了5種Title的實現,可以是圖片、文本、圖例等的形式。

    2.5數據源處理

    JFreeChart中的數據源是DataSet接口類型。該接口有三個主要的子類接口:CategoryDataset、PieDataset、SeriesDataset

    CategoryDataset接口的實現類基本上都維護了一個三元組<value,row,col>的列表結構。不同的實現類中value的類型不相同。<row,col>唯一確定一個三元組。CategoryDataset的實現類提供對這個三元組的增刪改查操作。

    PieDataset接口有兩個主要的實現類:CategoryToPieDataset、DefaultPieDataset。

    SeriesDataset接口的實現類基本上都維護了一種特定數據結構的列表。以TimeSeriesCollection為例。它維護一個TimeSeries對象列表,提供對該列表的增刪查操作。每個TimeSeries對象維護一個<time,value>列表,提供對該列表的增刪改查操作。

    posted @ 2010-07-20 20:29 donghang73 閱讀(1515) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 国产美女无遮挡免费视频网站 | 亚洲天堂一区在线| 免费久久精品国产片香蕉| 7m凹凸精品分类大全免费| 夜夜爽妓女8888视频免费观看| 亚洲成人动漫在线观看| 国产精品亚洲一区二区三区在线| 国产成人免费a在线视频app| 国产精品1024永久免费视频| 成人无码a级毛片免费| 美女羞羞视频免费网站| 国产精品高清视亚洲一区二区| 亚洲宅男永久在线| 亚洲av成人无码久久精品| 在线亚洲精品自拍| 亚洲国产一成久久精品国产成人综合 | 免费精品国产自产拍在线观看 | 免费精品一区二区三区在线观看 | 国产亚洲AV无码AV男人的天堂| 全部免费毛片在线| 日日AV拍夜夜添久久免费| 成人免费一级毛片在线播放视频| 国产精品区免费视频| 成人爽a毛片免费| 最近2019中文免费字幕在线观看| eeuss免费影院| 国产区在线免费观看| 国产精品免费久久久久久久久 | 日韩免费高清视频| 高清国语自产拍免费视频国产 | 亚洲酒色1314狠狠做| 亚洲视频精品在线| 亚洲国产精品国自产拍电影| 久久精品亚洲综合专区| 亚洲VA成无码人在线观看天堂 | 无码人妻一区二区三区免费n鬼沢| 日本在线免费观看| 91香焦国产线观看看免费| 最近免费中文字幕高清大全| 曰批视频免费40分钟试看天天| 国产国产人免费视频成69堂|