MarchQRShow

 

FileDepart
package march.io;

import java.io.*;

public class FileDepart {

    public static void main(String[] args) throws Exception{
        String sourceFile = "C:\\Users\\Administrator\\Desktop\\xpath\\run.zip";
        String descDir = "C:\\Users\\Administrator\\Desktop\\xpath\\runDepart";
        int blockSize = 512;

        byte[] fileData = readFile(sourceFile);
        int eIndex = 0;int sIndex = 0;int fileName = 0;
        while (eIndex!=fileData.length-1){
            fileName++;
            eIndex = fileName*blockSize-1;
            if(eIndex>fileData.length-1){
                eIndex=fileData.length-1;
            }
            byte[] outputData = new byte[eIndex-sIndex+1];
            for(int i=0;i<outputData.length;i++){
                outputData[i] = fileData[sIndex+i];
            }
            System.out.println((fileData.length-1)+" "+eIndex);
            writeFileBlock(descDir,fileName,outputData);
            sIndex= eIndex+1;
        }
    }

    public static byte[] readFile(String fileName) throws Exception{
        FileInputStream fileInputStream = new FileInputStream(fileName);
        DataInputStream dataInputStream = new DataInputStream(fileInputStream);
        byte[] res = new byte[dataInputStream.available()];
        dataInputStream.readFully(res);
        fileInputStream.close();
        return res;
    }

    public static void writeFileBlock(String savePath,int blockName,byte[] data) throws Exception{
        String fileString = blockName+" "+bytesToHexString(data);

        File file = new File(savePath+"/"+blockName+".txt");
        if(!file.exists()){
            file.createNewFile();
        }
        FileWriter fileWriter = new FileWriter(file);
        BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);
        bufferedWriter.write(fileString);
        bufferedWriter.close();
    }

    public static String bytesToHexString(byte[] src){
        StringBuilder stringBuilder = new StringBuilder("");
        if (src == null || src.length <= 0) {
            return null;
        }
        for (int i = 0; i < src.length; i++) {
            int v = src[i] & 0xFF;
            String hv = Integer.toHexString(v);
            if (hv.length() < 2) {
                stringBuilder.append(0);
            }
            stringBuilder.append(hv);
        }
        return stringBuilder.toString();
    }

    public static byte[] hexStringToBytes(String hexString) {
        if (hexString == null || hexString.equals("")) {
            return null;
        }
        hexString = hexString.toUpperCase();
        int length = hexString.length() / 2;
        char[] hexChars = hexString.toCharArray();
        byte[] d = new byte[length];
        for (int i = 0; i < length; i++) {
            int pos = i * 2;
            d[i] = (byte) (charToByte(hexChars[pos]) << 4 | charToByte(hexChars[pos + 1]));
        }
        return d;
    }

    private static byte charToByte(char c) {
        return (byte) "0123456789ABCDEF".indexOf(c);
    }
}
QRShow
package march.io;

import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.client.j2se.MatrixToImageWriter;
import com.google.zxing.common.BitMatrix;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
import java.awt.image.BufferedImage;
import java.io.*;
import java.util.HashMap;
import java.util.Map;

public class QRShow extends JFrame {
    private String _sourcePath;
    private int _qrCodeSizeW = 800;
    private int _qrCodeSizeH = 800;
    JTextField textField = new JTextField("0",20);
    ImagePanel imagePanel = null;

    public static void main(String[] args){
        String sourcePath ="C:\\Users\\Administrator\\Desktop\\xpath\\runDepart";
        int qrCodeSizeW = 1000;
        int qrCodeSizeH = 1000;
        QRShow q = new QRShow(sourcePath,qrCodeSizeW,qrCodeSizeH);
    }

    public QRShow(String sourcePath,int qrCodeSizeW,int qrCodeSizeH){
        this._sourcePath = sourcePath;
        this._qrCodeSizeW = qrCodeSizeW;
        this._qrCodeSizeH = qrCodeSizeH;
        imagePanel = new ImagePanel(this);
        init();
        this.setSize(new Dimension(800,600));
        this.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
        this.setVisible(true);
    }

