- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
今天编码时遇到了一个小问题。我不是java专家,而且我才刚刚开始学习GUI,所以请耐心等待。
我正在创建一个游戏,其中涉及由该 2D 数组组成的 map ,我创建了一种方法将该 2D 数组放入 textArea 中。
public void viewMap(String[][] matrix)
{
for (int r = 0; r < matrix.length; r++) {
for (int c = 0; c < matrix[0].length; c++)
{
textArea.setText(textArea.getText() + "\t" + String.valueOf(matrix[r][c]));
}
textArea.setText(textArea.getText() + "\n" );
}
}
如果您注意到我用来分隔每个元素的“\t”。这对于均匀间隔来说效果很好,但空间非常大。我的数组结果是这样的:
x H f f x x
x f x f D x
x x x x x x
这种间距很好,因为不同的字母不会偏移其他字母的位置,但对于我的目的来说,它太大了,但如果我简单地用几个空格代替“\t”,我会得到有些东西不像我使用/t 时那样排列,而是不同大小的字母会导致行的其余部分困惑。
所以我想知道是否有人可以帮助我想出一个解决方案,以便在打印时均匀地间隔这些字母。我非常感谢任何反馈和帮助。
谢谢。
最佳答案
文本组件并没有很好地设计用于以这种方式格式化数据(至少不是设计用于显示纯文本的组件)。
例如,您可以使用 JTable
...
import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.EventQueue;
import java.awt.Graphics;
import java.awt.Graphics2D;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import javax.swing.table.DefaultTableModel;
public class Test {
public static void main(String[] args) {
new Test();
}
public Test() {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
ex.printStackTrace();
}
JFrame frame = new JFrame("Testing");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(new TestPane());
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
});
}
public class TestPane extends JPanel {
public TestPane() {
setLayout(new BorderLayout());
String[][] matrix = new String[][]{
{"x", "H", "f", "f", "x", "x"},
{"x", "f", "x", "f", "D", "x"},
{"x", "H", "f", "f", "x", "x"},
};
DefaultTableModel model = new DefaultTableModel(0, 6);
for (String[] row : matrix) {
model.addRow(row);
}
JTable table = new JTable(model) {
@Override
protected void configureEnclosingScrollPane() {
}
};
table.setShowGrid(false);
table.setIntercellSpacing(new Dimension(0, 0));
add(new JScrollPane(table));
}
}
}
如果您不需要编辑值或需要任何真正奇特的东西(例如选择),您可以使用 JLabel
并将文本包装在 HTML TABLE 中...
setLayout(new GridBagLayout());
String[][] matrix = new String[][]{
{"x", "H", "f", "f", "x", "x"},
{"x", "f", "x", "f", "D", "x"},
{"x", "H", "f", "f", "x", "x"},
};
JLabel label = new JLabel();
StringBuilder sb = new StringBuilder("<html>");
sb.append("<table boder=0>");
for (String[] row : matrix) {
sb.append("<tr>");
for (String col : row) {
sb.append("<td align=center>").append(col).append("</td>");
}
sb.append("</tr>");
}
sb.append("</table>");
label.setText(sb.toString());
add(label);
而且...如果您“真的”想使用文本组件,那么像 JEditorPane
这样的组件可能是更好的选择,因为您无需担心等宽字体...
setLayout(new BorderLayout());
String[][] matrix = new String[][]{
{"x", "H", "f", "f", "x", "x"},
{"x", "f", "x", "f", "D", "x"},
{"x", "H", "f", "f", "x", "x"},};
JLabel label = new JLabel();
StringBuilder sb = new StringBuilder("<html><body>");
sb.append("<table boder=0>");
for (String[] row : matrix) {
sb.append("<tr>");
for (String col : row) {
sb.append("<td align=center>").append(col).append("</td>");
}
sb.append("</tr>");
}
sb.append("</table></body></html>");
JEditorPane ep = new JEditorPane();
ep.setContentType("text/html");
ep.setText(sb.toString());
add(new JScrollPane(ep));
关于java - 如何在 JTextArea 中均匀地分隔二维数组而不使用\t?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28444279/
我需要在半径R的圆内生成一个均匀随机点。 我意识到,通过在区间 [0 ... 2π) 中选择均匀随机的角度,并在区间 (0 ... R) 中选择均匀随机的半径,我最终会得到更多的点朝向中心,因为对于两
我想在一个正方形内生成 N 个点(均匀地)。我怎样才能做到这一点? 最佳答案 非常酷的问题,比我想象的要困难得多,但这就是想法。有关于 n 边形的论文,但我只会做正方形。因此,圆的均匀分布是一个常见问
考虑以下示例: import itertools import numpy as np a = np.arange(0,5) b = np.arange(0,3) c = np.arange(0,7)
SQL Server 将一组值分成 5 组,每组的 sum(count) 应该均匀分布。 表仅包含 2 列 rid 和 count。 create table t1(rid int, count in
我有以下简单的 HTML。 A B C 和 CSS: ul { width: 100%; display: flex; flex-direction:
我是一名优秀的程序员,十分优秀!