制作圆形Swing按钮(中文版)

转载 2007年10月04日 15:44:00
这是一个关于制作圆形Swing按钮的技巧。事实上,这个技巧中的知识方便的适用于任何形状的按钮,但我们只作一个圆形的按钮。当你制作一个圆形的按钮时,需要做两件事。第一件事是重载一个适当的绘画方法以画出一个圆形。第二件事是设置一些事件使得只有当你点击圆形按钮的范围中的时侯按钮才会作出响应(不是包含圆形按钮的矩形的范围中)。

下面是一个实现了圆形按钮的例程:

 
import java.awt.*;
import java.awt.geom.*;
import javax.swing.*;

public class RoundButton extends JButton {
  public RoundButton(String label) {
    super(label);

// 这些声明把按钮扩展为一个圆而不是一个椭圆。
    Dimension size = getPreferredSize();
    size.width = size.height = Math.max(size.width,
      size.height);
    setPreferredSize(size);


//这个调用使JButton不画背景,而允许我们画一个圆的背景。
    setContentAreaFilled(false);
  }

// 画圆的背景和标签
  protected void paintComponent(Graphics g) {
    if (getModel().isArmed()) {

// 你可以选一个高亮的颜色作为圆形按钮类的属性
      g.setColor(Color.lightGray);
    } else {
      g.setColor(getBackground());
    }
    g.fillOval(0, 0, getSize().width-1,
      getSize().height-1);

//这个调用会画一个标签和焦点矩形。
    super.paintComponent(g);
  }


// 用简单的弧画按钮的边界。
  protected void paintBorder(Graphics g) {
    g.setColor(getForeground());
    g.drawOval(0, 0, getSize().width-1,
      getSize().height-1);
  }


// 侦测点击事件
  Shape shape;
  public boolean contains(int x, int y) {

// 如果按钮改变大小,产生一个新的形状对象。
    if (shape == null ||
      !shape.getBounds().equals(getBounds())) {
      shape = new Ellipse2D.Float(0, 0,
        getWidth(), getHeight());
    }
    return shape.contains(x, y);
  }

// 测试程序
  public static void main(String[] args) {
// 产生一个带‘Jackpot’标签的按钮。   
    JButton button = new RoundButton("Jackpot");
    button.setBackground(Color.green);

// 产生一个框架以显示这个按钮。
    JFrame frame = new JFrame();
    frame.getContentPane().setBackground(Color.yellow);
    frame.getContentPane().add(button);
    frame.getContentPane().setLayout(new FlowLayout());
    frame.setSize(150, 150);
    frame.setVisible(true);
  }
}

       由于我们想保留JButton的大部分功能,我们让RoundButton类继承了JButton类。在RoundButton的构造方法中,setContentAreaFilled()方法被调用。这就让按钮画了一个矩形的焦点区,但不画背景。

现在我们需要画一个圆的背景。这是通过重载paintComponent()方法实现的。那个方法使用Graphics.fillOval()方法画一个实心的圆。然后paintComponent()方法调用super.paintComponent()在这个实心圆的上面画了一个标签。

这个例子还重载了paintBorder()方法以在圆形按钮的边界上画一个边。如果你不想要边框,你也可以不重载这个方法。这个方法调用了Graphics.drawOval()方法以在圆的边界上画一个细的边框。

注意:在JDKTM 1.2.2中,当你将鼠标拖进或拖出按钮的范围时,JButton的行为有一个小BUG。理论上,当你在圆形按钮上点击鼠标然后拖动鼠标离开按钮的边界时,按钮应该改变它的外形。当你拖动鼠标进入按钮的边界内时,按钮应回复它的外形。不幸的是,包含这个行为的代码不能调用contains()方法。代替它的是只使用按钮的‘限制范围’(这是包含按钮的最小矩形范围)注意,如果你在圆形边界内轻微的拖动鼠标,也就是说离开圆形的范围但不离开边界,按钮将不会改变它的外形。

 

相关文章推荐

Java制作圆形按钮

制作圆形Swing按钮(中文版)     作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站        这是一个关于制作...

一步步教你制作WPF圆形玻璃按钮

图1   1.介绍 从我开始使用vista的时候,我就非常喜欢它的圆形玻璃按钮。WPF最好的一个方面就是允许自定义任何控件的样式。用了一段时间的Microsoft Expression Bl...

用PPT制作圆形水晶按钮

看到图1中的水晶按钮,你可能以为是在Photoshop之类的专业图形软件中制作,然后再插入到这个演示文稿中的,其实我们可以利用PowerPoint的绘图功能来制作。这样不用处理插入图片的背景,而且非常...

圆形图片按钮

  • 2017-08-23 16:46
  • 94KB
  • 下载

iOS圆形按钮

  • 2015-01-12 22:44
  • 133KB
  • 下载

Swing圆形进度条

遇到JProgressBar的setVaule方法连续调用不刷新的问题,就想着用一个进度动画加一个Jlabel去刷新百分比而取代,网上无意看到这个方法,有需要的可以试试。 1.Animate...

CSS经典圆形按钮

  • 2013-08-14 11:06
  • 18KB
  • 下载

android 绘制圆形按钮

先上效果图: 代码: <item android:state_pressed="false" android:drawable="@drawable/greenbutton"
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)