当前位置: 首页 > news >正文

深圳百度推广网站建设深圳电器网站建设

深圳百度推广网站建设,深圳电器网站建设,天津 网站设计公司,网站的软件之前用 Flutter Canvas 画过一个三角三角形#xff0c;html 的 Canvas 也画过一次类似的#xff0c; 今天用 Flutter Canvas 试了下 感觉差不多#xff1a; html 版本 大致效果如下#xff1a; 思路和 html 实现的类似#xff1a; 也就是找出点的位置#xff0c;使用二阶… 之前用 Flutter Canvas 画过一个三角三角形html 的 Canvas 也画过一次类似的 今天用 Flutter Canvas 试了下 感觉差不多 html 版本 大致效果如下 思路和 html 实现的类似 也就是找出点的位置使用二阶贝塞尔曲线实现 代码如下 import package:flutter/material.dart;class PageCanvas extends StatefulWidget {const PageCanvas({Key? key}) : super(key: key);overrideStatePageCanvas createState() _PageCanvasState(); }class _PageCanvasState extends StatePageCanvas with TickerProviderStateMixin {late Animationdouble animation;late AnimationController controller;overridevoid initState() {// TODO: implement initStatesuper.initState();controller AnimationController(duration: const Duration(milliseconds: 2000), vsync: this);animation Tweendouble(begin: 0, end: 1).animate(controller);controller.repeat();}overrideWidget build(BuildContext context) {Size size MediaQuery.of(context).size;return Scaffold(appBar: AppBar(title: const Text(Canvas),backgroundColor: Colors.blue,),body: Column(children: [AnimatedBuilder(animation: controller,builder: (context, widget) {return CustomPaint(size: Size(size.width, size.height / 3),painter: MyPainter(animation.value),);}),const SizedBox(height: 60,),Center(child: SizedBox(// color: Colors.grey,width: 200,height: 200,child: ClipOval(child: Container(color: Colors.grey.withOpacity(0.3),child: AnimatedBuilder(animation: controller,builder: (context, widget) {return CustomPaint(size: Size(size.width, size.height / 3),painter: MyPainter2(animation.value),);}),),),),)],),);}overridevoid dispose() {controller.dispose();// TODO: implement disposesuper.dispose();} }class MyPainter extends CustomPainter {final double value;const MyPainter(this.value);overridevoid paint(Canvas canvas, Size size) {// print(value);Paint paint Paint();Path path Path();double positionX -size.width * value;double positionY 100;double positionRange 10;double positionX2 -size.width * (1 - value);double positionY2 110;double positionRange2 20;double positionX3 -size.width * (1.3 - value);double positionY3 120;double positionRange3 30;double step size.width / 4;//path.moveTo(0 positionX, positionY);for (int i 1; i 13; i) {if (i % 2 1) {path.quadraticBezierTo(step * (2 * i - 1) positionX,positionY - positionRange, step * (2 * i) positionX, positionY);} else {path.quadraticBezierTo(step * (2 * i - 1) positionX,positionY positionRange, step * (2 * i) positionX, positionY);}}path.lineTo(step * 10, 250);path.lineTo(0, 250);path.close();paint.color Colors.blue.withOpacity(0.2);canvas.drawPath(path, paint);canvas.save();canvas.restore();path Path();path.moveTo(0 positionX2, positionY2);for (int i 1; i 13; i) {if (i % 2 1) {path.quadraticBezierTo(step * (2 * i - 1) positionX2,positionY2 - positionRange2,step * (2 * i) positionX2,positionY2);} else {path.quadraticBezierTo(step * (2 * i - 1) positionX2,positionY2 positionRange2,step * (2 * i) positionX2,positionY2);}}path.lineTo(step * 10, 250);path.lineTo(0, 250);path.close();paint.color Colors.blue.withOpacity(0.6);canvas.drawPath(path, paint);canvas.save();canvas.restore();path Path();path.moveTo(0 positionX3, positionY3);for (int i 1; i 13; i) {if (i % 2 1) {path.quadraticBezierTo(step * (2 * i - 1) positionX3,positionY3 - positionRange3,step * (2 * i) positionX3,positionY3);} else {path.quadraticBezierTo(step * (2 * i - 1) positionX3,positionY3 positionRange3,step * (2 * i) positionX3,positionY3);}}path.lineTo(step * 10, 250);path.lineTo(0, 250);path.close();paint.color Colors.blue;canvas.drawPath(path, paint);}overridebool shouldRepaint(covariant CustomPainter oldDelegate) {// TODO: implement shouldRepaintreturn oldDelegate ! this;//return true;} }class MyPainter2 extends CustomPainter {final double value;const MyPainter2(this.value);overridevoid paint(Canvas canvas, Size size) {// print(value);Paint paint Paint();Path path Path();double positionX -size.width * value;double positionY 50;double positionRange 10;double positionX2 -size.width * (1 - value);double positionY2 60;double positionRange2 20;double positionX3 -size.width * (1.3 - value);double positionY3 70;double positionRange3 30;double step size.width / 4;//path.moveTo(0 positionX, positionY);for (int i 1; i 13; i) {if (i % 2 0) {path.quadraticBezierTo(step * (2 * i - 1) positionX,positionY - positionRange, step * (2 * i) positionX, positionY);} else {path.quadraticBezierTo(step * (2 * i - 1) positionX,positionY positionRange, step * (2 * i) positionX, positionY);}}path.lineTo(step * 10, 250);path.lineTo(0, 250);path.close();paint.color Colors.blue.withOpacity(0.2);canvas.drawPath(path, paint);canvas.save();canvas.restore();path Path();path.moveTo(0 positionX2, positionY2);for (int i 1; i 13; i) {if (i % 2 0) {path.quadraticBezierTo(step * (2 * i - 1) positionX2,positionY2 - positionRange2,step * (2 * i) positionX2,positionY2);} else {path.quadraticBezierTo(step * (2 * i - 1) positionX2,positionY2 positionRange2,step * (2 * i) positionX2,positionY2);}}path.lineTo(step * 10, 250);path.lineTo(0, 250);path.close();paint.color Colors.blue.withOpacity(0.6);canvas.drawPath(path, paint);canvas.save();canvas.restore();path Path();path.moveTo(0 positionX3, positionY3);for (int i 1; i 13; i) {if (i % 2 0) {path.quadraticBezierTo(step * (2 * i - 1) positionX3,positionY3 - positionRange2,step * (2 * i) positionX3,positionY3);} else {path.quadraticBezierTo(step * (2 * i - 1) positionX3,positionY3 positionRange2,step * (2 * i) positionX3,positionY3);}}path.lineTo(step * 10, 250);path.lineTo(0, 250);path.close();paint.color Colors.blue;canvas.drawPath(path, paint);canvas.save();canvas.restore();}overridebool shouldRepaint(covariant CustomPainter oldDelegate) {// TODO: implement shouldRepaintreturn oldDelegate ! this;//return true;} }
http://www.zqtcl.cn/news/147990/

