欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

flutter降幀,flutter 幀率監(jiān)控

flutter-動畫

1.動畫原理:在一段時間內快速的多次改變UI外觀,由于人眼會產(chǎn)生視覺暫留所以最終看到的就是一個連續(xù)的動畫。

成都創(chuàng)新互聯(lián)主要從事成都網(wǎng)站建設、做網(wǎng)站、網(wǎng)頁設計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務沙灣,十年網(wǎng)站建設經(jīng)驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:18982081108

UI的一次改變稱為一個動畫幀,對應一次屏幕刷新。

FPS:幀率,每秒的動畫幀數(shù)。

flutter動畫分為兩類:

常見動畫模式:

是一個抽象類,主要的功能是保存動畫的值和狀態(tài)。常用的一個Animation類是Animation double ,是一個在一段時間內依次生成一個區(qū)間之間的值的類,可以是線性或者曲線或者其他。

可以生成除double之外的其他類型值,如:Animation Color 或 Animation Size 。

是一個動畫控制器,控制動畫的播放狀態(tài),在屏幕刷新的每一幀,就會生成一個新的值。

包含動畫的啟動forward()、停止stop() 、反向播放 reverse()等方法,在給定的時間段內線性的生成從0.0到1.0(默認區(qū)間)的數(shù)字。

curve:描述動畫的曲線過程。

curvedAnimation:指定動畫的曲線。

常用Curve:

繼承自Animatable T ,表示的就是一個 Animation 對象的取值范圍,只需要設置開始和結束的邊界值(值也支持泛型)。 它唯一的工作就是定義輸入范圍到輸出范圍的映射。

例如,Tween可能會生成從紅到藍之間的色值,或者從0到255。

Tween.animate:返回一個Animation。

映射過程:

1). Tween.animation通過傳入 aniamtionController 獲得一個_AnimatedEvaluation 類型的 animation 對象(基類為 Animation), 并且將 aniamtionController 和 Tween 對象傳入了 _AnimatedEvaluation 對象。

2). animation.value方法即是調用 _evaluatable.evaluate(parent)方法, 而 _evaluatable 和 parent 分別為 Tween 對象和 AnimationController 對象。

3). 這里的 animation 其實就是前面的 AnimationController 對象, transform 方法里面的 animation.value則就是 AnimationController 線性生成的 0.0~1.0 直接的值。 在 lerp 方法里面我們可以看到這個 0.0~1.0 的值被映射到了 begin 和 end 范圍內了。

接收一個TickerProvider類型的對象,它的主要職責是創(chuàng)建Ticker。

防止屏幕外動畫消耗資源。

[圖片上傳失敗...(image-115b94-1636441483468)]

過程:

回調:

不使用addListener()和setState()來給widget添加動畫。

使用AnimatedWidget,將widget分離出來,創(chuàng)建一個可重用動畫的widget,AnimatedWidget中會自動調用addListener()和setState()

AnimatedModalBarrier、DecoratedBoxTransition、FadeTransition、PositionedTransition、RelativePositionedTransition、RotationTransition、ScaleTransition、SizeTransition、SlideTransition

如何渲染過渡,把渲染過程也抽象出來:

AnimatedBuilder的示例包括: BottomSheet、 PopupMenu、ProgressIndicator、RefreshIndicator、Scaffold、SnackBar、TabBar。

MaterialPageRoute:平臺風格一致的路由切換動畫

CupertinoPageRoute:左右切換風格

自定義:PageRouteBuilder

1.要創(chuàng)建交織動畫,需要使用多個動畫對象(Animation)。

2.一個AnimationController控制所有的動畫對象。

3.給每一個動畫對象指定時間間隔(Interval)

可以同時對其新、舊子元素添加顯示、隱藏動畫.

當AnimatedSwitcher的child發(fā)生變化時(類型或Key不同),舊child會執(zhí)行隱藏動畫,新child會執(zhí)行執(zhí)行顯示動畫。

希望大家支持一下,感謝

flutter微任務過多導致的幀率下降

第二點表明,微任務會在進行幀渲染的過程中進行。也就是你的微任務過多,會使頁面卡頓、掉幀

Flutter 之 動畫1

對動畫系統(tǒng)而言,為了實現(xiàn)動畫,它需要做三件事兒:1.確定畫面變化的規(guī)律;2.根據(jù)這個規(guī)律,設定動畫周期,啟動動畫;3.定期獲取當前動畫的值,不斷地微調、重繪畫面。

