java+mysql 课程设计-未完成版

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 课设

课程设计

大二下 Java + MySQL 两者结合的课程设计。

主题

一个音乐播放器,界面简陋,功能未能实现。只能对一个 .wav 格式的音频进行解码播放,仅此,想加上一个歌词同步功能,搞了好久都搞不起,遂放弃,觉得搞个其他的算了,格式转换太麻烦了。数据库未能来得及加上,已经放弃。暑假或者以后有时间再来完善一下,接着搞这个。

源码

package MusicPlayer;

import javax.sound.sampled.*;
import javax.swing.*;
import javax.swing.Timer;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.*;
import java.util.List;

/**
 * @author WangYH
 * @version 2021.1.3
 * @date 2023/6/1 22:14
 */

public class MusicPlayer extends JFrame implements ActionListener {
   
    private JButton openButton, playButton, pauseButton, stopButton, lyricButton;
    private JFileChooser fileChooser, lyricChooser;
    private JLabel nameLabel, timeLabel, lyricLabel;
    private Clip clip;
    private Timer timer;
    private ArrayList<Long> timeList;
    private ArrayList<String> lyricList;
    Map<Long, String> lyricMap;
    Map<Long, String> sortedMap;
    private boolean flag = true;
    private int count = 1;


    File lyricFile = null;

    public MusicPlayer() {
   

        super("音乐播放器");
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setSize(800, 500);
        setVisible(true);

        // 创建按钮
        openButton = new JButton("选择歌曲");
        playButton = new JButton("播放");
        pauseButton = new JButton("暂停");
        stopButton = new JButton("停止");
        lyricButton = new JButton("选择歌词");

        // 添加按钮监听器
        openButton.addActionListener(this);
        playButton.addActionListener(this);
        pauseButton.addActionListener(this);
        stopButton.addActionListener(this);
        lyricButton.addActionListener(this);

        // 创建文件选择器
        fileChooser = new JFileChooser();
        fileChooser.setCurrentDirectory(new File("D:\\JAVA\\IDEAProject\\MusicPlayer\\src\\music"));

        lyricChooser = new JFileChooser();
        lyricChooser.setCurrentDirectory(new File("D:\\JAVA\\IDEAProject\\MusicPlayer\\src\\music"));

        nameLabel = new JLabel("歌曲名称");
        timeLabel = new JLabel("00:00 / 00:00");
        lyricLabel = new JLabel();

        // 创建面板并添加按钮
        JPanel buttonPanel = new JPanel();
        buttonPanel.add(playButton);
        buttonPanel.add(pauseButton);
        buttonPanel.add(stopButton);

        //
        JPanel selectFilePanel = new JPanel();
        selectFilePanel.setPreferredSize(new Dimension(400, 200));
        selectFilePanel.setVisible(true);
        selectFilePanel.setLayout(null);
        openButton.setBounds(20, 20, 90, 30);
        lyricButton.setBounds(150, 20, 90, 30);
        selectFilePanel.add(openButton);
        selectFilePanel.add(lyricButton);


        JPanel infoPanel = new JPanel();
        infoPanel.setLayout(new GridLayout(3, 1));
        infoPanel.add(nameLabel);
        infoPanel.add(timeLabel);
        infoPanel.add(lyricLabel);


        // 将面板添加到窗口
        Container contentPane = getContentPane();
        contentPane.add(buttonPanel, BorderLayout.SOUTH);
        contentPane.add(selectFilePanel, BorderLayout.NORTH);
        contentPane.add(infoPanel, BorderLayout.CENTER);
        contentPane.setLocation(800, 500);

        pack();

        this.setVisible(true);



        //创建定时器
        timer = new Timer(500, new ActionListener() {
   


            @Override
            public void actionPerformed(ActionEvent e) {
   



                if (clip != null && clip.isRunning()) {
   

                    long position = clip.getMicrosecondPosition() / 1000;
                    long duration = clip.getMicrosecondLength();

                    String timeStr = formatTime(position) + "/" + formatTime(duration);

                    timeLabel.setText(timeStr);

                    /*long time1 = 0, time = 0,time2 = 0,time3 = 0;

                        time1 = Long.parseLong(timeParts[0]) * 60 * 1000;
                        time2 = Long.parseLong(timeParts[1]) * 1000;
                        time3 = Long.parseLong(timeParts[2]);

                        time =  ( time1 + time2 + time3);*/


                    if(flag){
   
                        // 将Map转换为List
                        List<Map.Entry<Long, String>> list = new ArrayList<>(lyricMap.entrySet());

                        // 对List进行排序
                        Collections.sort(list,new Comparator< Map.Entry< Long,String>>(){
   

                            @Override
                            public int compare(Map.Entry<Long, String> o1, Map.Entry<Long, String> o2) {
   
                                return o1.getKey().compareTo(o2.getKey());
                            }
                        });


                        // 将排序后的List转换为Map
                        sortedMap = new LinkedHashMap<>();
                        for (Map.Entry<Long, String> entry : list) {
   
                            sortedMap.put(entry.getKey(), entry.getValue());
                        }

                        flag = false;

                    }


                    long time1 = 0,time2 = 0;

                    //查找当前时间对应的歌词
                    if (sortedMap != null) {
   

                        for(Map.Entry<Long,String> entry : sortedMap.entrySet()){
   

                            if(count == 3){
   
                                count = 1;
                                break;
                            }

                            if(count == 1){
   
                                time1 = entry.getKey();
                                count++;
                                continue;
                            }
                            if (count == 2) {
   
                                time2 = entry.getKey();
                                count++;
                                continue;
                            }


                        }



                        String lyric = sortedMap.get(time1);
                        sortedMap.remove(time1);

                        if (lyric == null) {
   
                            lyric = "  ";
                        }

                        lyricLabel.setText(lyric);


                        try {
   

                            if (time1 < 1000) {
   
                                Thread.sleep(time2 - time1);
                            }
                            else {
   
                                Thread.sleep(time2 - time1);
                            }

                        } catch (InterruptedException interruptedException) {
   
                            interruptedException.printStackTrace();
                        }



                    }


                }
            }
        });
    }


