ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

JavaFX 绘图与动画程序设计

2021-03-07 14:01:36  阅读:218  来源: 互联网

标签:动画 ft FadeTransition javafx JavaFX scene 绘图 new import


直线类Line
矩形类Rectangle
圆类 Circle
椭圆类Ellipse
弧类 Arc
多边形类Polygon
折线类Polyline

        Line line = new Line(0,0,150,150);
        borderPane.getChildren().add(line);
        

交互式系统设计
鼠标拖动绘图的基本思想是用很多短直线一次相连代替直线

动画程序设计
淡入淡出动画
FadeTransition()

package sample;

import javafx.animation.Animation;
import javafx.animation.FadeTransition;
import javafx.application.Application;
import javafx.geometry.Orientation;
import javafx.scene.Scene;
import javafx.scene.control.CheckMenuItem;
import javafx.scene.control.Menu;
import javafx.scene.control.MenuBar;
import javafx.scene.control.Slider;
import javafx.scene.layout.BorderPane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Circle;
import javafx.scene.shape.Line;
import javafx.stage.Stage;
import javafx.scene.input.MouseEvent;
import javafx.util.Duration;


public class Main extends Application {


    @Override
    public void start(Stage primaryStage) throws Exception{
        BorderPane borderPane = new BorderPane();
        Circle circle = new Circle(150,150,100);
        circle.setFill(Color.BLACK);
        FadeTransition ft = new FadeTransition(Duration.millis(2000));
        ft.setCycleCount(Animation.INDEFINITE);
        ft.setFromValue(1.0);
        ft.setToValue(0.0);
        ft.setAutoReverse(true);
        ft.setNode(circle);
        ft.play();
        borderPane.setCenter(circle);

        primaryStage.setScene(new Scene(borderPane,300,300));
        primaryStage.show();


    }


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

移动效果
Pathtransition()

时间轴动画
太多了懒得写了

标签:动画,ft,FadeTransition,javafx,JavaFX,scene,绘图,new,import
来源: https://blog.csdn.net/Maoxim/article/details/114482401

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有