91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

flutter PositionedTransition實現縮放動畫

發布時間:2020-10-18 05:56:44 來源:腳本之家 閱讀:277 作者:早起的年輕人 欄目:移動開發

本文實例為大家分享了flutter實現縮放動畫的具體代碼,供大家參考,具體內容如下

flutter 動畫狀態監聽器

AnimationController

//動畫控制器
AnimationController controller;
//AnimationController是一個特殊的Animation對象,在屏幕刷新的每一幀,就會生成一個新的值,
// 默認情況下,AnimationController在給定的時間段內會線性的生成從0.0到1.0的數字
//用來控制動畫的開始與結束以及設置動畫的監聽
//vsync參數,存在vsync時會防止屏幕外動畫(動畫的UI不在當前屏幕時)消耗不必要的資源
//duration 動畫的時長,這里設置的 seconds: 2 為2秒,當然也可以設置毫秒 milliseconds:2000.
 controller =
 AnimationController(duration: const Duration(seconds: 2), vsync: this);
 //動畫開始、結束、向前移動或向后移動時會調用StatusListener
 controller.addStatusListener((status) {
 if (status == AnimationStatus.completed) {
 //動畫從 controller.reverse() 反向執行 結束時會回調此方法
 print("status is completed");
 // controller.reset(); 將動畫重置到開始前的狀態
 //開始執行
 //controller.forward();
 } else if (status == AnimationStatus.dismissed) {
 //動畫從 controller.forward() 正向執行 結束時會回調此方法
 print("status is dismissed");
 //controller.forward();
 }else if (status == AnimationStatus.forward) {
 print("status is forward");
 //執行 controller.forward() 會回調此狀態
 }else if (status == AnimationStatus.reverse) {
 //執行 controller.reverse() 會回調此狀態
 print("status is reverse");
 }
 });

AnimationController 的常用操作說明

flutter PositionedTransition實現縮放動畫

flutter AnimationStatus 動畫狀態說明

flutter PositionedTransition實現縮放動畫

flutter PositionedTransition 實現中心縮放動畫

flutter PositionedTransition實現縮放動畫

動畫開始與結束分析

flutter PositionedTransition實現縮放動畫

import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_x/base/base_appbar_page.dart';

/**
 * RelativeRectTween 縮放動畫
 */
class RelativeRectTweenPage extends StatefulWidget {
 @override
 State<StatefulWidget> createState() {
 return new RelativeRectTweenState();
 }
}

class RelativeRectTweenState extends BaseAppBarPageState<RelativeRectTweenPage>
 with SingleTickerProviderStateMixin {
 //動畫控制器
 AnimationController controller;
 Animation<RelativeRect> animation;

 @override
 String buildInitState() {
 buildBackBar("動畫", backIcon: Icons.arrow_back_ios);
 controller =
 AnimationController(duration: const Duration(seconds: 2), vsync: this);
 //動畫開始、結束、向前移動或向后移動時會調用StatusListener
 controller.addStatusListener((status) {
 if (status == AnimationStatus.completed) {
 //動畫從 controller.forward() 正向執行 結束時會回調此方法
 print("status is completed");
 //反向執行
 //controller.reverse();
 } else if (status == AnimationStatus.dismissed) {
 //動畫從 controller.reverse() 反向執行 結束時會回調此方法
 print("status is dismissed");
 //controller.forward();
 } else if (status == AnimationStatus.forward) {
 print("status is forward");
 //執行 controller.forward() 會回調此狀態
 } else if (status == AnimationStatus.reverse) {
 //執行 controller.reverse() 會回調此狀態
 print("status is reverse");
 }
 });

 // 這個動畫的過程是
 // 子widget 距左邊距離從 10.0 變化 到100.0
 // 子widget 距上邊距離從 10.0 變化 到100.0
 // 子widget 距右邊距離從 10.0 變化 到100.0
 // 子widget 距下邊距離從 10.0 變化 到100.0
 // 四邊同時變化 相同的距離 倍率,所以看出來是 中心縮小的動畫
 RelativeRectTween rectTween = RelativeRectTween(
 //初始位置設置
 begin: const RelativeRect.fromLTRB(
  //子widget 距父布局 left 10.0
  10.0,
  //子widget 距父布局 top 10.0
  10.0,
  //子widget 距父布局 right 10.0
  10.0,
  //子widget 距父布局 bottom 10.0
  10.0),
 //結束位置設置
 end: RelativeRect.fromLTRB(
  //子widget 距父布局 left 100.0
 100.0,
  //子widget 距父布局 top 100.0
 100.0,
 //子widget 距父布局 right 100.0
 100.0,
 //子widget 距父布局 bottom 100.0
 100.0,
 ),
 );

 //關聯 controller
 animation = rectTween.animate(controller);

 return null;
 }

 @override
 Widget buildWidget(BuildContext context) {
 return buildSlideTransition();
 }

 @override
 void dispose() {
 super.dispose();
 controller.dispose();
 }

 //漸變動畫
 Widget buildSlideTransition() {
 return Stack(
 children: <Widget>[
 //必須作為Stack的子widget
 PositionedTransition(
  rect: animation,
  child: Container(
  color: Colors.grey,
  child: Image.network(
  "http://img5.duitang.com/uploads/item/201411/16/20141116124947_xBNxM.jpeg",
  ),
  ),
 ),
 Positioned(
  bottom: 20,
  left: 20,
  child: FlatButton(
  onPressed: () {
  if (controller.isDismissed) {
   ///正向動畫開始
   controller.forward();
  } else if (controller.isCompleted) {
   ///反向動畫開始
   controller.reverse();
  } else {
   //停止
   controller.dispose();
   //重置動畫
   controller.reset();
  }
  },
  child: Text("開始")),
 )
 ],
 );
 }
}

flutter PositionedTransition 向上縮放

flutter PositionedTransition實現縮放動畫

 RelativeRectTween rectTween = RelativeRectTween(
 //初始位置設置
 begin: const RelativeRect.fromLTRB(
  50.0,
  50.0,
  50.0,
  50.0),
 //結束位置設置
 end: RelativeRect.fromLTRB(
 50.0,
 50.0,
 50.0,
 500.0,
 ),
 );

flutter PositionedTransition 向右縮放

flutter PositionedTransition實現縮放動畫

RelativeRectTween rectTween = RelativeRectTween(
 //初始位置設置
 begin: const RelativeRect.fromLTRB(
  50.0,
  50.0,
  50.0,
  50.0),
 //結束位置設置
 end: RelativeRect.fromLTRB(
 500.0,
 50.0,
 50.0,
 50.0,
 ),
 );

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和龙市| 青州市| 大田县| 邢台县| 吕梁市| 连平县| 竹北市| 景泰县| 南华县| 河津市| 宽城| 莱芜市| 呼伦贝尔市| 闽侯县| 望谟县| 高平市| 新巴尔虎右旗| 莆田市| 云阳县| 西平县| 桂林市| 曲阳县| 天津市| 灵武市| 洪洞县| 鸡泽县| 陆良县| 岳阳县| 万安县| 舒兰市| 修文县| 阜阳市| 安龙县| 闽侯县| 香港| 江津市| 海盐县| 南宫市| 分宜县| 凯里市| 朔州市|