    @Override
    public void actionPerformed(ActionEvent e) {
   



        class LyricMap <K> implements Map<Long, String> {
   


            private HashMap<Long,String> map;

            public LyricMap(){
   
                map = new HashMap<Long, String>();
            }

            @Override
            public int size() {
   
                return map.size();
            }

            @Override
            public boolean isEmpty() {
   
                return map.isEmpty();
            }

            @Override
            public boolean containsKey(Object key) {
   
                return map.containsKey(key);
            }

            @Override
            public boolean containsValue(Object value) {
   
                return map.containsValue(value);
            }

            @Override
            public String get(Object key) {
   
                return map.get(key);
            }

            @Override
            public String put(Long key, String value) {
   
                return map.put(key,value);
            }


            @Override
            public String remove(Object key) {
   
                return map.remove(key);
            }

            @Override
            public void putAll(Map<? extends Long, ? extends String> m) {
   
                map.putAll(m);
            }

            @Override
            public void clear() {
   
                map.clear();
            }

            @Override
            public Set<Long> keySet() {
   
                return map.keySet();
            }

            @Override
            public Collection<String> values() {
   
                return map.values();
            }

            @Override
            public Set<Entry<Long, String>> entrySet() {
   
                return map.entrySet();
            }

        }



        if (e.getSource() == openButton) {
   

            // 显示文件选择器
            int resultSing = fileChooser.showOpenDialog(this);
            if (resultSing == JFileChooser.APPROVE_OPTION) {
   

                // 获取用户选择的文件
                File selectedFile = fileChooser.getSelectedFile();

                try {
   

                    // 创建音频输入流
                    AudioInputStream audioInputStream = AudioSystem.getAudioInputStream(selectedFile);

                    AudioFormat format = audioInputStream.getFormat();

                    DataLine.Info info = new DataLine.Info(Clip.class, format);
                    // 创建音频剪辑
                    clip = (Clip) AudioSystem.getLine(info);
                    // 打开音频剪辑
                    clip.open(audioInputStream);

                    //更新标签内容
                    nameLabel.setText("歌曲名称   " + selectedFile.getName());
                    timeLabel.setText("00:00/   " + formatTime(clip.getMicrosecondLength()));


                    int resultLyric = lyricChooser.showOpenDialog(this);

                    if (resultLyric == JFileChooser.APPROVE_OPTION) {
   
                        // 获取用户选择的文件
                        lyricFile = lyricChooser.getSelectedFile();
                    }

                    if (lyricFile.exists()) {
   
                        BufferedReader reader = new BufferedReader(new FileReader(lyricFile));

                        lyricMap = new LyricMap<>();
                        timeList = new ArrayList<>();
                        lyricList = new ArrayList<>();

                        String line;

                        while ((line = reader.readLine()) != null) {
   

                            String[] parts = line.split("\\]|\\[");

                            int partslength = parts.length;

                            for (int i = 1; i < partslength; i += 2) {
   

                                String timeStr = parts[i].substring(1);

                                if (" ".equals(timeStr)){
   
                                    continue;
                                }

                                String[] timeParts = timeStr.split("[:.]");

                                if (timeParts.length == 3) {
   

                                    long time1 = 0, time = 0,time2 = 0,time3 = 0;


                                    try {
   

                                        time1 = Long.parseLong(timeParts[0]) * 60 * 1000;
                                        time2 = Long.parseLong(timeParts[1]) * 1000;
                                        time3 = Long.parseLong(timeParts[2]);

                                        time =  ( time1 + time2 + time3);

                                        if (time != 0) {
   
                                            timeList.add(time);
                                            lyricList.add(parts[i+1]);
                                        }



                                       /* lyricMap.put(time,parts[i + 1]);*/


                                    } catch (Exception e1) {
   
                                        // 处理异常,例如输出错误信息或设置默认值
                                        System.err.println("Invalid time string: " + time);
                                        time = -1;
                                        // 设置默认值为-1
                                    }

                                   /* timeList.add(time);
                                    lyricList.add(parts[i+1]);*/
                                }

                            }

                        }

                        reader.close();

                        /**
                         * put() 方法用于将键值对插入到 lyricMap 中。
                         * 在这里,timeList.get(i) 是获取第 i 个时间戳,
                         * lyricList.get(i) 是获取第 i 个歌词内容,然后将它们作为键值对插入到 lyricMap 中。
                         */

                      for (int i = 0; i < timeList.size(); i++) {
   

                          lyricMap.put(timeList.get(i),lyricList.get(i));

                      }


                    }

                    timer.start();

                } catch (UnsupportedAudioFileException | IOException | LineUnavailableException ex) {
   
                    JOptionPane.showMessageDialog(this, "无法打开文件:" + ex.getMessage(), "错误", JOptionPane.ERROR_MESSAGE);
                }
            }
        } else if (e.getSource() == playButton) {
   
            // 播放音频剪辑
            if (clip != null) {
   
                clip.start();
            }
        } else if (e.getSource() == pauseButton) {
   
            // 暂停音频剪辑
            if (clip != null) {
   
                clip.stop();
            }
        } else if (e.getSource() == stopButton) {
   
            // 停止音频剪辑
            if (clip != null) {
   
                clip.stop();
                clip.setFramePosition(0);
                //clip.setFramePosition(0)的意思是将音频剪辑的帧位置设置为0,也就是从音频剪辑的开头开始播放。
                //
                //这个方法通常用于重复播放音频剪辑,当音频剪辑播放完成后,我们可以使用该方法将帧位置重置为0,从而实现循环播放的效果。
                lyricLabel.setText("歌词");
            }
        }

    }