    public void init(){
        this.setLayout(new BorderLayout(10,5));
        JPanel panel = new JPanel();
        panel.setLayout(new GridLayout(20,1));
        final JButton btnNext = new JButton("->");
        final JButton btnPre = new JButton("<-");
        panel.add(textField);
        panel.add(btnPre);
        panel.add(btnNext);
        this.add(panel,BorderLayout.EAST);
        this.add(imagePanel,BorderLayout.CENTER);
        Toolkit.getDefaultToolkit().addAWTEventListener(new AWTEventListener() {
            public void eventDispatched(AWTEvent event) {
                if(event.getID()==KeyEvent.KEY_PRESSED){
                    switch (((KeyEvent)event).getKeyCode()) {
                        case KeyEvent.VK_RIGHT:
                            btnNext.doClick();
                            break;
                        case KeyEvent.VK_LEFT:
                            btnPre.doClick();
                            break;
                    }
                }
            }
        }, AWTEvent.KEY_EVENT_MASK);

        btnNext.addActionListener(new ActionListener() {
            public void actionPerformed(ActionEvent e) {
                showQr(true);
            }
        });
        btnPre.addActionListener(new ActionListener() {
            public void actionPerformed(ActionEvent e) {
                showQr(false);
            }
        });
    }

    public void showQr(boolean next){
        try{
            int blockName = Integer.parseInt(this.textField.getText());
            blockName = next?(blockName+1):(blockName-1);
            imagePanel.displayBlock(blockName);
            this.textField.setText(blockName+"");
        }catch (Exception e){
            //e.printStackTrace();
        }
    }

    public class ImagePanel extends JPanel{
        public Image image;
        private QRShow _qrShow;

        ImagePanel(QRShow qrShow){
            _qrShow = qrShow;
        }

