JavaFx Path 实现摇头动画

项目需要,点击登录时信息填写不完整需要一些动画提示,于是就研究了一下JavaFx的动画,方便以后查看!
以此记录!
废话不多说,代码如下:

            Path path = new Path();//创建一个路径对象
            double x=loginButton.getLayoutX()+25;
            double y=loginButton.getLayoutY();
            path.getElements().add(new MoveTo(x, y+18));//从哪个位置开始动画,一般来说给组件的默认位置就行
            path.getElements().add(new LineTo(x-20, y+18));//添加一个向左移动的路径
            path.getElements().add(new LineTo(x+20, y+18));//添加一个向右移动的路径  这样就完成第一遍摇头
            path.getElements().add(new LineTo(x-20, y+18));//添加一个向左移动的路径 第二遍
            path.getElements().add(new LineTo(x+20, y+18));//添加一个向右移动的路径  这样就完成第二遍摇头
            path.getElements().add(new LineTo(x, y+18));//最后移动到原来的位置

            PathTransition pathTransition = new PathTransition();//创建一个动画对象
            pathTransition.setDuration(Duration.seconds(0.5));//动画持续时间 0.5秒
            pathTransition.setPath(path);//把我们设置好的动画路径放入里面
            pathTransition.setNode(loginButton);//给动画添加组件,让某个组件来完成这个动画
            pathTransition.setCycleCount(1);//执行1遍 
            pathTransition.play();//执行动画

有的同学会想,我们添加了重复的两个左右移动路径,为什么不复用,把
setCycleCount(1) 改成
setCycleCount(2),
因为复用,我们有一个
path.getElements().add(new LineTo(x, y+18));//最后移动到原来的位置
重复动画的话,这个也会重复两边,动画效果看起来就不连贯,有兴趣的可以自己试试看!

图片:
在这里插入图片描述

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值