相关文章:

  • 响应式网站有什么区别官方app
  • 手机网站建设哪里好网站架构设计师待遇怎么样
  • 静态网站设计wordpress网页视频播放器
  • 打电话做网站的话术网站安全维护方案
  • 变更备案网站可以访问吗google浏览器下载安装
  • 网站空间更换网站开发的服务器是什么
  • 网站 网页玉溪建设网站
  • 江西宜春市城市建设档案馆网站朋友圈广告30元1000次
  • 响应式网站 分辨率惊艳的网站
  • 苏州网站公司排名前十最好看的视频免费下载
  • 快速设计一个网站wordpress4.9.6
  • 网站建立教学深圳宝安网站建设公司推荐
  • 深圳企业网站建设制作公司叶县红色家园网站建设
  • 网站制作报价被哪些因素影响建设银行官方网站首页个人登录
  • 免费网站怎么建谁能给个网站谢谢
  • 吴忠网站建设家里面的服务器可以做网站吗
  • 这是我自己做的网站做网站前台要学什么课程
  • 程序网站开发建设隔离变压器移动网站
  • 网站设置不发送消息怎么设置回来用typecho做的网站
  • 网站机房建设嵌入式培训机构哪家好
  • 购物网站页面设计图片网站 签约
  • 上海网站改版方案网站邮件设置
  • 如何在自己网站添加链接高端品牌logo图片
  • 网站建设找c宋南南app软件设计
  • 龙岗网站推广seo 0xu
  • 成都做网站微网站后台录入
  • 开发区网站建设山东房地产新闻
  • 手机如何搭建网站网站菜单导航
  • 网站建设丿金手指专业社交投票论坛网站开发
  • 做一套网站开发多少钱设计高端的国外网站