iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Flutter构建自定义Widgets的全过程记录
  • 816
分享到

Flutter构建自定义Widgets的全过程记录

2024-04-02 19:04:59 816人浏览 安东尼
摘要

目录一.组合widget实现二.通过自定义CustomPainter实现widgets三.饼状图piechart.dart代码展示四.实际效果图,eg:附:Flutter中父widg

一.组合widget实现

1.Android和flutter自定义控件对比

Android中,一般会继承View或已经存在的某个控件,然后覆盖draw方法来实现自定义View。在Flutter中,一个自定义widget通常是通过组合其它widget来实现的,而不是继承。下面看看如何构建持有一个label的CustomButton。这是通过将Text与RaisedButton组合来实现的,而不是继承RaisedButton并重写其绘制方法实现,eg :custombuttontest.dart

import 'package:flutter/material.dart';
 
class CustomButtonTest extends StatelessWidget{
  final String textStr;
  CustomButtonTest(this.textStr);
 
  @override
  Widget build(BuildContext context) {
    return RaisedButton(
      onPressed: (){},
      child: Text(
        textStr,
        textAlign: TextAlign.center,
      )
    );
  }
 
}

上面定义好组件之后,可直接在调用build的方法中现实,eg :

@override
  Widget build(BuildContext context) {
    return new Center(
      child: new CustomButton("Custom Button"),
    );
  }
}

二.通过自定义CustomPainter实现widgets

1.CustomPainter主要属性介绍,和Android开发中的自定义View类似,Flutter中的绘制也是依靠canvas和Paint来实现的

1).Canvas //画布,为开发者提供了点、线、矩形、圆形、嵌套矩形等绘制方法。

2).Paint //画笔,可以设置抗锯齿,画笔颜色,粗细,填充模式等属性,绘制时可以定义多个画笔以满足不同的绘制需求。eg:

Paint _paint = new Paint()
..color = Colors.red // 画笔颜色 
..strokeCap = StrokeCap.round //画笔笔触类型,包括(1.round-画笔笔触呈半圆形轮廓开始和结束;2.butt-笔触开始和结束边缘平坦,没有外延;3.square-笔触开始和结束边缘平坦,向外延伸长度为画笔宽度的一半)
..isAntiAlias = true //是否启动抗锯齿
..style=PaintingStyle.fill //绘画风格,默认为填充,有fill和stroke两种
..blendMode=BlendMode.exclusion //颜色混合模式
..colorFilter=ColorFilter.mode(Colors.blueAccent, BlendMode.exclusion)//颜色渲染模式
..maskFilter=MaskFilter.blur(BlurStyle.inner, 3.0)//模糊遮罩效果
..filterQuality=FilterQuality.high//颜色渲染模式的质量
..strokeWidth = 15.0;//画笔的宽度复制代码

3).Offset //坐标,可以用来表示某个点在画布中的坐标位置。

4).Rect //矩形,在图形的绘制中,一般都是分区域绘制的,这个区域一般都是一个矩形,在绘制中通常使用Rect来存储绘制的位置信息。

5).坐标系 //在Flutter中,坐标系原点(0,0)位于左上角,X轴向右变大,Y轴向下变大。

2.painting.dart中的主要方法,eg:

void drawRect(Rect rect, Paint paint) {...} //画矩形
void drawLine(Offset p1, Offset p2, Paint paint) {...} //画线
void drawPoints(PointMode pointMode, List<Offset> points, Paint paint) {...} //画点
void drawCircle(Offset c, double radius, Paint paint) {...} //画圆
void drawArc(Rect rect, double startAngle, double sweepAngle, bool useCenter, Paint paint) {...} //画圆弧

三.饼状图piechart.dart代码展示

import 'dart:math';
import 'package:flutter/material.dart';
 
class PieChartTest extends StatelessWidget{
  const PieChartTest({Key? key}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('pie chart'),
      ),
      body:Container(
        alignment: Alignment.center,
        child: CustomPaint(
          size: const Size(300, 300),
          painter: PieChartPainter(),
        ),
      )
    );
  }
}
 
