flutter 螢幕適配 demo main
一種一勞永逸的全域性適配方式
效果
320x480
data:image/s3,"s3://crabby-images/cd6c9/cd6c959f34d768ad1e29d4eb13faa9d91e0559f8" alt="flutter螢幕適配 ,一種一勞永逸的全域性適配方式"
1080x1920
data:image/s3,"s3://crabby-images/53d0c/53d0c43adfb6bf35d61237b69b6f089bb006fb23" alt="flutter螢幕適配 ,一種一勞永逸的全域性適配方式"
原理 (具體程式碼 main)
1.更改配置的 ViewConfiguration 的size和devicePixelRatio (ViewConfiguration 這個類再 RenderView 裡賦值,而RenderView是
renderObject樹的根,在佈局和繪製的過程中,會根據ViewConfiguration的值來做由父向子的佈局繪製操作)
2.PointerDataPacket 從引擎衝過來的事件,預設採用的是 系統的devicePixelRatio ,這裡就需要適用我們的值
複寫 initInstances() 內部 ui.window.onPointerDataPacket=_handlePointerDataPacket 賦值以下
void _handlePointerDataPacket(ui.PointerDataPacket packet) {
_pendingPointerEvents.addAll(PointerEventConverter.expand(
packet.data,
// 適配事件的轉換比率,採用我們修改的
getAdapterRatio()));
if (!locked) _flushPointerEventQueue();
}
複製程式碼