這三件事情對應到 Flutter 中,就是 Animation、AnimationController 與 Listener:

1.Animation 是 Flutter 動畫庫中的核心類,會根據(jù)預定規(guī)則,在單位時間內持續(xù)輸出動畫的當前狀態(tài)。Animation 知道當前動畫的狀態(tài)(比如,動畫是否開始、停止、前進或者后退,以及動畫的當前值),但卻不知道這些狀態(tài)究竟應用在哪個組件對象上。換句話說,Animation 僅僅是用來提供動畫數(shù)據(jù),而不負責動畫的渲染。

2.AnimationController 用于管理 Animation,可以用來設置動畫的時長、啟動動畫、暫停動畫、反轉動畫等。

3.Listener 是 Animation 的回調函數(shù),用來監(jiān)聽動畫的進度變化,我們需要在這個回調函數(shù)中,根據(jù)動畫的當前值重新渲染組件,實現(xiàn)動畫的渲染。

class NormalAnimateWidget extends StatefulWidget {

@override

StatecreateState()=_NormalAnimateState();

}

class _NormalAnimateState extends Statewith SingleTickerProviderStateMixin{

AnimationController?controller;

Animation?animation;

@override

void initState() {

// TODO: implement initState

super.initState();

/*

* AnimationController

AnimationController用于控制動畫,它包含動畫的啟動forward()、停止stop() 、反向播放 reverse()等方法。

* AnimationController會在動畫的每一幀,就會生成一個新的值。

* 默認情況下,AnimationController在給定的時間段內線性的生成從 0.0 到1.0(默認區(qū)間)的數(shù)字。

* */

/*Ticker

當創(chuàng)建一個AnimationController時,需要傳遞一個vsync參數(shù),

它接收一個TickerProvider類型的對象,它的主要職責是創(chuàng)建Ticker,定義如下:

abstract class TickerProvider {

//通過一個回調創(chuàng)建一個Ticker

Ticker createTicker(TickerCallback onTick);

}

Flutter 應用在啟動時都會綁定一個SchedulerBinding,

通過SchedulerBinding可以給每一次屏幕刷新添加回調,

而Ticker就是通過SchedulerBinding來添加屏幕刷新回調,這樣一來,

每次屏幕刷新都會調用TickerCallback。

使用Ticker(而不是Timer)來驅動動畫會防止屏幕外動畫(動畫的UI不在當前屏幕時,如鎖屏時)

消耗不必要的資源,因為Flutter中屏幕刷新時會通知到綁定的SchedulerBinding,

而Ticker是受SchedulerBinding驅動的,

由于鎖屏后屏幕會停止刷新,所以Ticker就不會再觸發(fā)。

*/

// 創(chuàng)建動畫周期為1秒的AnimationController對象

controller =AnimationController(

vsync:this, duration:const Duration(milliseconds:3000));

/*

* Curve

* 動畫過程可以是勻速的、勻加速的或者先加速后減速等。

* Flutter中通過Curve(曲線)來描述動畫過程,

* 我們把勻速動畫稱為線性的(Curves.linear),而非勻速動畫稱為非線性的。

* 我們可以通過CurvedAnimation來指定動畫的曲線,如:

final CurvedAnimation curve =

CurvedAnimation(parent: controller, curve: Curves.easeIn);

*

Curves曲線 動畫過程

linear 勻速的

decelerate 勻減速

ease 開始加速,后面減速

easeIn 開始慢,后面快

easeOut? 開始快,后面慢

easeInOut? 開始慢,然后加速,最后再減速

*

* 當然我們也可以創(chuàng)建自己Curve,例如我們定義一個正弦曲線:

class ShakeCurve extends Curve {

@override

double transform(double t) {

return math.sin(t * math.PI * 2);

}

}

* */

final CurvedAnimation curve =CurvedAnimation(

parent:controller!, curve:Curves.linear);

/*

* Animation

*Animation是一個抽象類,它本身和UI渲染沒有任何關系,

* 而它主要的功能是保存動畫的插值和狀態(tài);其中一個比較常用的Animation類是Animation。

* Animation對象是一個在一段時間內依次生成一個區(qū)間(Tween)之間值的類。

* Animation對象在整個動畫執(zhí)行過程中輸出的值可以是線性的、曲線的、一個步進函數(shù)或者任何其他曲線函數(shù)等等,

* 這由Curve來決定。 根據(jù)Animation對象的控制方式,

* 動畫可以正向運行(從起始狀態(tài)開始,到終止狀態(tài)結束),

* 也可以反向運行,甚至可以在中間切換方向。

* Animation還可以生成除double之外的其他類型值

* ,如:Animation 或Animation。

* 在動畫的每一幀中,我們可以通過Animation對象的value屬性獲取動畫的當前狀態(tài)值。

#動畫通知

我們可以通過Animation來監(jiān)聽動畫每一幀以及執(zhí)行狀態(tài)的變化,Animation有如下兩個方法:

addListener();它可以用于給Animation添加幀監(jiān)聽器,

* 在每一幀都會被調用。

* 幀監(jiān)聽器中最常見的行為是改變狀態(tài)后調用setState()來觸發(fā)UI重建。

addStatusListener();

* 它可以給Animation添加“動畫狀態(tài)改變”監(jiān)聽器;

* 動畫開始、結束、正向或反向(見AnimationStatus定義)時會調用狀態(tài)改變的監(jiān)聽器。

* */

// 創(chuàng)建從50到200線性變化的Animation對象

// 普通動畫需要手動監(jiān)聽動畫狀態(tài),刷新UI

animation =Tween(begin:10.0, end:200.0).animate(curve)

..addListener(()=setState((){}));

/*

* Tween

* 默認情況下,AnimationController對象值的范圍是[0.0,1.0]。

* 如果我們需要構建UI的動畫值在不同的范圍或不同的數(shù)據(jù)類型,

* 則可以使用Tween來添加映射以生成不同的范圍或數(shù)據(jù)類型的值。

*Tween構造函數(shù)需要begin和end兩個參數(shù)。

* Tween的唯一職責就是定義從輸入范圍到輸出范圍的映射。

* 輸入范圍通常為[0.0,1.0],但這不是必須的,我們可以自定義需要的范圍。

* */

// 啟動動畫

controller!.repeat(reverse:true);

//

// 第二段

// animation!.addStatusListener((status) {

//? if (status == AnimationStatus.completed) {

//? ? controller!.reverse();// 動畫結束時反向執(zhí)行

//? } else if (status == AnimationStatus.dismissed) {

//? ? controller!.forward();// 動畫反向執(zhí)行完畢時,重新執(zhí)行

//? }

// });

// controller!.forward();// 啟動動畫

}

@override

Widget build(BuildContext context) {

return MaterialApp(

home:Scaffold(

body:Center(

child:Container(

width:animation!.value,// 將動畫的值賦給 widget 的寬高

? ? ? ? ? ? ? height:animation!.value,//

? ? ? ? ? ? ? child:FlutterLogo(),

)

)

)

);

}

@override

void dispose() {

// 釋放資源

controller!.dispose();

super.dispose();

}

}