class PieChartPainter extends CustomPainter{
 
  Paint getColoredPaint(Color color){
    Paint paint=Paint();
    paint.color=color;
    return paint;
  }
 
  @override
  void paint(Canvas canvas, Size size) {
    double wheelSize=min(size.width, size.height)/2;
    double nbElem=8;
    double radius=(2*pi)/nbElem;
    Rect boundingRect=Rect.fromCircle(center: Offset(wheelSize,wheelSize), radius: wheelSize);
    canvas.drawArc(boundingRect, 0, radius, true, getColoredPaint(Colors.orange));
    canvas.drawArc(boundingRect, radius, radius, true, getColoredPaint(Colors.black));
    canvas.drawArc(boundingRect, radius*2, radius, true, getColoredPaint(Colors.green));
    canvas.drawArc(boundingRect, radius*3, radius, true, getColoredPaint(Colors.red));
    canvas.drawArc(boundingRect, radius*4, radius, true, getColoredPaint(Colors.blue));
    canvas.drawArc(boundingRect, radius*5, radius, true, getColoredPaint(Colors.yellow));
    canvas.drawArc(boundingRect, radius*6, radius, true, getColoredPaint(Colors.purple));
    canvas.drawArc(boundingRect, radius*7, radius, true, getColoredPaint(Colors.white));
  }
 
  @override
  bool shouldRepaint(covariant CustomPainter oldDelegate)=>oldDelegate!=this;
}

四.实际效果图,eg:

附:Flutter中父widget调用子widget的方法

一、定义globalKey,注意<>中的是State类。

final _childWidgeTKEy = GlobalKey();

二、在父页面初始化子widget

ChildPage(key:_receiveKey),

三、

class ChildPage extends StatefulWidget {undefined
ChildPage({Key key}) : super(key: key);
​​​​​​​@override
ChildPageState createState() => ChildPageState();
}

四、在父界面调用子widget中的方法

_childWidgetKey.currentState.onRefresh();

总结

到此这篇关于Flutter构建自定义Widgets的文章就介绍到这了,更多相关Flutter构建自定义Widgets内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Flutter构建自定义Widgets的全过程记录

