resize.dart 2.15 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

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

void main() async {
  runApp(const ResizeApp());
}

class ResizeApp extends StatefulWidget {
  const ResizeApp({super.key});

  static const double resizeBy = 10.0;
  static const Key heightLabel = Key('height label');
  static const Key widthLabel = Key('width label');
  static const Key extendedFab = Key('extended FAB');

  static const MethodChannel platform =
    MethodChannel('samples.flutter.dev/resize');

  static Future<void> resize(Size size) async {
    await ResizeApp.platform.invokeMethod<void>(
      'resize',
      <String, dynamic>{
        'width': size.width,
        'height': size.height,
      }
    );
  }

  @override
  State<ResizeApp> createState() => _ResizeAppState();
}

class _ResizeAppState extends State<ResizeApp> {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Builder(
        builder: (BuildContext context) {
          final Size currentSize = MediaQuery.of(context).size;
          return Scaffold(
            floatingActionButton: FloatingActionButton.extended(
              key: ResizeApp.extendedFab,
              label: const Text('Resize'),
              onPressed: () {
                final Size nextSize = Size(
                  currentSize.width + ResizeApp.resizeBy,
                  currentSize.height + ResizeApp.resizeBy,
                );
                ResizeApp.resize(nextSize);
              },
            ),
            body: Center(
              child: Column(
                mainAxisAlignment: MainAxisAlignment.center,
                children: <Widget>[
                  Text(
                    key: ResizeApp.widthLabel,
                    'width: ${currentSize.width}'
                  ),
                  Text(
                    key: ResizeApp.heightLabel,
                    'height: ${currentSize.height}',
                  ),
                ],
              ),
            ),
          );
        }
      ),
    );
  }
}