Java绘图 如何正确绘图和出现滚动条
面是我认为正确的做法(结合自己的经验写的,如果不正确,请大家指正):
我的绘图控件是JPanel,
出现滚动条的前提,必须让绘图控件放在JScrollPane上,
对于JScrollPane的Layout,没有特殊要求,下面这样即可:
view plaincopy to clipboardprint?
jScrollPane1.setViewportView(jPanel1);
jScrollPane1.setViewportView(jPanel1);
然后,另外维持一个BufferedImage(假设叫image1),各种图像的处理都是对image1进行。
画的时候,只需要把image1画在jPanel1上即可。
下面是如何画图:
(1)在生成jPanel1的时候,需要覆盖paint(Graphics g)方法,在里面把image1画上去:
view plaincopy to clipboardprint?
jPanel1 = new JPanel(){
@Override
public void paint(Graphics g) {
super.paint(g);
if(image1 != null){
g.clearRect(0, 0, this.getWidth(), this.getHeight());
g.drawImage(image1, 0, 0, null);
g.dispose();
}
}
};
jPanel1 = new JPanel(){
@Override
public void paint(Graphics g) {
super.paint(g);
if(image1 != null){
g.clearRect(0, 0, this.getWidth(), this.getHeight());
g.drawImage(image1, 0, 0, null);
g.dispose();
}
}
};
(2)在所有对image1的处理以后,需要调用jPanel1.repaint() → 注:会自己调用paint(Graphics g)方法
比如在对image1进行放大缩小,或者去掉某些颜色以后,需要调用jPanel1.repaint()
(3)在image1的size有变化的时候,需要调用:
view plaincopy to clipboardprint?
jPanel1.setPreferredSize(new Dimension(image1.getWidth(),image1.getHeight()));
jPanel1.updateUI();
jPanel1.setPreferredSize(new Dimension(image1.getWidth(),image1.getHeight()));
jPanel1.updateUI();
这是关键!!因为不修改jPanel1的PreferredSize的话,滚动条永远都出不来!!
注意:
①第一次绘制image1时,也应该调用这两句,因为image1从null变成有值,size当然有变化。
②在jPanel1覆盖的paint(Graphics g)方法里,不要调用这两句。因为调用jPanel1.updateUI()时,会自动调用repaint(),进而自动调用paint(Graph
相关文档:
我们知道,在Java中设置变量值的操作,除了long和double类型的变量外都是原子操作,也就是说,对于变量值的简单读写操作没有必要进行同步。
这在JVM 1.2之前,Java的内存模型实现总是从主存读取变量,是不需要进行特别的注意的。而随着JVM的成熟和优化,现在在多线程环境下
volatile关键字的使用变得非常重要。在当前的 ......
对于这个系列里的问题,每个学Java的人都应该搞懂。当然,如果只是学Java玩玩就无所谓了。如果你认为自己已经超越初学者了,却不很懂这些问题,请将你自己重归初学者行列。内容均来自于CSDN的经典老贴。如果大家感觉在基础学习自己薄弱的也可以那出来共享,共同学习.
&nb ......
cd /usr/lib/jvm/java
-1.5.0-sun-1.5.0.15/jre/lib/fonts
sudo mkdir fallback
cd fallback
sudo cp /usr/share/fonts/truetype/arphic/uming.ttc /usr/lib/jvm/java
-1.5.0-sun-1.5.0.15/jre/lib/fonts/fallback
sudo mkfontdir
sudo mkfontscale ......
原文地址: http://www.javaworld.com/javaworld/jw-09-2007/jw-09-optimizingregex.html
如果你花费了数小时和正则表达式做斗争,只是为了让它完成它几秒内就可以完成的匹配,那么这篇文章正是为你量身定做的。Cristian
Mocanu指出了在什么地方正则模式匹配会发生延迟 ......
方法一:只加密
import java.security.*;
import java.security.spec.*;
class MD5_test {
public final static String MD5(String s) {
char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
&n ......