為什么Flutter開發(fā)APP性能最接近原生,前端程序員請關注

Flutter是谷歌公司推出的跨終端的開發(fā)框架,支持Android、iOS和WEB終端。1.0版在2018年12月5日發(fā)布,目前的最新版本是1.5,它采用的開發(fā)語言是Dart,Dart也是谷歌開發(fā)的計算機編程語言,語法類似C,是編譯型語言:

hello world例子,打印字符串“Hello World!”:

1、沒有橋接層

React Native、Weex等技術都是跨終端的框架,然而性能跟原生App存在很大差距。這是由于它們的工作原理決定的:

React Native、Weex等技術多了一個橋接層,所以界面渲染會慢一些,由于UI渲染非常頻繁,想要不卡頓,基本上比較難,性能和用戶體驗跟原生代碼有差距。而這恰恰是Flutter的優(yōu)勢所在:

Dart可以被編譯成不同平臺的本地代碼,讓Flutter不通過橋接層直接跟平臺通信,自然性能會快一些。

2、編譯執(zhí)行

JavaScript是解釋執(zhí)行的,Dart是編譯執(zhí)行的,性能誰好一目了然。

3、Flutter Engine虛擬機

Flutter是依靠Flutter Engine虛擬機在iOS和Android上運行的,F(xiàn)lutter Engine使用C/C++編寫,開發(fā)人員通過Flutter框架直接和API在內部進行交互,所以具有輸入低延遲和UI渲染高幀速率的特點。除了這特點之外,F(xiàn)lutter還提供了自己的小部件,F(xiàn)lutter小部件是使用從React獲取靈感的現(xiàn)代框架構建的。 中心思想是您使用小部件構建UI。

