SvgTransform.fromString constructor

SvgTransform.fromString(
  1. String? transform
)

Implementation

factory SvgTransform.fromString(String? transform) {
  if (transform == null) {
    return none;
  }

  final mat = Matrix4.identity();

  for (final m in _transformRegExp.allMatches(transform)) {
    final name = m.group(1);
    final parameterList = SvgParser.splitDoubles(m.group(2)!).toList();

    switch (name) {
      case 'matrix':
        final mm = <double>[
          ...parameterList,
          ...List.filled(6 - parameterList.length, 0.0)
        ];

        mat.multiply(Matrix4(mm[0], mm[1], 0, 0, mm[2], mm[3], 0, 0, 0, 0, 1,
            0, mm[4], mm[5], 0, 1));
        break;
      case 'translate':
        final dx = parameterList[0];
        final dy = [...parameterList, .0][1];

        mat.multiply(Matrix4.identity()..translate(dx, dy));
        break;
      case 'scale':
        final sw = parameterList[0];
        final sh = [...parameterList, sw][1];

        mat.multiply(Matrix4.identity()..scale(sw, sh));
        break;
      case 'rotate':
        final degrees = parameterList[0];

        var ox = 0.0;
        var oy = 0.0;
        if (parameterList.length > 1) {
          // Rotation about the origin (ox, oy)
          ox = parameterList[1];
          oy = [...parameterList, .0][2];
          mat.translate(ox, oy);
        }

        mat.multiply(Matrix4.rotationZ(radians(degrees)));

        if (ox != 0 || oy != 0) {
          mat.translate(-ox, -oy);
        }
        break;

      case 'skewX':
        // assert(false, 'skewX');
        mat.multiply(Matrix4.skewX(radians(parameterList[0])));
        break;
      case 'skewY':
        // assert(false, 'skewY');
        mat.multiply(Matrix4.skewY(radians(parameterList[0])));
        break;
    }
  }

  return SvgTransform(mat);
}