一文帶你了解Android?Flutter中Transform的使用
簡(jiǎn)介
雖然我們?cè)陂_發(fā)APP的過程中是以功能為主,但是有時(shí)候?yàn)榱嗣烙^或者其他的特殊的需求,需要對(duì)組件進(jìn)行一些變換。在Flutter中這種變換就叫做Transform。
flutter的強(qiáng)大之處在于,可以對(duì)所有的widget進(jìn)行Transform,因此可以做出非??犰诺男Ч?。
Transform簡(jiǎn)介
在Flutter中,Transform本身也是一個(gè)Widget,它主要是把變換作用在它的子widget上。我們先來(lái)看下Transform的定義和構(gòu)造函數(shù):
class Transform extends SingleChildRenderObjectWidget const Transform({ Key? key, required this.transform, this.origin, this.alignment, this.transformHitTests = true, this.filterQuality, Widget? child, }) : assert(transform != null), super(key: key, child: child);
可以看到Transform需要transform,origin,alignment,transformHitTests和filterQuality這幾個(gè)屬性。
其中transform是一個(gè)Matrix4對(duì)象,它是一個(gè)4維的矩陣,用來(lái)描述child應(yīng)該怎么被transform。
origin是一個(gè)Offset對(duì)象,表示的是原始坐標(biāo)系的值,默認(rèn)是左上角。origin和transform是有關(guān)聯(lián)關(guān)系的,我們可以通過修改origin來(lái)達(dá)到不同的transform的效果。
alignment是origin的對(duì)其方式,是一個(gè)AlignmentGeometry對(duì)象。
filterQuality是在進(jìn)行圖像變換的過程中,圖像的取樣質(zhì)量。
除了上面這個(gè)默認(rèn)的構(gòu)造函數(shù)之外,為了簡(jiǎn)單起見Transform還提供了幾個(gè)有特殊作用的構(gòu)造函數(shù):
Transform.rotate({ Key? key, required double angle, this.origin, this.alignment = Alignment.center, this.transformHitTests = true, this.filterQuality, Widget? child, }) : transform = Matrix4.rotationZ(angle), super(key: key, child: child);
Transform.rotate就是對(duì)子child進(jìn)行旋轉(zhuǎn)變換。
通過傳入angle屬性,實(shí)現(xiàn)子child沿Z軸旋轉(zhuǎn)。
Transform.translate({ Key? key, required Offset offset, this.transformHitTests = true, this.filterQuality, Widget? child, }) : transform = Matrix4.translationValues(offset.dx, offset.dy, 0.0), origin = null, alignment = null, super(key: key, child: child);
Transform.translate是通過改變offset的值來(lái)修改原始坐標(biāo)系的位置。
Transform.scale({ Key? key, required double scale, this.origin, this.alignment = Alignment.center, this.transformHitTests = true, this.filterQuality, Widget? child, }) : transform = Matrix4.diagonal3Values(scale, scale, 1.0), super(key: key, child: child);
Transform.scale通過傳入scale,來(lái)對(duì)子child進(jìn)行放大縮小。
從上面的不同構(gòu)造函數(shù)可以看出來(lái),實(shí)際上最終都將傳入的參數(shù)轉(zhuǎn)換成為Matrix4的transform對(duì)象。
如果你對(duì)Matrix4熟悉的話,那么可以用最直接的構(gòu)造函數(shù),直接傳入Matrix4。
Transform的使用
上面我們介紹了Transform.rotate,Transform.translate和Transform.scale這幾個(gè)構(gòu)造函數(shù),接下來(lái)我們將會(huì)使用具體的例子來(lái)進(jìn)行詳細(xì)的講解。
首先是Transform.rotate,用來(lái)對(duì)子組件進(jìn)行旋轉(zhuǎn),下面是一個(gè)使用的例子:
Widget build(BuildContext context) { return Center( child: Transform.rotate( angle: pi/4, child: const Icon( Icons.airplanemode_active, size: 200, color: Colors.blue, ), )); }
上面的例子將一個(gè)飛機(jī)的Icon旋轉(zhuǎn)pi/4,也就是45度,最后生成的界面如下:
接下來(lái)是Transform.translate,這個(gè)方法主要是對(duì)子組件進(jìn)行坐標(biāo)軸變換,需要傳入一個(gè)offset選項(xiàng),如下所示:
return Transform.translate( offset:const Offset(50.0, 100.0), child: const Icon( Icons.airplanemode_active, size: 200, color: Colors.blue, ), );
上面我們還是使用了飛機(jī)的圖標(biāo),不過對(duì)他進(jìn)行了坐標(biāo)軸變換,最后得出的界面如下:
最后我們要展示的是Transform.scale,用來(lái)對(duì)子組件進(jìn)行縮放。
上面我們的圖標(biāo)size是200,我們可以將其縮放為50%,如下所示:
return Transform.scale( scale: 0.5, child: const Icon( Icons.airplanemode_active, size: 200, color: Colors.blue, ), );
運(yùn)行我們可以得到下面的界面:
是不是變小了很多?
總結(jié)
Transform是一個(gè)功能強(qiáng)大的widget,通過Transform我們可以做出很多非常有趣的效果。
以上就是一文帶你了解Android Flutter中Transform的使用的詳細(xì)內(nèi)容,更多關(guān)于Android Flutter Transform的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android使用HorizontalScrollView實(shí)現(xiàn)水平滾動(dòng)
這篇文章主要為大家詳細(xì)介紹了Android使用HorizontalScrollView實(shí)現(xiàn)水平滾動(dòng),并點(diǎn)擊有相應(yīng)的反應(yīng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11Android入門之TableLayout應(yīng)用解析(一)
這篇文章主要介紹了Android入門之TableLayout應(yīng)用,需要的朋友可以參考下2014-08-08Android 中從屏幕左下角彈出Dialog動(dòng)畫效果的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android 中從屏幕左下角彈出Dialog動(dòng)畫效果的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12Android Fragment中使用SurfaceView切換時(shí)閃一下黑屏的解決辦法
本篇文章主要給大家分享Android Fragment中使用SurfaceView切換時(shí)閃一下黑屏的解決辦法,需要的朋友可以參考下2015-09-09Android 斷點(diǎn)下載和自動(dòng)安裝的示例代碼
本篇文章主要介紹了Android斷點(diǎn)下載和自動(dòng)安裝的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2018-01-01Android開發(fā) -- 控件的顯示與隱藏 setVisibility View.VISIBLE View.INVISI
本文簡(jiǎn)單介紹在Android開發(fā)中控件的顯示與隱藏幾種常見的屬性,給大家一個(gè)參考,希望對(duì)大家學(xué)習(xí)有所幫助。2016-06-06Android性能優(yōu)化之RecyclerView分頁(yè)加載組件功能詳解
這篇文章主要為大家介紹了Android性能優(yōu)化之RecyclerView分頁(yè)加載組件功能詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Android AIDL和遠(yuǎn)程Service調(diào)用示例代碼
本文主要介紹Android AIDL和遠(yuǎn)程Service,這里詳細(xì)介紹了相關(guān)知識(shí),并附實(shí)例代碼和實(shí)現(xiàn)效果圖,有興趣的朋友參考下2016-08-08