Home > Java > javaTutorial > How to Draw Lines on a JPanel Using Button Clicks in Java?

How to Draw Lines on a JPanel Using Button Clicks in Java?

Patricia Arquette
Release: 2024-12-14 12:22:13
Original
452 people have browsed it

How to Draw Lines on a JPanel Using Button Clicks in Java?

How to Draw a Line in a JPanel with a Button Click in Java

The given code provides a graphical user interface (GUI) with a JPanel and several buttons. The goal is to draw lines on the JPanel when the buttons are clicked.

Drawing Lines

To draw lines on the JPanel, you can use the drawLine() method of the Graphics object:

public void paint(Graphics graphics)
{
    graphics.drawLine(10, 20, 300, 310);
}
Copy after login

This code draws a line from the point (10, 20) to the point (300, 310). You can modify these coordinates to draw lines in different positions and directions.

Event Handling with Mouse Events

To handle user interactions, such as button clicks and mouse movements, you can use event listeners. In this case, you will use mouse listeners to detect when the user clicks on the JPanel.

public class MouseHandler extends MouseAdapter {

    @Override
    public void mouseClicked(MouseEvent arg0) {


        /////////////


    }
}
Copy after login

In the mouseClicked method, you can write the code to draw the line based on the user's click.

Integrating with the GUI

To integrate the line drawing code with the GUI, you need to add a button to the JPanel. When the button is clicked, it should trigger the mouseClicked method of the MouseHandler and draw the line.

JLabel label = new JLabel("New label");
label.addMouseListener(new MouseHandler() {
   @Override
   public void mouseClicked(MouseEvent arg0) {


    /////////////


   }
});
contentPane.add(label);
Copy after login

In this example, a button named "New label" is added to the JPanel. When it is clicked, it calls the mouseClicked method of the MouseHandler. You can modify the mouseClicked method to include the code for drawing the line.

Handling Multiple Lines

If you want to draw multiple lines, you can store the points clicked by the user and draw lines between them. You can use a List to store the points and then draw a line between each pair of consecutive points.

Example Implementation

Here is a complete example that demonstrates drawing multiple lines on a JPanel with button clicks:

import java.awt.BasicStroke;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Point;
import java.awt.RenderingHints;
import java.awt.event.ActionEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.util.ArrayList;
import java.util.List;
import javax.swing.AbstractAction;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.KeyStroke;

public class Main {

    private ArrayList<Point> points = new ArrayList<>();
    private boolean drawing;

    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {

            @Override
            public void run() {
                new Main().display();
            }
        });
    }

    private void display() {
        JFrame f = new JFrame("LinePanel");
        f.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

        JPanel panel = new JPanel();
        panel.setPreferredSize(new Dimension(640, 480));
        panel.addMouseListener(new MouseHandler());
        panel.addMouseMotionListener(new MouseHandler());
        f.add(panel);

        JButton clearButton = new JButton("Clear");
        clearButton.addActionListener(new AbstractAction() {

            @Override
            public void actionPerformed(ActionEvent e) {
                points.clear();
                panel.repaint();
            }
        });
        f.add(clearButton, BorderLayout.SOUTH);

        f.pack();
        f.setLocationRelativeTo(null);
        f.setVisible(true);
    }

    private class MouseHandler extends MouseAdapter {

        @Override
        public void mousePressed(MouseEvent e) {
            drawing = true;
            points.add(e.getPoint());
            panel.repaint();
        }

        @Override
        public void mouseReleased(MouseEvent e) {
            drawing = false;
            panel.repaint();
        }

        @Override
        public void mouseDragged(MouseEvent e) {
            if (drawing) {
                points.add(e.getPoint());
                panel.repaint();
            }
        }
    }
}
Copy after login

This example creates a JFrame with a JPanel and a "Clear" button. When the user clicks on the JPanel, it starts drawing a line. As the mouse is moved, the line extends. When the mouse is released, the line is complete. The "Clear" button can be used to clear all the lines and start over.

The above is the detailed content of How to Draw Lines on a JPanel Using Button Clicks in Java?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template