Javascript を使用せずに JavaFX からのコピー、強調表示、および編集を無効にする場合、イベントをトラップしてそれに応じて処理し、残りのオプションはそのままにしておく方法があります。
イベント ディスパッチャーを使用して、いくつかのイベントをフィルター処理してみましょう。
主なイベント:
- Ctrl+C または Ctrl+Insert によるコピーを避ける
- Shift+矢印で選択を避ける
マウス イベントの場合:
- マウスクリックによる単語、行、段落の選択を避ける
- マウスのドラッグによる選択を回避しますが、スクロールバーのドラッグは許可します
(必要に応じて他にも追加できます)
public class WebEventDispatcher implements EventDispatcher {
private final EventDispatcher oldDispatcher;
private Point2D limit;
public WebEventDispatcher(EventDispatcher oldDispatcher) {
this.oldDispatcher = oldDispatcher;
}
public void setLimit(Point2D limit){
this.limit = limit;
}
private boolean allowDrag=false;
@Override
public Event dispatchEvent(Event event, EventDispatchChain tail) {
if (event instanceof MouseEvent){
MouseEvent m = (MouseEvent)event;
if (event.getEventType().equals(MouseEvent.MOUSE_CLICKED) ||
event.getEventType().equals(MouseEvent.MOUSE_PRESSED)) {
Point2D origin=new Point2D(m.getX(),m.getY());
allowDrag=!(origin.getX()<limit.getX() && origin.getY()<limit.getY());
}
// avoid selection with mouse dragging, allowing dragging the scrollbars
if (event.getEventType().equals(MouseEvent.MOUSE_DRAGGED)) {
if(!allowDrag){
event.consume();
}
}
// Avoid selection of word, line, paragraph with mouse click
if(m.getClickCount()>1){
event.consume();
}
}
if (event instanceof KeyEvent && event.getEventType().equals(KeyEvent.KEY_PRESSED)){
KeyEvent k= (KeyEvent)event;
// Avoid copy with Ctrl+C or Ctrl+Insert
if((k.getCode().equals(KeyCode.C) || k.getCode().equals(KeyCode.INSERT)) && k.isControlDown()){
event.consume();
}
// Avoid selection with shift+Arrow
if(k.isShiftDown() && (k.getCode().equals(KeyCode.RIGHT) || k.getCode().equals(KeyCode.LEFT) ||
k.getCode().equals(KeyCode.UP) || k.getCode().equals(KeyCode.DOWN))){
event.consume();
}
}
return oldDispatcher.dispatchEvent(event, tail);
}
}
シーンで、コンテキスト メニューを無効にしてコピー/貼り付けオプションを回避し、スクロールバーのない Web ビューのコンテンツ領域を見つけ、カスタム イベント ディスパッチャーを設定します。
private Point2D pLimit;
private double width, height;
@Override
public void start(Stage primaryStage) {
WebView webView = new WebView();
WebEngine webEngine = webView.getEngine();
// disable context menu (copy option)
webView.setContextMenuEnabled(false);
WebEventDispatcher webEventDispatcher = new WebEventDispatcher(webView.getEventDispatcher());
webEngine.getLoadWorker().stateProperty().addListener(new ChangeListener<State>() {
@Override
public void changed(ObservableValue<? extends State> observable, State oldValue, State newValue) {
if(newValue.equals(State.SUCCEEDED)){
// dispatch all events
webView.setEventDispatcher(webEventDispatcher);
}
}
});
webEngine.load("<URL>");
Scene scene = new Scene(webView);
primaryStage.setTitle("WebView scrollbar test");
primaryStage.setScene(scene);
primaryStage.show();
webView.getChildrenUnmodifiable().addListener(new ListChangeListener<Node>() {
@Override
public void onChanged(Change<? extends Node> c) {
pLimit=webView.localToScene(webView.getWidth(),webView.getHeight());
webView.lookupAll(".scroll-bar").stream()
.map(s->(ScrollBar)s).forEach(s->{
if(s.getOrientation().equals(VERTICAL)){
width=s.getBoundsInLocal().getWidth();
}
if(s.getOrientation().equals(HORIZONTAL)){
height=s.getBoundsInLocal().getHeight();
}
});
// dispatch all events
webEventDispatcher.setLimit(pLimit.subtract(width, height));
}
});
}