    /**
     * 将时间(以微秒为单位)格式化为字符串
     *
     * @param time 时间(以微秒为单位)
     * @return 格式化后的字符串(格式为“mm:ss”)
     */

    private String formatTime(long time) {
   
        SimpleDateFormat formatter = new SimpleDateFormat("mm:ss");
        return formatter.format(time / 1000);
    }




}

测试

package MusicPlayer;

import com.musicplayer.MusicUI;

/**
 * @author WangYH
 * @version 2021.1.3
 * @date 2023/6/2 22:08
 */

public class MusicplayTest {
   

    public static void main(String[] args) {
   

        MusicPlayer musicPlayer = new MusicPlayer();
        musicPlayer.setVisible(true);

    }
}

转换歌词

package com.musicplayer;

import java.io.*;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList;
import java.util.Map;
import java.util.TreeMap;

/**
 * @author WangYH
 * @version 2021.1.3
 * @date 2023/6/2 20:18
 */

public class LrcParser {
   

    private Map<Long, String> lyricMap;
    private ArrayList<Long> timeList;
    private ArrayList<String> lyricList;

    public LrcParser() {
   
        lyricMap = new TreeMap<>();
        timeList = new ArrayList<>();
        lyricList = new ArrayList<>();
    }


    public void readLyricFile(String filePath) {
   

        try {
   

            BufferedReader reader = new BufferedReader(new FileReader(filePath));

            String line;

            while ((line = reader.readLine()) != null) {
   

                String[] parts = line.split("\\]|\\[");

                int partslength = parts.length;

                for (int i = 1; i < partslength; i+=2){
   
                    String timeStr = parts[i].substring(1);

                    String[] timeParts = timeStr.split("[:.]");

                    if (timeParts.length == 3) {
   

                        long time1 = 0,time = 0,time2 = 0,time3 = 0;

                        try {
   

                            time1 = Long.parseLong(timeParts[0]) * 60 * 1000;
                            time2 = Long.parseLong(timeParts[1]) * 1000;
                            time3 = Long.parseLong(timeParts[2]);

                            time =  ( time1 + time2 + time3);

                            lyricMap.put(time,parts[i + 1]);


                        }catch (Exception e){
   
                            // 处理异常,例如输出错误信息或设置默认值
                            System.err.println("Invalid time string: " + time);
                            time = -1;
                            // 设置默认值为-1
                        }

                        /*timeList.add(time);
                        lyricList.add(parts[i+1]);*/

                    }

                }

            }



            reader.close();

/*
            for (int i = 0; i < timeList.size(); i++) {
                lyricMap.put(timeList.get(i), lyricList.get(i));
            }*/


        } catch (IOException e) {
   
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
   
        LrcParser parser = new LrcParser();
        parser.readLyricFile("D:\\JAVA\\IDEAProject\\MusicPlayer\\src\\music\\我的名字 - 焦迈奇.lrc");


        try {
   
            Thread.sleep(2000);
        } catch (InterruptedException e) {
   
            e.printStackTrace();
        }

        /*parser.lyricMap.forEach((Key, value) -> System.out.println(Key + ":" + value));*/
/*
        for (Map.Entry<Long, String> entry : parser.lyricMap.entrySet()) {
            Long key = entry.getKey();
            String value = entry.getValue();
            System.out.println(key + ": " + value);
        }*/



        PrintWriter writer = new PrintWriter(new OutputStreamWriter(System.out, StandardCharsets.UTF_8), true);
        parser.lyricMap.forEach((key, value) -> writer.println(key + ": " + value));



    }




}

就先这样吧,以后有时间再来写,现在换个项目写算了。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
17天前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
53 14
|
18天前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
35 9
|
1月前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
151 26
|
1月前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
2月前
|
关系型数据库 MySQL Java
MySQL索引优化与Java应用实践
【11月更文挑战第25天】在大数据量和高并发的业务场景下,MySQL数据库的索引优化是提升查询性能的关键。本文将深入探讨MySQL索引的多种类型、优化策略及其在Java应用中的实践,通过历史背景、业务场景、底层原理的介绍,并结合Java示例代码,帮助Java架构师更好地理解并应用这些技术。
85 2
|
2月前
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
3月前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
338 6
|
20小时前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
5天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
63 0
|
1月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
63 3