        public void displayBlock(int blockName){
            String filePath = _sourcePath+"/"+blockName+".txt";
            File file = new File(filePath);
            if(file.exists()){
                try {
                    FileReader fileReader = new FileReader(file);
                    BufferedReader bufferedReader = new BufferedReader(fileReader);
                    String dataString = bufferedReader.readLine();
                    bufferedReader.close();
                    this.image = getBarCode(dataString);
                    this.repaint();
                    _qrShow.setTitle(blockName+"");
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }else{
                _qrShow.setTitle("-------");
            }
        }

        public Image getBarCode(String fileString){
            try {
                Map<EncodeHintType,String> map =new HashMap<EncodeHintType, String>();
                map.put(EncodeHintType.CHARACTER_SET,"UTF-8");
                map.put(EncodeHintType.MARGIN,"0");
                BitMatrix bitMatrix = new MultiFormatWriter().encode(fileString, BarcodeFormat.QR_CODE,_qrCodeSizeW,_qrCodeSizeH,map);
                BufferedImage bufferedImage = MatrixToImageWriter.toBufferedImage(bitMatrix);
                return bufferedImage;
            }catch (Exception e) {
                e.printStackTrace();
            }
            return null;
        }

        public void paint(Graphics graphics){
            super.paint(graphics);
            graphics.drawImage(image,0,0,this.getSize().height,this.getSize().height,null);
        }
    }
}

pom

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>march.io</groupId>
    <artifactId>march-qrcode</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>com.google.zxing</groupId>
            <artifactId>core</artifactId>
            <version>3.3.0</version>
        </dependency>
        <dependency>
            <groupId>com.google.zxing</groupId>
            <artifactId>javase</artifactId>
            <version>3.3.0</version>
        </dependency>
    </dependencies>
</project>

 

【路径规划】(螺旋)基于A星全覆盖路径规划研究(Matlab代码实现)内容概要:本文围绕“基于A星算法的全覆盖路径规划”展开研究,重点介绍了一种结合螺旋搜索策略的A星算法在栅格地图中的路径规划实现方法,并提供了完整的Matlab代码实现。该方法旨在解决移动机器人或无人机在未知或部分已知环境中实现高效、无遗漏的区域全覆盖路径规划问题。文中详细阐述了A星算法的基本原理、启发式函数设计、开放集与关闭集管理机制,并融合螺旋遍历策略以提升初始探索效率,确保覆盖完整性。同时,文档提及该研究属于一系列路径规划技术的一部分,涵盖多种智能优化算法与其他路径规划方法的融合应用。; 适合人群:具备一定Matlab编程基础,从事机器人、自动化、智能控制及相关领域研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于服务机器人、农业无人机、扫地机器人等需要完成区域全覆盖任务的设备路径设计;②用于学习和理解A星算法在实际路径规划中的扩展应用,特别是如何结合特定搜索策略(如螺旋)提升算法性能;③作为科研复现与算法对比实验的基础代码参考。; 阅读建议:建议结合Matlab代码逐段理解算法实现细节,重点关注A星算法与螺旋策略的切换逻辑与条件判断,并可通过修改地图环境、障碍物分布等方式进行仿真实验,进一步掌握算法适应性与优化方向。
内容概要:本文围绕基于MVC模式的JSP动态网页开发实战项目在毕业设计中的全栈应用展开,系统阐述了如何通过现代化开发实践提升毕业设计的技术深度与工程价值。文章以“导师双选系统”为例,详细展示了从需求分析、数据库设计、DAO与Service层实现(含事务与Redis缓存)、RESTful控制层到JSP视图层的完整开发流程,并强调前后端分离、代码生成、热部署与Docker一键部署等关键技术的应用。项目不仅实现了高并发下的冲突检测与抢选功能,还通过JMeter验证了系统的高性能与数据一致性,体现了工业级开发标准在教学场景中的可行性。; 适合人群:计算机相关专业本科或研究生,具备JavaWeb基础并正在进行毕业设计的学生,以及希望提升项目工程化水平的初学者; 使用场景及目标:①将传统“论文+截图”式毕业设计升级为可运行、可部署的全栈项目,增强答辩竞争力;②掌握MVC架构、JSP+Servlet+DAO协同开发、Redis缓存优化、RESTful接口设计与高并发处理等核心技术;③实现代码自动化生成与容器化部署,提升开发效率与系统可维护性; 阅读建议:建议结合文中提供的完整代码案例动手实践,重点理解DAO层乐观锁、Service层事务控制与缓存策略、前端异步交互机制,并尝试扩展为Spring Boot或前后端分离架构,深入体会从学术项目向工业级系统演进的设计思路。
内容概要:本文介绍了一套基于MATLAB实现的无人机三维路径规划解决方案,融合灰狼优化算法(GWO)与B样条曲线技术,在复杂三维环境中生成安全、平滑且高效的飞行路径。系统首先通过模拟生成包含风速、障碍密度、通信干扰等多种环境因素的5万条数据,训练路径代价预测模型(采用岭回归与回归树对比选优),随后构建含8个球形障碍物的三维空间环境,利用灰狼算法优化B样条控制点,以最小化路径长度、平滑度、避障惩罚和安全裕度等综合代价函数。整个流程涵盖参数设置、模型训练、路径优化、代价预测与多维度可视化评估,提供了带详细注释和简洁版的双版本代码,支持一键运行并输出丰富的评估图表。; 适合人群:具备一定MATLAB编程基础,熟悉基本优化算法和路径规划概念的科研人员、研究生及无人机相关领域的工程技术人员,尤其适合从事智能优化、机器人导航或空中交通规划的研究与开发人员。; 使用场景及目标:①应用于复杂三维环境下的无人机自主导航路径规划;②研究和对比灰狼优化算法在路径优化中的性能;③学习如何将机器学习模型融入路径代价评估;④掌握B样条曲线在轨迹平滑处理中的应用;⑤通过可视化结果分析算法收敛性与路径质量。; 其他说明:代码已调试成功,支持自由调节灰狼数量、迭代次数、控制点数等参数,平衡精度与运行时间。提供模拟数据生成、模型训练、路径优化与多图评估全流程,注释详尽,便于理解与二次开发。
基于密集型复杂城市场景下求解无人机三维路径规划的Q-learning 算法研究(Matlab代码实现)内容概要:本文围绕密集型复杂城市场景下的无人机三维路径规划问题,提出并实现了基于Q-learning算法的解决方案,并提供了完整的Matlab代码实现。研究重点在于利用强化学习技术,在高动态、高障碍密度的城市环境中为无人机规划出安全、高效的飞行路径。文中详细阐述了环境建模、状态空间与动作空间设计、奖励机制构建以及Q-learning训练过程等关键环节,展示了算法在避障、路径优化和适应复杂地形方面的有效性。此外,文档还附带多个相关科研方向的技术资源链接,涵盖路径规划、无人机协同、智能优化算法等领域,突出其实用性和科研参考价值。; 适合人群:具备一定Matlab编程基础,对人工智能、强化学习、路径规划或无人机控制感兴趣的高校学生、科研人员及工程技术人员,尤其适合从事智能交通、无人系统或自动化相关研究的1-3年经验研究人员。; 使用场景及目标:①学习和掌握Q-learning在三维路径规划中的具体应用方法;②复现并改进复杂城市环境下无人机避障与导航算法;③作为智能优化算法在实际工程问题中落地的参考案例,支撑科研项目开发或论文撰写; 阅读建议:建议结合提供的Matlab代码进行实践操作,逐步调试算法模块,深入理解状态转移与奖励函数的设计逻辑。同时可参考文档中列出的其他路径规划与优化资源,拓展对多智能体协同、动态环境决策等问题的认知。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值