JSlider作为Swing中提供的滑标组件, 以图形方式在有界区间内通过移动滑块来选择值,滑块可以显示主刻度标记和次刻度标记。大量应用于如播放器中的音量设定等领域中。
但是JSlider本身提供的UI样式很单调,不足以满足用户的审美需求,往往需要我们自行重构其UI。
下面我给出一个简单的例子。
package org.loon.framework.swing.test;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.GradientPaint;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Polygon;
import java.awt.Rectangle;
import java.awt.RenderingHints;
import javax.swing.Box;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JSlider;
import javax.swing.WindowConstants;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
/** *//**
* <p>
* Title: LoonFramework
* </p>
* <p>
* Description:
* </p>
* <p>
* Copyright: Copyright (c) 2007
* </p>
* <p>
* Company: LoonFramework
* </p>
*
* @author chenpeng
* @email:ceponline@yahoo.com.cn
* @version 0.1
*/
public class ExampleSlider extends JPanel ...{
/** *//**
*
*/
private static final long serialVersionUID = 1L;
public ExampleSlider() ...{
// 设定布局器
super(new BorderLayout());
// 设定监听器
ChangeListener listener = new ChangeListener() ...{
public void stateChanged(ChangeEvent e) ...{
if (e.getSource() instanceof JSlider) ...{
System.out.println("刻度: "
+ ((JSlider) e.getSource()).getValue());
}
}
};
// 设定JSlider1
JSlider s1 = new JSlider(0, 100, 0);
// 注入自定义ui
s1.setUI(new MySliderUI());
// 主刻度
s1.setMajorTickSpacing(10);
// 次刻度
s1.setMinorTickSpacing(5);
// 设定为显示
s1.setPaintTicks(true);
s1.setPaintLabels(true);
// 监听slider1
s1.addChangeListener(listener);
// 设定JSlider2
JSlider s2 = new JSlider(0, 100, 0);
// 使用MetalSliderUI为ui
s2.setUI(new javax.swing.plaf.metal.MetalSliderUI() ...{
protected void paintHorizontalLabel(Graphics g, int v, Component l) ...{
JLabel lbl = (JLabel) l;
lbl.setForeground(Color.green);
super.paintHorizontalLabel(g, v, lbl);
}
});
s2.setForeground(Color.BLUE);
s2.setMajorTickSpacing(10);
s2.setMinorTickSpacing(5);
s2.setPaintTicks(true);
s2.setPaintLabels(true);
s2.addChangeListener(listener);
//使用盒式容器
Box box = Box.createVerticalBox();
box.add(Box.createVerticalStrut(5));
box.add(s1);
box.add(Box.createVerticalStrut(5));
box.add(s2);
box.add(Box.createVerticalGlue());
add(box, BorderLayout.CENTER);
add(Box.createHorizontalStrut(5), BorderLayout.WEST);
add(Box.createHorizontalStrut(5), BorderLayout.EAST);
//设定窗体大小
setPreferredSize(new Dimension(240, 100));
}
public static void main(String[] args) ...{
EventQueue.invokeLater(new Runnable() ...{
public void run() ...{
createUI();
}
});
}
public static void createUI() ...{
JFrame frame = new JFrame("音量刻度设置");
frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
frame.getContentPane().add(new ExampleSlider());
frame.setResizable(false);
frame.pack();
//居中
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
}
class MySliderUI extends javax.swing.plaf.metal.MetalSliderUI ...{
/** *//**
* 绘制指示物
*/
public void paintThumb(Graphics g) ...{
Graphics2D g2d = (Graphics2D) g;
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
//填充椭圆框为当前thumb位置
g2d.fillOval(thumbRect.x, thumbRect.y, thumbRect.width,
thumbRect.height);
//也可以帖图(利用鼠标事件转换image即可体现不同状态)
//g2d.drawImage(image, thumbRect.x, thumbRect.y, thumbRect.width,thumbRect.height,null);
}
/** *//**
* 绘制刻度轨迹
*/
public void paintTrack(Graphics g) ...{
int cy, cw;
Rectangle trackBounds = trackRect;
if (slider.getOrientation() == JSlider.HORIZONTAL) ...{
Graphics2D g2 = (Graphics2D) g;
cy = (trackBounds.height / 2) - 2;
cw = trackBounds.width;
g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING,
RenderingHints.VALUE_ANTIALIAS_ON);
g2.translate(trackBounds.x, trackBounds.y + cy);
// 背景设为灰色
g2.setPaint(Color.GRAY);
g2.fillRect(0, -cy, cw, cy * 2);
int trackLeft = 0;
int trackRight = 0;
trackRight = trackRect.width - 1;
int middleOfThumb = 0;
int fillLeft = 0;
int fillRight = 0;
//坐标换算
middleOfThumb = thumbRect.x + (thumbRect.width / 2);
middleOfThumb -= trackRect.x;
if (!drawInverted()) ...{
fillLeft = !slider.isEnabled() ? trackLeft : trackLeft + 1;
fillRight = middleOfThumb;
} else ...{
fillLeft = middleOfThumb;
fillRight = !slider.isEnabled() ? trackRight - 1
: trackRight - 2;
}
// 设定渐变
g2.setPaint(new GradientPaint(0, 0, new Color(0, 100, 100), cw, 0,
new Color(0, 255, 100), true));
g2.fillRect(0, -cy, fillRight - fillLeft, cy * 2);
g2.setPaint(slider.getBackground());
Polygon polygon = new Polygon();
polygon.addPoint(0, cy);
polygon.addPoint(0, -cy);
polygon.addPoint(cw, -cy);
g2.fillPolygon(polygon);
polygon.reset();
g2.setPaint(Color.WHITE);
g2.drawLine(0, cy, cw - 1, cy);
g2.setRenderingHint(RenderingHints.KEY_ANTIALIASING,
RenderingHints.VALUE_ANTIALIAS_OFF);
g2.translate(-trackBounds.x, -(trackBounds.y + cy));
} else ...{
super.paintTrack(g);
}
}
}
效果图:
原文出自 “Java究竟怎么玩” 博客http://cping1982.blog.51cto.com/601635/130163
- 大小: 9.5 KB
分享到:
相关推荐
### 自定义`JSlider`标签名称 `JSlider`的标签可以通过`Hashtable`来定制。例如,可以创建一个哈希表,用数字名称作为键,数字对象作为值,然后将这些标签关联到滑块的特定刻度上。这提供了一种灵活的方式来显示...
JSlider是Swing中的一个组件,用于创建滑块界面元素,用户可以通过拖动滑块在指定的范围内选择值。滑块常用于音量控制、亮度调节等场景,为用户提供直观的交互体验。 在Java Swing中,JSlider的主要功能和特性包括...
`JSlider`支持水平和垂直两种方向,并提供了一系列的自定义选项,如显示刻度标记、显示刻度值、设置主次刻度间隔等,这使得它成为一个非常灵活且强大的用户界面元素。 #### 示例代码分析 在给出的代码示例中,我们...
7. **Swing小部件(Widgets)**:包括JSpinner(数字选择器)、JSlider(滑块)、JComboBox(下拉列表)等,提供了更多用户交互方式。 8. **国际化(Internationalization)**:Swing支持多语言,开发者可以通过...
此外,书中可能还涵盖了更多关于Swing组件的高级主题,如布局管理器、菜单、对话框、事件处理以及自定义组件的创建等。通过深入阅读《Java Swing》,开发者不仅可以理解Swing的基本概念,还能掌握构建专业级GUI应用...
`JSlider`是Java Swing的一个组件,虽然在AWT中没有直接对应的部分,但它是AWT环境下的常用扩展。`JSlider`常用于创建滑块控件,允许用户通过拖动滑块来选择一个介于最小值和最大值之间的数值,这在各种需要用户输入...
- `JWindow` 是一个无边界窗口,较少直接使用,但可以用于创建自定义窗口布局。 3. **中间容器** - `JPanel` 是最基础的面板,可以用来组织和展示组件。 - `JScrollPane` 提供了滚动条功能,当组件内容超出可视...
在Swing中,你可以添加不同类型的元素,如字符串、图标或者自定义对象。通过监听ActionEvent,你可以响应用户的选中操作。 2. **列表框(JList)**:JList显示一组可滚动的项目,用户可以选择一个或多个项。它可以...
通过这个项目,我们可以深入了解Swing组件的功能、交互方式以及自定义的可能性。 Swing组件是构建Java桌面应用程序的基础,它们包括按钮(JButton)、文本框(JTextField)、标签(JLabel)、面板(JPanel)、滚动...
- **JSlider**:滑块组件,用于选择一个数值范围内的值。 - **JTextField**:单行文本输入框。 - **JTextArea**:多行文本输入和显示区域。 - **JPasswordField**:用于安全输入密码的文本框,输入内容通常以星号或...
- **可定制性**:Swing 组件允许用户自定义其外观和行为,这使得开发者能够轻松地创建符合特定设计需求的应用程序界面。 - **事件模型**:Swing 基于观察者模式实现了事件处理机制,允许开发者通过注册监听器来...
1. **components-IconDemoProject.zip**:这个例子展示了如何在Swing组件上使用图标(Icon),包括设置按钮、菜单项等的图标,以及自定义图标的显示方式。 2. **components-SplitPaneDemo2Project.zip**:SplitPane...
在应用中,用户可以通过JButton、JRadiobutton、JSlider、JCheckBox自定义变量的值并与应用进行交互。 **方法** * 数组 2D * javax.swing.JFrame * javax.swing.JPanel * javax.swing.JLabel * javax.swing....
7. **滑块(JSlider)**:滑块组件用于表示数值范围,用户可以通过拖动滑块来选择值。可以设置最小值、最大值、步进值,并通过AdjustmentListener监听滑动事件。 8. **菜单(JMenu, JMenuItem)**:菜单系统是Swing...
- `JSlider`:用于调整画笔粗细,实现画笔宽度的动态改变。 - `JRadioButton` 和 `ButtonGroup`:用于选择不同的形状,如直线、矩形等。 2. **绘图原理**: - `Graphics2D`:在`JPanel`的`paintComponent...
6. **Swing小部件和工具条**:了解滑块(JSlider)、进度条(JProgressBar)、定时器(Timer)和工具条(JToolBar)等增强用户体验的组件。 7. **外观和感觉**:学习如何改变Swing应用的视觉风格,使用LookAndFeel ...
Swing程序设计中还涉及到许多细节,比如线程安全、组件的绘画(JComponent的paint()方法)、自定义组件的开发等。Swing是线程不安全的,正确的做法是所有的UI操作都应该在事件分派线程(Event Dispatch Thread,EDT...
另外,Swing 还包含了对话框(JOptionPane)、进度条(JProgressBar)、滑块(JSlider)等控件,丰富了用户界面元素,增强了用户体验。 为了构建复杂的表单,Swing 提供了 JFormDesigner 和 NetBeans IDE 等工具,...
9. **Swing小部件**:Swing还包括许多其他组件,如滑块(JSlider)、进度条(JProgressBar)、日历选择器(JCalendar)、复选框(JCheckBox)和单选按钮(JRadioButton)。"exam"可能涵盖了这些小部件的使用。 10. ...
除此之外,Swing还提供了JToolBar来创建工具栏,JSlider、JSpinner和JProgressBar等组件用于用户输入和反馈。 Swing不仅提供了丰富的组件库,还支持外观和感觉(Look and Feel)的定制,开发者可以选择默认的Metal ...