`
lian
  • 浏览: 57750 次
  • 性别: Icon_minigender_1
  • 来自: 洛阳
社区版块
存档分类
最新评论

swing自定义JSlider

阅读更多

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
分享到:
评论

相关推荐

    SWING教學-JSlider 元件的使用

    ### 自定义`JSlider`标签名称 `JSlider`的标签可以通过`Hashtable`来定制。例如,可以创建一个哈希表,用数字名称作为键,数字对象作为值,然后将这些标签关联到滑块的特定刻度上。这提供了一种灵活的方式来显示...

    Java Swing JSlider滑块的实现示例

    JSlider是Swing中的一个组件,用于创建滑块界面元素,用户可以通过拖动滑块在指定的范围内选择值。滑块常用于音量控制、亮度调节等场景,为用户提供直观的交互体验。 在Java Swing中,JSlider的主要功能和特性包括...

    swing刻度例子

    `JSlider`支持水平和垂直两种方向,并提供了一系列的自定义选项,如显示刻度标记、显示刻度值、设置主次刻度间隔等,这使得它成为一个非常灵活且强大的用户界面元素。 #### 示例代码分析 在给出的代码示例中,我们...

    swing经典开发,全面了解java swing核心编程

    7. **Swing小部件(Widgets)**:包括JSpinner(数字选择器)、JSlider(滑块)、JComboBox(下拉列表)等,提供了更多用户交互方式。 8. **国际化(Internationalization)**:Swing支持多语言,开发者可以通过...

    java swing

    此外,书中可能还涵盖了更多关于Swing组件的高级主题,如布局管理器、菜单、对话框、事件处理以及自定义组件的创建等。通过深入阅读《Java Swing》,开发者不仅可以理解Swing的基本概念,还能掌握构建专业级GUI应用...

    javaAWT组件JSlider应用

    `JSlider`是Java Swing的一个组件,虽然在AWT中没有直接对应的部分,但它是AWT环境下的常用扩展。`JSlider`常用于创建滑块控件,允许用户通过拖动滑块来选择一个介于最小值和最大值之间的数值,这在各种需要用户输入...

    JavaSwing界面设计(所有控件及示例)

    - `JWindow` 是一个无边界窗口,较少直接使用,但可以用于创建自定义窗口布局。 3. **中间容器** - `JPanel` 是最基础的面板,可以用来组织和展示组件。 - `JScrollPane` 提供了滚动条功能,当组件内容超出可视...

    一些Swing应用实例Java源码包

    在Swing中,你可以添加不同类型的元素,如字符串、图标或者自定义对象。通过监听ActionEvent,你可以响应用户的选中操作。 2. **列表框(JList)**:JList显示一组可滚动的项目,用户可以选择一个或多个项。它可以...

    swing全组件演示开源项目

    通过这个项目,我们可以深入了解Swing组件的功能、交互方式以及自定义的可能性。 Swing组件是构建Java桌面应用程序的基础,它们包括按钮(JButton)、文本框(JTextField)、标签(JLabel)、面板(JPanel)、滚动...

    swing组件的详细介绍

    - **JSlider**:滑块组件,用于选择一个数值范围内的值。 - **JTextField**:单行文本输入框。 - **JTextArea**:多行文本输入和显示区域。 - **JPasswordField**:用于安全输入密码的文本框,输入内容通常以星号或...

    java swing权威指南

    - **可定制性**:Swing 组件允许用户自定义其外观和行为,这使得开发者能够轻松地创建符合特定设计需求的应用程序界面。 - **事件模型**:Swing 基于观察者模式实现了事件处理机制,允许开发者通过注册监听器来...

    Swing 官方例子

    1. **components-IconDemoProject.zip**:这个例子展示了如何在Swing组件上使用图标(Icon),包括设置按钮、菜单项等的图标,以及自定义图标的显示方式。 2. **components-SplitPaneDemo2Project.zip**:SplitPane...

    Spreading_of_Fire:森林火灾蔓延模拟

    在应用中,用户可以通过JButton、JRadiobutton、JSlider、JCheckBox自定义变量的值并与应用进行交互。 **方法** * 数组 2D * javax.swing.JFrame * javax.swing.JPanel * javax.swing.JLabel * javax.swing....

    Java Swing 学习代码

    7. **滑块(JSlider)**:滑块组件用于表示数值范围,用户可以通过拖动滑块来选择值。可以设置最小值、最大值、步进值,并通过AdjustmentListener监听滑动事件。 8. **菜单(JMenu, JMenuItem)**:菜单系统是Swing...

    java Swing 实现的画图小程序

    - `JSlider`:用于调整画笔粗细,实现画笔宽度的动态改变。 - `JRadioButton` 和 `ButtonGroup`:用于选择不同的形状,如直线、矩形等。 2. **绘图原理**: - `Graphics2D`:在`JPanel`的`paintComponent...

    Java Swing的显示方式

    Look and Feel 在 Swing 中扮演着核心角色,允许开发者自定义应用的外观和感觉。默认情况下,Swing 提供了两种内置的 Look and Feel:Metal (Java 默认) 和 System (与操作系统一致)。此外,还可以使用第三方的 Look...

    精通Java Swing程序设计

    6. **Swing小部件和工具条**:了解滑块(JSlider)、进度条(JProgressBar)、定时器(Timer)和工具条(JToolBar)等增强用户体验的组件。 7. **外观和感觉**:学习如何改变Swing应用的视觉风格,使用LookAndFeel ...

    Java_Swing程序设计

    Swing程序设计中还涉及到许多细节,比如线程安全、组件的绘画(JComponent的paint()方法)、自定义组件的开发等。Swing是线程不安全的,正确的做法是所有的UI操作都应该在事件分派线程(Event Dispatch Thread,EDT...

    GUISwing的中级代码

    另外,Swing 还包含了对话框(JOptionPane)、进度条(JProgressBar)、滑块(JSlider)等控件,丰富了用户界面元素,增强了用户体验。 为了构建复杂的表单,Swing 提供了 JFormDesigner 和 NetBeans IDE 等工具,...

    swing例子

    9. **Swing小部件**:Swing还包括许多其他组件,如滑块(JSlider)、进度条(JProgressBar)、日历选择器(JCalendar)、复选框(JCheckBox)和单选按钮(JRadioButton)。"exam"可能涵盖了这些小部件的使用。 10. ...

Global site tag (gtag.js) - Google Analytics