窗口小部件根據(jù)其當前配置和狀態(tài)描述了它們的視圖。 當窗口小部件的狀態(tài)發(fā)生更改時,窗口小部件會重建其描述,框架將根據(jù)前面的描述進行區(qū)分,以確定底層呈現(xiàn)樹從一個狀態(tài)轉換到下一個狀態(tài)所需的最小更改。可以直接在OS平臺提供的畫布上進行描繪,也就是一些核心類庫直接放到虛擬機里面,調用起來更快。

從它的系統(tǒng)結構可以看出,類似安卓的ART(Android Run Time)虛擬機,同樣采用AOT(Ahead of TIme)技術,會在APP安裝時就編譯成機器語言,不再解釋執(zhí)行,從而優(yōu)化了APP運行的性能。

4、自帶渲染引擎

Flutter使用谷歌自己的Skia渲染引擎,而Android系統(tǒng)自帶Skia引擎,iOS平臺上Flutter也會把Skia引擎打包到APP中,從而實現(xiàn)了高效渲染。而React Native通過橋接層訪問原生UI,操作頻繁就容易出性能問題。

綜合所述,F(xiàn)lutter 是性能最接近原生代碼 的一種開發(fā)框架,未來也會是構建谷歌Fuchsia應用的主要方式,前途不可限量,唯一的問題就是需要學習一門新的語言:Dart,而有Java或者C#語言基礎的程序員會比較容易學習。

flutter頁面卡頓檢測

對于任何一款應用來說,頁面的流暢度是用戶體驗最重要的幾個指標之一。我們需要用數(shù)據(jù)的形式標識出頁面的流暢程度。

對于大部分人而言,當每秒的畫面達到60,也就是俗稱60FPS的時候,整個過程就是流暢的。一秒 60 幀,也就意味著平均兩幀之間的間隔為 16.7ms。但并不意味著一秒低于60幀,人眼就會感覺到卡頓。小轟將查閱到的資料列出如下:

官方SDK為開發(fā)者提供的幀率檢測工具,使用非常簡單,在 MaterialApp 下添加屬性 showPerformanceOverlay:true 。

如圖,PerformanceOverLay 會分別為我們展示了構建(UI)耗時和渲染(Raster)耗時。

一款pub上的開源工具,鏈接地址: fps_monitor

本文名稱:flutter降幀,flutter 幀率監(jiān)控
文章起源:http://aaarwkj.com/article46/dsiiihg.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、動態(tài)網(wǎng)站App開發(fā)、云服務器、企業(yè)網(wǎng)站制作、Google

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設
久草手机福利在线观看| 久久夜色精品国产高清不卡| 超碰欧美黄色免费在线| 亚洲淫婷婷久久一区二区| 日本高清久久一区二区三区| 日韩不卡高清免费在线视频| 高清在线一区二区在线| 日韩精品高清不卡一区二区三区| 免费一区二区三区黄色| 国产原创av剧情在线观看| 国产欧美日韩综合91| 日本人妻伦理在线播放| 国产精品综合日韩精| 久久99热这里只频精品| 婷婷综合伊人久久狠狠| 中文字幕欧美人妻在线| 亚洲码av一区二区三区| 亚洲国产精品性色av| 午夜神马福利激情视频| 中文字幕一区二区三区不卡日日 | 国产日韩欧美国产精品| 蜜臀视频网站在线观看| 国产精品一区二区三区 在线 | 天天操天天射夜夜撸| 日本高清视频免费一区| 日本一区二区三区视频版| 国产日韩传媒在线观看| 日本免费一区二区在线视频| 亚洲精品国产高清久久| 99精品热视频在线观看| 韩国电视剧大全免费国语观看| 在线观看视频网站一卡二卡| 岛国av在线免费观看| 精品乱码一区二区三区四区| 国产 亚洲 一区 二区| 亚洲乱码国产乱码精品| 久久精品久久黄色片看看| 丰满高潮少妇在线观看| 人妻中出中文字幕一区二区| 国产一区二区精品久久岳| 人妻的秘密一区二区三区|