我使用JEditorPane在swing应用程序中呈现一些HTML。我使用子弹点列表<ul><li>...</li></ul>
,我在输出中获得了过大的子弹点。相同的HTML块将在真实的浏览器中显示正常大小的项目符号。
我在Windows 7 / JDK 7和iirc上也在Ubuntu和OpenJDK 1.7.0_09上观察到了这一点。
这是否已知?有办法吗?
工作示例:
import javax.swing.JEditorPane;
import javax.swing.JFrame;
import javax.swing.WindowConstants;
/**
*
*/
public class HTMLTest {
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
// create new frame
JFrame frame = new JFrame();
frame.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE);
frame.setSize(500, 500);
// create editor pane and fill with some html
JEditorPane pane = new JEditorPane();
pane.setContentType("text/html");
pane.setEditable(false);
pane.setText("<html><h1>Heading</h1>Text<ul><li>Bullet point</li></ul></html>");
// add editor pane to frame and set frame visible
frame.add(pane);
frame.setVisible(true);
}
}
P.S。:我现在正在使用
ul {
list-style-type: none;
margin-left: 10px
}
在css文件中
<li>• Item 1</li>
在html中有一个不错的要点。解决方案受到aterai的启发。
答案 0 :(得分:6)
请参阅ListView源代码
public void paint(Graphics g, Shape allocation) {
super.paint(g, allocation);
Rectangle alloc = allocation.getBounds();
Rectangle clip = g.getClipBounds();
// Since listPainter paints in the insets we have to check for the
// case where the child is not painted because the paint region is
// to the left of the child. This assumes the ListPainter paints in
// the left margin.
if ((clip.x + clip.width) < (alloc.x + getLeftInset())) {
Rectangle childRect = alloc;
alloc = getInsideAllocation(allocation);
int n = getViewCount();
int endY = clip.y + clip.height;
for (int i = 0; i < n; i++) {
childRect.setBounds(alloc);
childAllocation(i, childRect);
if (childRect.y < endY) {
if ((childRect.y + childRect.height) >= clip.y) {
listPainter.paint(g, childRect.x, childRect.y,
childRect.width, childRect.height,
this, i);
}
}
else {
break;
}
}
}
}
listPainter将过去的参数用作
if (childtype == CSS.Value.SQUARE || childtype == CSS.Value.CIRCLE
|| childtype == CSS.Value.DISC) {
drawShape(g, childtype, (int) x, (int) y,
(int) w, (int) h, align);
}
并且drawShape正在跟随,因为你可以看到大小被硬编码为8
void drawShape(Graphics g, CSS.Value type, int ax, int ay, int aw,
int ah, float align) {
// Align to bottom of shape.
int gap = isLeftToRight ? - (bulletgap + 8) : (aw + bulletgap);
int x = ax + gap;
int y = Math.max(ay, ay + (int)(align * ah) - 8);
if (type == CSS.Value.SQUARE) {
g.drawRect(x, y, 8, 8);
} else if (type == CSS.Value.CIRCLE) {
g.drawOval(x, y, 8, 8);
} else {
g.fillOval(x, y, 8, 8);
}
}
您可以尝试在自己的画家提供的方法中替换StyleSheet的ListPainter
public ListPainter getListPainter(AttributeSet a) {
return new ListPainter(a, this);
}
您可以在其中更改项目符号的渲染
答案 1 :(得分:2)
+1 @StanislavL,这是另一个例子(使用css list-style-image属性):
bullet.png:
import java.awt.*;
import javax.swing.*;
import javax.swing.text.*;
import javax.swing.text.html.*;
public class HTMLTest2 {
public JComponent makeEditorPane(String bullet) {
// create editor pane and fill with some html
JEditorPane pane = new JEditorPane();
pane.setContentType("text/html");
pane.setEditable(false);
if(bullet!=null) {
HTMLEditorKit htmlEditorKit = (HTMLEditorKit)pane.getEditorKit();
StyleSheet styleSheet = htmlEditorKit.getStyleSheet();
//String u = getClass().getResource(bullet).toString();
String u = "http://i.stack.imgur.com/jV29K.png";
styleSheet.addRule(String.format("ul{list-style-image:url(%s);margin:0px 20px;", u));
//styleSheet.addRule("ul{list-style-type:circle;margin:0px 20px;}");
//styleSheet.addRule("ul{list-style-type:disc;margin:0px 20px;}");
//styleSheet.addRule("ul{list-style-type:decimal;margin:0px 20px;}");
}
pane.setText("<html><h1>Heading</h1>Text<ul><li>Bullet point</li></ul></html>");
return pane;
}
public JComponent makeUI() {
JPanel p = new JPanel(new GridLayout(2,1));
p.add(new JScrollPane(makeEditorPane(null)));
p.add(new JScrollPane(makeEditorPane("bullet.png")));
return p;
}
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
@Override public void run() {
createAndShowGUI();
}
});
}
public static void createAndShowGUI() {
JFrame f = new JFrame();
f.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
f.getContentPane().add(new HTMLTest2().makeUI());
f.setSize(320, 320);
f.setLocationRelativeTo(null);
f.setVisible(true);
}
}