box_decoration_test.dart 4.26 KB
Newer Older
Ian Hickson's avatar
Ian Hickson committed
1
// Copyright 2014 The Flutter Authors. All rights reserved.
2 3 4 5
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'package:flutter/painting.dart';
6
import 'package:flutter_test/flutter_test.dart';
7 8 9 10

import '../rendering/mock_canvas.dart';

void main() {
11 12 13 14 15 16
  test('BoxDecoration.lerp identical a,b', () {
    expect(BoxDecoration.lerp(null, null, 0), null);
    const BoxDecoration decoration = BoxDecoration();
    expect(identical(BoxDecoration.lerp(decoration, decoration, 0.5), decoration), true);
  });

17
  test('BoxDecoration with BorderRadiusDirectional', () {
18 19 20
    const BoxDecoration decoration = BoxDecoration(
      color: Color(0xFF000000),
      borderRadius: BorderRadiusDirectional.only(topStart: Radius.circular(100.0)),
21 22
    );
    final BoxPainter painter = decoration.createBoxPainter();
23
    const Size size = Size(1000.0, 1000.0);
24 25 26 27
    expect(
      (Canvas canvas) {
        painter.paint(
          canvas,
28
          Offset.zero,
29 30 31 32
          const ImageConfiguration(size: size, textDirection: TextDirection.rtl),
        );
      },
      paints
33
        ..rrect(rrect: RRect.fromRectAndCorners(Offset.zero & size, topRight: const Radius.circular(100.0))),
34 35 36 37 38 39 40
    );
    expect(decoration.hitTest(size, const Offset(10.0, 10.0), textDirection: TextDirection.rtl), isTrue);
    expect(decoration.hitTest(size, const Offset(990.0, 10.0), textDirection: TextDirection.rtl), isFalse);
    expect(
      (Canvas canvas) {
        painter.paint(
          canvas,
41
          Offset.zero,
42 43 44 45
          const ImageConfiguration(size: size, textDirection: TextDirection.ltr),
        );
      },
      paints
46
        ..rrect(rrect: RRect.fromRectAndCorners(Offset.zero & size, topLeft: const Radius.circular(100.0))),
47 48 49 50
    );
    expect(decoration.hitTest(size, const Offset(10.0, 10.0), textDirection: TextDirection.ltr), isFalse);
    expect(decoration.hitTest(size, const Offset(990.0, 10.0), textDirection: TextDirection.ltr), isTrue);
  });
51 52

  test('BoxDecoration with LinearGradient using AlignmentDirectional', () {
53 54 55
    const BoxDecoration decoration = BoxDecoration(
      color: Color(0xFF000000),
      gradient: LinearGradient(
56 57
        begin: AlignmentDirectional.centerStart,
        end: AlignmentDirectional.bottomEnd,
58 59 60
        colors: <Color>[
          Color(0xFF000000),
          Color(0xFFFFFFFF),
61 62 63 64
        ],
      ),
    );
    final BoxPainter painter = decoration.createBoxPainter();
65
    const Size size = Size(1000.0, 1000.0);
66
    expect(
67
      (Canvas canvas) {
68 69
        painter.paint(
          canvas,
70
          Offset.zero,
71 72 73 74 75 76
          const ImageConfiguration(size: size, textDirection: TextDirection.rtl),
        );
      },
      paints..rect(rect: Offset.zero & size),
    );
  });
77

78
  test('BoxDecoration.getClipPath with borderRadius', () {
79 80 81 82 83 84 85 86 87 88 89 90
    const double radius = 10;
    final BoxDecoration decoration = BoxDecoration(
      borderRadius: BorderRadius.circular(radius),
    );
    const Rect rect = Rect.fromLTWH(0.0, 0.0, 100.0, 20.0);
    final Path clipPath = decoration.getClipPath(rect, TextDirection.ltr);
    final Matcher isLookLikeExpectedPath = isPathThat(
      includes: const <Offset>[ Offset(30.0, 10.0), Offset(50.0, 10.0), ],
      excludes: const <Offset>[ Offset(1.0, 1.0), Offset(99.0, 19.0), ],
    );
    expect(clipPath, isLookLikeExpectedPath);
  });
91 92 93 94 95 96 97 98 99 100 101 102 103

  test('BoxDecoration.getClipPath with shape BoxShape.circle', () {
    const BoxDecoration decoration = BoxDecoration(
      shape: BoxShape.circle,
    );
    const Rect rect = Rect.fromLTWH(0.0, 0.0, 100.0, 20.0);
    final Path clipPath = decoration.getClipPath(rect, TextDirection.ltr);
    final Matcher isLookLikeExpectedPath = isPathThat(
      includes: const <Offset>[ Offset(50.0, 0.0), Offset(40.0, 10.0), ],
      excludes: const <Offset>[ Offset(40.0, 0.0), Offset(10.0, 10.0), ],
    );
    expect(clipPath, isLookLikeExpectedPath);
  });
104 105 106 107 108 109 110 111 112 113 114 115 116

  test('BoxDecorations with different blendModes are not equal', () {
    // Regression test for https://github.com/flutter/flutter/issues/100754.
    const BoxDecoration one = BoxDecoration(
      color: Color(0x00000000),
      backgroundBlendMode: BlendMode.color,
    );
    const BoxDecoration two = BoxDecoration(
      color: Color(0x00000000),
      backgroundBlendMode: BlendMode.difference,
    );
    expect(one == two, isFalse);
  });
117
}