📄 report.java
字号:
package main;
import java.awt.*;
import javax.swing.*;
import javax.swing.border.*;
import javax.swing.tree.*;
import javax.swing.event.*;
import java.awt.event.*;
import java.io.*;
import main.myClass.*;
public class Report extends JFrame{
JSplitPane splitPane = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT);
JEditorPane edit=new JEditorPane();
DefaultMutableTreeNode top=new DefaultMutableTreeNode("排序方法");
JTree tree=new JTree(top);
private String[] name;
public Report(myHashtable algorithm){
setTitle("课程设计报告");
edit.setEditable(false);
edit.setFont(new Font("宋体",0,14));
splitPane.setDividerLocation(0.3d);
init(algorithm);
tree.addTreeSelectionListener(new TreeSelectionListener() {
public void valueChanged(TreeSelectionEvent e) {
DefaultMutableTreeNode node = (DefaultMutableTreeNode)
tree.getLastSelectedPathComponent();
if(node==null) return;
if(node.isLeaf()){
String parent=node.getParent().toString();
if(node.getUserObject().equals("算法描述")){
try{
FileReader temp=new FileReader("./main/Report/"+parent+"Alg.txt");
edit.read(temp,null);
temp.close();
}
catch(Exception f){f.printStackTrace();}
}
else if(node.getUserObject().equals("排序评价")){
try{
FileReader temp=new FileReader("./main/Report/"+parent+"Comp.txt");
edit.read(temp,null);
temp.close();
}
catch(Exception f){f.printStackTrace();}
}
else if(node.getUserObject().equals("源代码")){
try{
FileReader temp=new FileReader("./main/Report/"+parent+"Code.txt");
edit.read(temp,null);
temp.close();
}
catch(Exception f){f.printStackTrace();}
}
}
else return;
}
});
splitPane.setLeftComponent(new JScrollPane(tree));
splitPane.setRightComponent(new JScrollPane(edit));
getContentPane().add(splitPane,BorderLayout.CENTER);
}
public void addNode(DefaultMutableTreeNode top,String[] son){
for(int i=0;i<son.length;i++){
DefaultMutableTreeNode temp=new DefaultMutableTreeNode(son[i]);
DefaultMutableTreeNode suanfa=new DefaultMutableTreeNode("算法描述");
DefaultMutableTreeNode code=new DefaultMutableTreeNode("源代码");
DefaultMutableTreeNode complication=new DefaultMutableTreeNode("排序评价");
temp.add(suanfa);
temp.add(code);
temp.add(complication);
top.add(temp);
}
}
public void init(myHashtable algorithm){
name=new String[algorithm.size()];
top.removeAllChildren();
for(int i=0;i<algorithm.size();i++)
name[i]=algorithm.getKey(i);
addNode(top,name);
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -