如果将文本换行设置为关闭,那么这当然是一件小事,因为可以通过计算换行符的数量来轻松计算行数。不幸的是,当启用文本换行时,似乎没有任何明显的和非杂乱的方法来执行此操作,除了在初始化框时实际在每行的末尾添加换行符。
到目前为止,这就是我解决问题的方法,但是这是非常不受欢迎的,因为在很多情况下,它会在一个单词的中间插入换行符,当然,这个解决方案很复杂而且很混乱。有没有人有什么建议?如果我将文本区域包装在文本流容器中,是否有办法解决这个问题?
答案 0 :(得分:0)
我遇到了同样的问题。经过一番挖掘,我发现this thread有你想要的答案。
它使用Label
来保存TextArea
的文本,并在标签高度更改时更新其高度。这是一个完整的演示:
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.geometry.Insets;
import javafx.geometry.Pos;
import javafx.scene.GroupBuilder;
import javafx.scene.control.Label;
import javafx.scene.control.TextArea;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.StackPaneBuilder;
public class ScrollFreeTextArea extends StackPane{
private Label label;
private StackPane lblContainer ;
private TextArea textArea;
private Character NEW_LINE_CHAR = new Character((char)10);
private final double NEW_LINE_HEIGHT = 18D;
private final double TOP_PADDING = 3D;
private final double BOTTOM_PADDING = 6D;
public ScrollFreeTextArea(){
super();
configure();
}
public ScrollFreeTextArea(String text){
super();
configure();
textArea.setText(text);
}
private void configure(){
setAlignment(Pos.TOP_LEFT);
this.textArea =new TextArea();
this.textArea.setWrapText(true);
this.textArea.getStyleClass().add("scroll-free-text-area");
this.label =new Label();
this.label.setWrapText(true);
this.label.prefWidthProperty().bind(this.textArea.widthProperty());
this.label.textProperty().bind(this.textArea.textProperty());
this.lblContainer = StackPaneBuilder.create()
.alignment(Pos.TOP_LEFT)
.padding(new Insets(4,7,7,7))
.children(label)
.build();
// Binding the container width to the TextArea width.
lblContainer.maxWidthProperty().bind(textArea.widthProperty());
textArea.textProperty().addListener(new ChangeListener<String>() {
@Override
public void changed(ObservableValue<? extends String> paramObservableValue, String paramT1, String value) {
layoutForNewLine(textArea.getText());
}
});
label.heightProperty().addListener(new ChangeListener<Number>() {
@Override
public void changed(ObservableValue<? extends Number> paramObservableValue, Number paramT1, Number paramT2) {
layoutForNewLine(textArea.getText());
}
});
getChildren().addAll(GroupBuilder.create().children(lblContainer).build(),textArea);
}
private void layoutForNewLine(String text){
if(text!=null && text.length()>0 &&
((Character)text.charAt(text.length()-1)).equals(NEW_LINE_CHAR)){
textArea.setPrefHeight(label.getHeight() + NEW_LINE_HEIGHT + TOP_PADDING + BOTTOM_PADDING);
textArea.setMinHeight(label.getHeight() + NEW_LINE_HEIGHT + TOP_PADDING + BOTTOM_PADDING);
}else{
textArea.setPrefHeight(label.getHeight() + TOP_PADDING + BOTTOM_PADDING);
textArea.setMinHeight(label.getHeight() + TOP_PADDING + BOTTOM_PADDING);
}
}
}
答案 1 :(得分:0)
来自TextArea
TextArea textArea = new TextArea();
采取文字
String toCount = textArea.getText();
将其拆分为行
String[] lineArray = toCount.split("\n");
指数0到lineArray.length -1
是您的行 - 其中lineArray.length -1
是您的总数。
如果您希望它们可见,您如何插入行计数是另一回事。