有没有想过Flutter如何获取这些小部件并将其实际转换为屏幕上的像素?

您可能已经知道如何使用StatelessWidget和StatefulWidget。但是那些小部件仅构成其他小部件。布置小部件并将其渲染在其他位置进行。

不透明度(Opacity)

注:随着SDK的更新参数可能有变化

它只接受一个child。因此,您可以将任何小部件包装在中,Opacity并更改其显示方式。除child外,只有一个参数被调用opacity,该参数的值在0.0到1.0之间。它控制不透明度。

The Widget(Opacity小部件)

Opacity小部件继承了SingleChildRenderObjectWidget.

扩展类扩展的层次结构如下:

Opacity -> SingleChildRenderObjectWidget -> RenderObjectWidget -> Widget

相反,StatelessWidget和StatefulWidget如下:

StatelessWidget/StatefulWidget -> Widget

区别在于,Stateless/StatefulWidget仅构成控件,而"Opacity"控件实际上改变了控件的绘制方式

但是,如果您查看这些类中的任何一个,您将找不到与实际绘制不透明度相关的任何代码

这是因为小部件仅保存配置信息。 在这种情况下,Opacity小部件仅保留不透明度值。

这就是为什么每次调用构建函数时都可以创建新的小部件的原因。因为窗口小部件的构造并不昂贵。它们仅仅是信息的容器。

The Rendering(Opacity怎么渲染的?)

它在RenderObjects内部

RenderObject负责一些事情,包括渲染。

Opacity小部件使用这些方法创建和更新RenderObject:

  @override
RenderObject createRenderObject(BuildContext context) {
return RenderOpacity(opacity: opacity);
} @override
void updateRenderObject(BuildContext context, RenderOpacity renderObject) {
renderObject..opacity = opacity;
}

渲染不透明度

该Opacity部件尺寸本身是完全相同的大小作为其子(child)一样。它基本上模仿了孩子(child)的各个方面,除了绘画。在绘制其子项之前,先为其添加不透明度。

在这种情况下,RenderOpacity需要实现所有方法(例如执行布局/命中测试/计算大小),并要求其子级执行实际工作。

RenderOpacity扩展了RenderProxyBox。这些恰好实现了这些方法,并将实际计算推迟到了唯一的孩子。

double get opacity => _opacity;
double _opacity;
set opacity(double value) {
_opacity = value;
markNeedsPaint();
}

在上面的代码中删除了很多断言/优化。

字段通常向私有变量公开获取器。还有一个设置器,除了设置字段外,还调用markNeedsPaint()或markNeedsLayout()。顾名思义,它告诉系统"嘿,我改变了,请重新粉刷/重新布置我"。

在内部,RenderOpacity我们发现此方法:

@override
void paint(PaintingContext context, Offset offset) {
context.pushOpacity(offset, _alpha, super.paint);
}

同样,删除了优化和断言。

该PaintingContext基本上是一个奇特的画布。在这个精美的画布上,有一种称为pushOpacity的方法。

这一行是实际的不透明度实现。

回顾

  • 该Opacity不是StatelessWidget还是StatefulWidget而是一个SingleChildRenderObjectWidget。
  • 将Widget仅持有该渲染器可以使用的信息。
  • 在这种情况下,Opacity持有代表不透明度的双精度。
  • RenderOpacity,它扩展了RenderProxyBox执行实际布点/渲染等。
  • 由于不透明度的行为与其子对象完全相同,因此它将每个方法调用都委派给该子对象。
  • 它覆盖了paint方法,并调用pushOpacity,它将所需的不透明度添加到小部件。

请记住,小部件仅是配置,并且RenderObject仅管理布局/渲染等

在Flutter中,您基本上总是在重新创建小部件。当您的build()方法被调用时,您将创建一堆小部件。每次更改时都会调用此构建方法。例如,当发生动画时,通常会调用build方法。这意味着您不能每次都重建整个子树。相反,您想更新它。

Element介绍:

Element是一棵大树

第一次创建窗口小部件时,它会膨胀为Element。然后将该Element插入到树中。如果该窗口小部件后来发生更改,则将其与旧窗口小部件进行比较,然后相应地更新Element。重要的是,该Element不会被重建,而只会被更新。

Element是核心框架的核心部分,显然还有更多的内容,但是目前这已经足够了。

更具体的可以看原文...