本文链接: https://www.lsjlt.com/news/162183.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Flutter构建自定义Widgets的全过程记录
    目录一.组合widget实现二.通过自定义CustomPainter实现widgets三.饼状图piechart.dart代码展示四.实际效果图,eg:附:Flutter中父widg...
    99+
    2024-04-02
  • Flutter构建自定义Widgets的方法是什么
    这篇文章主要讲解了“Flutter构建自定义Widgets的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Flutter构建自定义Widgets的方法是什么”吧!一.组合widge...
    99+
    2023-06-26
  • 自定义WPF分页控件的全过程记录
    一、分页控件功能说明# 实现如上图所示的分页控件,需要实现一下几个功能: 可以设置每页能够展示的最大列数(例如每页8列、每页16列等等)。 加载的数组总数量超过...
    99+
    2024-04-02
  • vite构建vue3项目的全过程记录
    目录环境准备创建项目启动总结环境准备 安装最新版本 @vuejs/app yarn global add @vue/cli # OR npm install -g @vue/cli ...
    99+
    2023-01-16
    vite搭建vue3 vue3+vite vue构建
  • MyBatis-Plus自定义SQL的详细过程记录
    目录前言一、在src/main/resource目录下编写XML1.1  目录结构1.2   编写实体类对应的Mapper接口1.3 ...
    99+
    2024-04-02
  • vue自定义表格列的实现过程记录
    目录前言效果图 setTable组件 使用 结束语 前言 在我们开发PC端的项目使用表单时,尤其是crm系统,应该经常会遇到这样的需求, 用户需要根据设置来自定义显示列。 查了ele...
    99+
    2024-04-02
  • 利用Vue Native构建移动应用的全过程记录
    目录前言Vue Native 的特性声明式渲染双向绑定Vue.js 生态系统的丰富性编译为 React Native设置开发环境创建一个Vue Native项目Vue Native ...
    99+
    2024-04-02
  • OpenCV相机标定的全过程记录
    目录一、OpenCV标定的几个常用函数findChessboardCorners()棋盘格角点检测cv::drawChessboardCorners()棋盘格角点的绘制find4Qu...
    99+
    2024-04-02
  • 使用vant 自定义弹框全过程
    目录vant 自定义弹框vant 弹框和弹出层vant 自定义弹框 使用vant制作弹框,具体如下: html层 <van-popup v-model="show...
    99+
    2024-04-02
  • 通过自定制LogManager实现程序完全自定义的logger
    目录引言怎么实现自定义的LogManager自定义的LogManager中使用到的ServerFileHandler实现Formatter前一篇博文介绍了JDK logging基础知...
    99+
    2024-04-02
  • springboot整合shiro与自定义过滤器的全过程
    目录filter自定义过滤器  增加了 对验证码的校验Shiro中的权限控制总结filter自定义过滤器  增加了 对验证码的校验 package com.you...
    99+
    2024-04-02
  • SpringBoot创建RSocket服务器的全过程记录
    前言 在微服务的多样化世界中,HTTP是代理到代理通信中无可争议的领导者。它成熟,无处不在。但在某些情况下,HTTP请求-响应可能很麻烦。如果您需要传统请求-响应之外的通信模式,如f...
    99+
    2024-04-02
  • .NET Core自定义项目模板的全过程
    前言: 前面介绍 自定义项目模板 中介绍了一种简单的方式——通过创建项目导出为项目模板方式实现。本次将采用dotenet cil(手脚架)来创建项目模板。 那么,我们首先看下当前do...
    99+
    2024-04-02
  • 微信小程序自定义tabBar的步骤记录
    目录1、前言 2、自定义tabBar样式 3、引入custom-tab-bar及相关配置4、完整Demo总结1、前言 很多时候,小程序自带的tabBar不能够满足项目需求,这个时候...
    99+
    2024-04-02
  • Android自定义软键盘的步骤记录
    目录效果图实现自定义软键盘1、通过xml定义键盘2、将xml文件与keyboardview绑定起来3、处理点击事件onKey附赠一些实用的效果处理总结效果图 还是咱们的老规矩,先放最...
    99+
    2024-04-02
  • Dockerfile构建自定义镜像的实现
    目录前言 Dockerfile简介 Dockerfile构建镜像的流程 Dockerfile使用 前言 前面文章中使用docker运行容器使用的镜像都是从dockerhub上远程p...
    99+
    2024-04-02
  • eclipse构建自定义菜单的实现
    1.1 简介在开发工具上添加自己需要的功能,可以基于eclipse的插件进行扩展以满足新功能的需要。下面就说说如何在eclipse上如何添加菜单项。1.2 建立工程新建eclipse插件工程...
    99+
    2023-06-02
  • uniapp微信小程序自定义导航栏的全过程
    目录前言那么标题栏的高度我们怎么获取呢?献上源码:组件使用:效果图:总结前言 相信很多小伙伴在使用uniapp进行多端开发的时候呢,在面对一些奇葩的业务需求的时候,uniapp给我们...
    99+
    2024-04-02
  • springboot打war包的全过程记录
    目录为什么要把SpringBoot打成war包springboot打war包分步指南总结为什么要把SpringBoot打成war包 正常情况下SpringBoot项目是以jar包的形...
    99+
    2024-04-02
  • Android自定义View实现数字雨效果的全过程
    目录效果图实现步骤总结效果图 在安卓中多种类型的动画,有帧动画、补间动画、属性动画,除此之外,使用自定义的View结合数学公式,就可以绘制出复杂的界面或者动画。这篇文章记录的是仿照黑...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作