title: Text(“旋转小人儿”),
centerTitle: true,
),
body: CustomPaint(
size: MediaQuery.of(context).size,
painter: _MyPainter(_controller),
),
);
}
}
class _MyPainter extends CustomPainter {
AnimationController _controller;
_MyPainter(this._controller) : super(repaint: _controller);
@override
void paint(Canvas canvas, Size size) {
translateToCenter(canvas, size);
double dy = 10 * sin(pi * 2 * _controller.value);
Path path = new Path()
…moveTo(30 * sin(pi * 2 * _controller.value), dy)
…lineTo(100 * sin(pi * 2 * _controller.value), 220 + dy)
…moveTo(0, dy)
…lineTo(0, 200 + dy)
…lineTo(300, 200 + dy)
…lineTo(-300, 200 + dy);
Paint paint = new Paint()
…color = Colors.black
…style = PaintingStyle.stroke
…strokeWidth = 2
…isAntiAlias = true;
canvas.drawPath(path, paint);
}
@override
bool shouldRepaint(covariant CustomPainter oldDelegate) {
return true;
}
void translateToCenter(Canvas canvas, Size size) {
canvas.translate(size.width / 2, size.height / 2);
}
}
第二版效果
又仔细观察好像是斜对角的线,即
- 线的上端点,移动方向,左->右
- 线的下端点,移动方向,右->左
- 围绕着y轴旋转,y的坐标上下有波动,x的值通过radius_sin(pi_2*_controller.value)获取。(_controller是设定的一个动画,value取值范围在0-1,radius是旋转半径)
再看下效果:
是不是有那个味儿了。。。
最后,代码如下:
import ‘dart:ui’;
import ‘dart:math’;
import ‘package:flutter/material.dart’;
// 旋转小人儿
class RotateGirlMainPage extends StatefulWidget {
@override
_RotateGirlMainPageState createState() => _RotateGirlMainPageState();
}
class _RotateGirlMainPageState extends State
with SingleTickerProviderStateMixin {
AnimationController _controller;
@override
void initState() {
super.initState();
_controller = new AnimationController(
vsync: this, duration: const Duration(milliseconds: 1500));
_controller.repeat();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(“旋转小人儿”),
centerTitle: true,
),
body: CustomPaint(
size: MediaQuery.of(context).size,
painter: _MyPainter(_controller),
),
);
}
}
class _MyPainter extends CustomPainter {
AnimationController _controller;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
学习分享,共勉
Android高级架构师进阶之路
题外话,我在阿里工作多年,深知技术改革和创新的方向,Android开发以其美观、快速、高效、开放等优势迅速俘获人心,但很多Android兴趣爱好者所需的进阶学习资料确实不太系统,完整。今天我把我搜集和整理的这份学习资料分享给有需要的人,若有关Android学习进阶可以与我在Android终极开发交流群一起讨论交流。 点击这里前往我的Git领取资料 的同时,还可以加入一个好的学习交流圈,何乐而不为呢?加入我们和我们一起吧!!
- Android进阶知识体系学习脑图
- Android进阶高级工程师学习全套手册
- 对标Android阿里P7,年薪50w+学习视频
- 大厂内部Android高频面试题,以及面试经历
QLfxu-1710837840930)]
- 对标Android阿里P7,年薪50w+学习视频
[外链图片转存中…(img-siEbf2Q5-1710837840931)]
- 大厂内部Android高频面试题,以及面试经历