Flutte 什么是Widget,RenderObjects和Elements的更多相关文章

  1. 【搬运】 Page Object 官方文档 (新增了Widget特性)

    Appium Java client has facilities which components to [Page Object](https://github.com/SeleniumHQ/se ...

  2. Flutter资源

    目录 文章 一开始 HOWTO文档 网站/博客 高级 视频 组件 演示 UI 材料设计 图片 地图 图表 导航 验证 文字和富文本 分析.流量统计 自动构建 风格样式 媒体 音频 视频 语音 存储 获 ...

  3. 2020互联网寒冬之下,作为一个Android老码农,是如何进入腾讯的?

    由于众所周知的原因,原生Android开发如今已经日渐凋敝,作为一个Android程序员,不仅要会Java,Kotlin,JavaScript,Css,Html,还要会Flutter,C++,FFmp ...

  4. 阿里、腾讯、百度、网易、美团Android面试经验分享,拿到了百度、腾讯offer

    基本情况 2021届普通本科,Android开发岗. 此文主要是2020年秋招面试经验汇总,最终拿到了百度.腾讯的offer. 主要包括阿里三面,腾讯四面,百度三面,网易三面,美团一场面完. 阿里(由 ...

  5. Tkinter Listbox(列表框)

    Python - Tkinter Listbox(列表框): 列表框部件用于显示一个项目列表,用户可以选择的项目数   列表框部件用于显示一个项目列表,用户可以选择的项目数. 语法: 这里是一个简单的 ...

  6. appium():PageObject&PageFactory

    Appium Java client has facilities which components to Page Object design pattern and Selenium PageFa ...

  7. Appium+python自动化(十一)- 元素定位秘籍助你打通任督二脉 - 下卷(超详解)

    简介 宏哥看你骨骼惊奇,印堂发亮,必是练武之奇才! 按照上一篇的节目预告,这一篇还是继续由宏哥给小伙伴们分享元素定位,是不是按照上一篇的秘籍修炼,是不是感觉到头顶盖好像被掀开,内气从头上冒出去,顿时觉 ...

  8. JQuery UI Widget Factory官方Demo

    <!doctype html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  9. widget jquery 理解

    jquery ui 的所有组件都是基于一个简单,可重用的widget. 这个widget是jquery ui的核心部分,实用它能实现一致的API,创建有状态的插件,而无需关心插件的内部转换. $.wi ...

随机推荐

  1. Lambda 表达式 学习

    最近几天在学习Lambda,给我的理解就是一个匿名函数的升级版,代码极大可能的简洁了很多,不需要像以前一样必须使用众多的代码才能实现相关功能. 慢慢积累学习,将Java 8的相关知识进行一个学习. 用 ...

  2. 12.su 命令与sudo 服务

     1.su 命令:解决切换用户身份的需求,使得当前用户在不退出登录的情况下,顺畅地切换到其他用户. 比如从root 管理员切换至普通用户: [root@Centos test]# id uid=0(r ...

  3. Neeto-Vue:我为了记笔记,手写了一个为知笔记客户端

    构建自托管的笔记系统 这两年各种笔记系统快速井喷,好像谁都能来掺一脚,app store随便搜索一个关键字就会有一大堆的结果,从老牌的印象笔记,Bear,MWeb,有道云笔记再到新星专注笔记之类,从买 ...

  4. jvm系列二内存结构

    二.内存结构 整体架构 1.程序计数器 作用 用于保存JVM中下一条所要执行的指令的地址 特点 线程私有 CPU会为每个线程分配时间片,当当前线程的时间片使用完以后,CPU就会去执行另一个线程中的代码 ...

  5. 设计模式(七)——适配器模式(SpringMVC框架分析)

    适配器模式 1 现实生活中的适配器例子 泰国插座用的是两孔的(欧标),可以买个多功能转换插头 (适配器) ,这样就可以使用了. 2 基本介绍 1) 适配器模式(Adapter Pattern)将某个类 ...

  6. docker(9)Dockerfile制作镜像

    前言 如果我们已经安装了一个python3的环境,如果另一台机器也需要安装同样的环境又要敲一遍,很麻烦,这里可以配置Dockerfile文件,让其自动安装,类似shell脚本 Dockerfile编写 ...

  7. Web APP和原生 APP的不同

    我们现在手机中的APP,大部分都是混合APP,也就是既用到了原生APP的基础,又用到了Web APP的基础,混合的比例从0%到100%之间不等.更好的了解APP的类型,有助于我们学则合适的测试策略.今 ...

  8. 使用VisualStudio直接运行简单的C#语句

    场景 经常有这样的需求, 想要测试一些简单的C#语法, 或者测试一下 文件 目录 操作相关的Api, 通常的做法是建立一个C#控制台项目, 然后写代码测试, 但是这样的做法对测试简单的语法和Api来说 ...

  9. D - D (畅通工程再续)

    相信大家都听说一个"百岛湖"的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现.现在政府决定大力发展百岛湖,发展首先要解决的问题当然是交通问题,政 ...

  10. 最大子阵 DP or 前缀和orb暴力 能过

    在一个给定的n*m二维矩阵中求一个子矩阵元素和的最大值. 思路: 1:一个二维矩阵由两个点可以确定,枚举两个点,取子矩阵最大值. 2:在一维矩阵中,求一个序列的最大子段,利用 f[i]=max(f[i ...