繁体   English   中英

如何在 flutter 的 Matrix Gesture Detector 小部件中重置矩阵的比例?

[英]How to reset scale of matrix in Matrix Gesture Detector widget in flutter?

我正在使用 flutter 中的矩阵手势检测器小部件。 我设法重置了缩放比例,但是当我下次放大时,它从上次缩放的 position 开始。 我找不到解决方案来解决这个问题。 有人可以告诉我从原始 position 开始的方法这是我的代码

import 'package:flutter/material.dart';
import 'package:matrix_gesture_detector/matrix_gesture_detector.dart';

class ZoomableWidget extends StatefulWidget {
  final Widget child;

  const ZoomableWidget({Key key, this.child}) : super(key: key);
  @override
  _ZoomableWidgetState createState() => _ZoomableWidgetState();
}

class _ZoomableWidgetState extends State<ZoomableWidget> {
  Matrix4 matrix = Matrix4.identity();
  Matrix4 resetMatrix =  Matrix4.identity();

  @override
  Widget build(BuildContext context) {
    return GestureDetector(
      onDoubleTap: (){
        setState(() {
          matrix = resetMatrix;
        });
      },
      child: MatrixGestureDetector(
        shouldRotate: false,
        onMatrixUpdate: (Matrix4 m, Matrix4 tm, Matrix4 sm, Matrix4 rm) {
          setState(() {
            matrix = m;
          });
        },
        child: Transform(
          transform: matrix,
          child: widget.child,
        ),
      ),
    );
  }
}

您需要修复onMatrixUpdate方法:

onMatrixUpdate: (Matrix4 m, Matrix4 tm, Matrix4 sm, Matrix4 rm) {
  setState(() {
    matrix = MatrixGestureDetector.compose(matrix, tm, sm, rm);
  });
},

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM