2015-04-15 90 views
0

現在我所得到的都是點,但沒有連接它們的線...... 我應該重新創建在切換之前初始化的原始「線」嗎?或者我應該不是要創建新的線條,而是重新修改原始線條?需要幫助繪製使用箭頭鍵的線段

public class DrawLineWithArrowKeys extends Application { 
    double bX = 150; 
    double bY = 150; 
    double eX = 150; 
    double eY = 150; 
    double segment = 20; 
@Override 
public void start(Stage primaryStage) { 
Pane myPane = new Pane(); 

Line line = new Line(bX,bY,eX,eY); 
line.setStrokeWidth(2); 
line.setStroke(Color.RED); 
myPane.getChildren().add(line); 

line.setOnKeyPressed(e -> { 
if (e.getCode().isArrowKey()) 
{ 
    switch (e.getCode()) { 

    case DOWN: 
     bY += segment; 
     eY = bY; 
     Line line2 = new Line(bX,bY,eX,eY); 
     line2.setStrokeWidth(2); 
     line2.setStroke(Color.GREEN); 
     myPane.getChildren().add(line2); 
     break; 

    case UP: 
     bY -= segment; 
     eY = bY; 
     Line line3 = new Line(bX,bY,eX,eY); 
     line3.setStrokeWidth(2); 
     line3.setStroke(Color.GREEN); 
     myPane.getChildren().add(line3); 
     break; 

    case LEFT: 
     bX -= segment; 
     eX = bX; 
     Line line4 = new Line(bX,bY, eX, eY); 
     line4.setStrokeWidth(2); 
     line4.setStroke(Color.GREEN); 
     myPane.getChildren().add(line4); 
     break; 

    case RIGHT: 
     bX += segment; 
     eX = bX; 
     Line line5 = new Line(bX,bY,eX,eY); 
     line5.setStrokeWidth(2); 
     line5.setStroke(Color.GREEN); 
     myPane.getChildren().add(line5); 
     break; 

     default: 



     break; 
    } 
} 
}); 


Scene scene = new Scene(myPane, 300, 300); 
primaryStage.setTitle("Draw Line with Arrow Keys"); 
primaryStage.setScene(scene); 
primaryStage.show(); 
line.requestFocus(); 

}

+0

@Uluk BIY,上述修改後的代碼。 – FlyingFinger1125

回答

1

我終於明白了,謝謝你不只是把答案交給我,而是我最終通過你的代碼並分解它,看看它是如何工作的......結果,我能夠拿出一個解決作業...

package skowronek15; 

import javafx.application.Application; 
import javafx.stage.Stage; 
import javafx.scene.Scene; 
import javafx.scene.layout.Pane; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Line; 



public class DrawLineWithArrowKeys extends Application { 
double bX = 150; //start x value denote for beginning-X 
double bY = 150; //start y value denote for beginning-y 
double eX = 150; //start x value denote for end-x 
double eY = 150; //start y value denote for end-y 
double bX2, bY2; //start of next line 
double segment = 20; //length of segment 


@Override 
public void start(Stage primaryStage) { 
    Pane myPane = new Pane(); //create a pane 


    Line line = new Line(bX,bY,eX,eY); //create the starting or initial line 
    line.setStrokeWidth(2); //set width 
    line.setStroke(Color.RED); //set color 
    myPane.getChildren().add(line); //add line to pane 

    line.setOnKeyPressed(e -> { //switch statement to determine what happens when 
           // each key is pressed 
    if (e.getCode().isArrowKey()) 
    { 
     switch (e.getCode()) { 

     case DOWN: 
      bY2 = bY ; //start of next line, bY2 is equal to the start of originating 
         // y-coordinate bY 
      bY += segment;//increment start of first line 
      eY = bY; // end y (eY) coordinate equal to beginning y coordinate (bY) after 
        // it's incremented; 


      Line line2 = new Line(bX,bY2,eX,eY); //create a new line to be drawn; 
           //beginning y coordinate is now bY2; 
      line2.setStrokeWidth(2); 
      line2.setStroke(Color.GREEN); 
      myPane.getChildren().add(line2); 
      break; 

     case UP: 
      bY2 = bY; 
      bY -= segment; 
      eY = bY; 

      Line line3 = new Line(bX,bY2,eX,eY); 
      line3.setStrokeWidth(2); 
      line3.setStroke(Color.GREEN); 
      myPane.getChildren().add(line3); 
      break; 

     case LEFT: 
      bX2 = bX; 
      bX -= segment; 
      eX = bX; 

      Line line4 = new Line(bX2,bY, eX, eY); 
      line4.setStrokeWidth(2); 
      line4.setStroke(Color.GREEN); 
      myPane.getChildren().add(line4); 
      break; 

     case RIGHT: 
      bX2 = bX; 
      bX += segment; 
      eX = bX; 
      Line line5 = new Line(bX2,bY,eX,eY); 
      line5.setStrokeWidth(2); 
      line5.setStroke(Color.GREEN); 
      myPane.getChildren().add(line5); 
      line5.getStrokeLineJoin(); 
      break; 

      default: 


      break; 
     } 
    } 
    }); 


    Scene scene = new Scene(myPane, 300, 300); 
    primaryStage.setTitle("Draw Line with Arrow Keys"); 
    primaryStage.setScene(scene); 
    primaryStage.show(); 
    line.requestFocus(); 



} 






public static void main(String[] args) { 
    launch(args); 
} 

}

1

您可以使用PathPathElement S:

private int bX = 75, bY = 75; 
private int step = 20; 


@Override 
public void start(Stage primaryStage) 
{ 

    Pane myPane = new Pane(); 
    Path path = new Path(new MoveTo(bX, bY)); // move to starting point 
    path.setStrokeWidth(1); 
    path.setStroke(Color.GREEN); 

    myPane.getChildren().add(path); 

    path.setOnKeyPressed(e -> 
    { 
     if (e.getCode().isArrowKey()) 
     { 
      switch (e.getCode()) 
      { 
       case DOWN: 
        bY += step; 
        break; 

       case UP: 
        bY -= step; 
        break; 

       case LEFT: 
        bX -= step; 
        break; 

       case RIGHT: 
        bX += step; 
        break; 
      } 
      path.getElements().add(new LineTo(bX, bY)); 
     } 
    }); 

    Scene scene = new Scene(myPane, 150, 150); 
    primaryStage.setTitle("Draw Line with Arrow Keys"); 
    primaryStage.setScene(scene); 
    primaryStage.show(); 
    path.requestFocus(); 
} 

我不是這樣的問題功課提供現成代碼的粉絲。但至少似乎你已經試圖實施。

+0

是的,謝謝你。我在書中查找了Path課,並閱讀了它。關於任務的唯一提示是在每種情況下或每個鍵被擊中時產生「新線」。我有點困惑。有人建議使用多段線並將這些點存儲在一個列表中,然後使用一個循環來迭代,但這意味着您將有一組關閉線被繪製。在swing中,你只需要調用repaint()方法。在這裏,您正在繪製基於開始x和開始y座標的同一行。 – FlyingFinger1125

+0

@ FlyingFinger1125,此代碼可以很容易地轉換爲「新的Line()」版本。 –

+0

我對代碼進行了一些修改,但是,我只點擊了點,而不是連接點的線,因爲我點擊了箭頭鍵。我差不多完成了,但看起來我忽略了一些東西...... – FlyingFinger1125