我正在尝试使用Java中的动态文本区域创建简单的文本编辑器。
该应用程序开始时只有1个文本区域。每次按ENTER键,应用程序都会创建一个新的文本区域。这是工作!大声笑。但是,当我尝试更改上一个文本区域时,该文本区域未更改。问题是因为我以前的文本区域已经在容器中。因此,我的问题是我们如何更新容器中的所有文本区域?
看我的代码:
import javax.swing.*;
import javax.swing.text.*;
import java.awt.*;
import java.io.*;
import java.awt.event.*;
public class SimpleEditor extends JFrame {
int count = 0;
Container content = getContentPane();
private JTextComponent[] textComp;
public static void main(String[] args) {
SimpleEditor editor = new SimpleEditor();
editor.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
editor.setVisible(true);
}
// Create an editor.
public SimpleEditor() {
super("Swing Editor");
dinamicTA();
content.setLayout(new FlowLayout());
for(int i=0;i<count;i++) {
content.add(textComp[i]);
}
pack();
content.setSize(content.getPreferredSize());
pack();
}
//create DINAMIC TEXT AREA
public void dinamicTA () {
if(count==0) {
textComp = new JTextComponent[1];
textComp[0] = createTextComponent();
count+=1;
}
else {
JTextComponent[] texttemp;
texttemp = new JTextComponent[count];
for(int i=0;i<count;i++) {
texttemp[i] = createTextComponent();
}
count+=1;
textComp = new JTextComponent[count];
for(int i=0;i<count-1;i++) {
textComp[i] = createTextComponent();
//textComp[i].setText(texttemp[i].getText()+"wow"); <-- not working
}
textComp[count-1] = createTextComponent();
content.add(textComp[count-1]);
}
}
// Create the JTextComponent subclass.
protected JTextComponent createTextComponent() {
JTextArea ta = new JTextArea();
if (count%2==0)
ta.setForeground(Color.red);
else
ta.setForeground(Color.GREEN);
ta.setFont(new Font("Courier New",Font.PLAIN,12));
ta.setLineWrap(true);
ta.setWrapStyleWord(true);
ta.addKeyListener(new java.awt.event.KeyAdapter() {
public void keyReleased(java.awt.event.KeyEvent ev) {
taKeyReleased(ev);
}
});
ta.setColumns(15);
pack();
ta.setSize(ta.getPreferredSize());
pack();
return ta;
}
private void taKeyReleased(java.awt.event.KeyEvent ev) {
int key = ev.getKeyCode();
if (key == KeyEvent.VK_ENTER) {
dinamicTA();
pack();
content.setSize(content.getPreferredSize());
pack();
}
}
}
还有2个问题。每次按ENTER键,都会创建一个文本区域,而上一个文本区域会得到一个换行符。您是否有删除分隔线的想法?下一个问题:我按ENTER键而不单击新的文本区域后如何转到下一个文本区域?
抱歉,有太多问题..哈哈哈。谢谢:)
最佳答案
对于您的第一个问题,我将代码更改为
`
import javax.swing.*;
import javax.swing.text.*;
import java.awt.*;
import java.awt.event.*;
public class SimpleEditor extends JFrame {
/**
*
*/
private static final long serialVersionUID = 1L;
int count = 0;
Container content = getContentPane();
private JTextComponent[] textComp;
// Create an editor.
public SimpleEditor() {
super("Swing Editor");
dinamicTA();
content.setLayout(new FlowLayout());
for(int i=0;i<count;i++) {
content.add(textComp[i]);
}
pack();
content.setSize(content.getPreferredSize());
pack();
}
//create DINAMIC TEXT AREA
public void dinamicTA () {
if(count==0) {
textComp = new JTextComponent[1];
textComp[0] = createTextComponent();
count+=1;
}
else {
JTextComponent[] texttemp;
texttemp = textComp;
count+=1;
textComp = new JTextComponent[count];
for(int i=0;i<count-1;i++) {
textComp[i] = texttemp[i];
textComp[i].setText(textComp[i].getText()+"wow"); //<-- not working
}
textComp[count-1] = createTextComponent();
content.add(textComp[count-1]);
textComp[count-1].requestFocus(); //get focus
}
}
// Create the JTextComponent subclass.
protected JTextComponent createTextComponent() {
final JTextArea ta = new JTextArea();
if (count%2==0)
ta.setForeground(Color.red);
else
ta.setForeground(Color.GREEN);
ta.setFont(new Font("Courier New",Font.PLAIN,12));
ta.setLineWrap(true);
ta.setWrapStyleWord(true);
ta.addKeyListener(new java.awt.event.KeyAdapter() {
public void keyReleased(java.awt.event.KeyEvent ev) {
taKeyReleased(ev);
}
});
ta.setColumns(15);
pack();
ta.setSize(ta.getPreferredSize());
pack();
return ta;
}
private void taKeyReleased(java.awt.event.KeyEvent ev) {
int key = ev.getKeyCode();
if (key == KeyEvent.VK_ENTER) {
dinamicTA();
pack();
content.setSize(content.getPreferredSize());
pack();
}
}
public static void main(String[] args) {
SimpleEditor editor = new SimpleEditor();
editor.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
editor.setVisible(true);
}
}
`
我认为原始代码的问题是:每次添加新组件时,它都会丢失对先前组件的引用。