* fix some warnings and some deprecated reported by `flutter analyze` Signed-off-by: 21pages <pages21@163.com> * pubspec.lock changes from flutter 3.16.9 Signed-off-by: 21pages <pages21@163.com> * pubspec.lock changes from `flutter pub upgrade` Signed-off-by: 21pages <pages21@163.com> --------- Signed-off-by: 21pages <pages21@163.com>
		
			
				
	
	
		
			212 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			212 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
import 'package:flutter/material.dart';
 | 
						|
import 'package:flutter_hbb/common.dart';
 | 
						|
import 'package:toggle_switch/toggle_switch.dart';
 | 
						|
 | 
						|
class GestureIcons {
 | 
						|
  static const String _family = 'gestureicons';
 | 
						|
 | 
						|
  GestureIcons._();
 | 
						|
 | 
						|
  static const IconData iconMouse = IconData(0xe65c, fontFamily: _family);
 | 
						|
  static const IconData iconTabletTouch = IconData(0xe9ce, fontFamily: _family);
 | 
						|
  static const IconData iconGestureFDrag =
 | 
						|
      IconData(0xe686, fontFamily: _family);
 | 
						|
  static const IconData iconMobileTouch = IconData(0xe9cd, fontFamily: _family);
 | 
						|
  static const IconData iconGesturePress =
 | 
						|
      IconData(0xe66c, fontFamily: _family);
 | 
						|
  static const IconData iconGestureTap = IconData(0xe66f, fontFamily: _family);
 | 
						|
  static const IconData iconGesturePinch =
 | 
						|
      IconData(0xe66a, fontFamily: _family);
 | 
						|
  static const IconData iconGesturePressHold =
 | 
						|
      IconData(0xe66b, fontFamily: _family);
 | 
						|
  static const IconData iconGestureFDragUpDown_ =
 | 
						|
      IconData(0xe685, fontFamily: _family);
 | 
						|
  static const IconData iconGestureFTap_ =
 | 
						|
      IconData(0xe68e, fontFamily: _family);
 | 
						|
  static const IconData iconGestureFSwipeRight =
 | 
						|
      IconData(0xe68f, fontFamily: _family);
 | 
						|
  static const IconData iconGestureFdoubleTap =
 | 
						|
      IconData(0xe691, fontFamily: _family);
 | 
						|
  static const IconData iconGestureFThreeFingers =
 | 
						|
      IconData(0xe687, fontFamily: _family);
 | 
						|
}
 | 
						|
 | 
						|
typedef OnTouchModeChange = void Function(bool);
 | 
						|
 | 
						|
class GestureHelp extends StatefulWidget {
 | 
						|
  GestureHelp(
 | 
						|
      {Key? key, required this.touchMode, required this.onTouchModeChange})
 | 
						|
      : super(key: key);
 | 
						|
  final bool touchMode;
 | 
						|
  final OnTouchModeChange onTouchModeChange;
 | 
						|
 | 
						|
  @override
 | 
						|
  State<StatefulWidget> createState() => _GestureHelpState();
 | 
						|
}
 | 
						|
 | 
						|
class _GestureHelpState extends State<GestureHelp> {
 | 
						|
  var _selectedIndex;
 | 
						|
  var _touchMode;
 | 
						|
 | 
						|
  @override
 | 
						|
  void initState() {
 | 
						|
    _touchMode = widget.touchMode;
 | 
						|
    _selectedIndex = _touchMode ? 1 : 0;
 | 
						|
    super.initState();
 | 
						|
  }
 | 
						|
 | 
						|
  @override
 | 
						|
  Widget build(BuildContext context) {
 | 
						|
    final size = MediaQuery.of(context).size;
 | 
						|
    final space = 12.0;
 | 
						|
    var width = size.width - 2 * space;
 | 
						|
    final minWidth = 90;
 | 
						|
    if (size.width > minWidth + 2 * space) {
 | 
						|
      final n = (size.width / (minWidth + 2 * space)).floor();
 | 
						|
      width = size.width / n - 2 * space;
 | 
						|
    }
 | 
						|
    return Center(
 | 
						|
        child: Padding(
 | 
						|
            padding: const EdgeInsets.symmetric(vertical: 12.0),
 | 
						|
            child: Column(
 | 
						|
              mainAxisAlignment: MainAxisAlignment.center,
 | 
						|
              crossAxisAlignment: CrossAxisAlignment.center,
 | 
						|
              children: <Widget>[
 | 
						|
                ToggleSwitch(
 | 
						|
                  initialLabelIndex: _selectedIndex,
 | 
						|
                  activeFgColor: Colors.white,
 | 
						|
                  inactiveFgColor: Colors.white60,
 | 
						|
                  activeBgColor: [MyTheme.accent],
 | 
						|
                  inactiveBgColor: Theme.of(context).hintColor,
 | 
						|
                  totalSwitches: 2,
 | 
						|
                  minWidth: 150,
 | 
						|
                  fontSize: 15,
 | 
						|
                  iconSize: 18,
 | 
						|
                  labels: [translate("Mouse mode"), translate("Touch mode")],
 | 
						|
                  icons: [Icons.mouse, Icons.touch_app],
 | 
						|
                  onToggle: (index) {
 | 
						|
                    setState(() {
 | 
						|
                      if (_selectedIndex != index) {
 | 
						|
                        _selectedIndex = index ?? 0;
 | 
						|
                        _touchMode = index == 0 ? false : true;
 | 
						|
                        widget.onTouchModeChange(_touchMode);
 | 
						|
                      }
 | 
						|
                    });
 | 
						|
                  },
 | 
						|
                ),
 | 
						|
                const SizedBox(height: 30),
 | 
						|
                Container(
 | 
						|
                    child: Wrap(
 | 
						|
                  spacing: space,
 | 
						|
                  runSpacing: 2 * space,
 | 
						|
                  children: _touchMode
 | 
						|
                      ? [
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconMobileTouch,
 | 
						|
                              translate("One-Finger Tap"),
 | 
						|
                              translate("Left Mouse")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGesturePressHold,
 | 
						|
                              translate("One-Long Tap"),
 | 
						|
                              translate("Right Mouse")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGestureFSwipeRight,
 | 
						|
                              translate("One-Finger Move"),
 | 
						|
                              translate("Mouse Drag")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGestureFThreeFingers,
 | 
						|
                              translate("Three-Finger vertically"),
 | 
						|
                              translate("Mouse Wheel")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGestureFDrag,
 | 
						|
                              translate("Two-Finger Move"),
 | 
						|
                              translate("Canvas Move")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGesturePinch,
 | 
						|
                              translate("Pinch to Zoom"),
 | 
						|
                              translate("Canvas Zoom")),
 | 
						|
                        ]
 | 
						|
                      : [
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconMobileTouch,
 | 
						|
                              translate("One-Finger Tap"),
 | 
						|
                              translate("Left Mouse")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGesturePressHold,
 | 
						|
                              translate("One-Long Tap"),
 | 
						|
                              translate("Right Mouse")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGestureFSwipeRight,
 | 
						|
                              translate("Double Tap & Move"),
 | 
						|
                              translate("Mouse Drag")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGestureFThreeFingers,
 | 
						|
                              translate("Three-Finger vertically"),
 | 
						|
                              translate("Mouse Wheel")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGestureFDrag,
 | 
						|
                              translate("Two-Finger Move"),
 | 
						|
                              translate("Canvas Move")),
 | 
						|
                          GestureInfo(
 | 
						|
                              width,
 | 
						|
                              GestureIcons.iconGesturePinch,
 | 
						|
                              translate("Pinch to Zoom"),
 | 
						|
                              translate("Canvas Zoom")),
 | 
						|
                        ],
 | 
						|
                )),
 | 
						|
              ],
 | 
						|
            )));
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
class GestureInfo extends StatelessWidget {
 | 
						|
  const GestureInfo(this.width, this.icon, this.fromText, this.toText,
 | 
						|
      {Key? key})
 | 
						|
      : super(key: key);
 | 
						|
 | 
						|
  final String fromText;
 | 
						|
  final String toText;
 | 
						|
  final IconData icon;
 | 
						|
  final double width;
 | 
						|
 | 
						|
  final iconSize = 35.0;
 | 
						|
  final iconColor = MyTheme.accent;
 | 
						|
 | 
						|
  @override
 | 
						|
  Widget build(BuildContext context) {
 | 
						|
    return Container(
 | 
						|
        width: width,
 | 
						|
        child: Column(
 | 
						|
          children: [
 | 
						|
            Icon(
 | 
						|
              icon,
 | 
						|
              size: iconSize,
 | 
						|
              color: iconColor,
 | 
						|
            ),
 | 
						|
            SizedBox(height: 6),
 | 
						|
            Text(fromText,
 | 
						|
                textAlign: TextAlign.center,
 | 
						|
                style:
 | 
						|
                    TextStyle(fontSize: 9, color: Theme.of(context).hintColor)),
 | 
						|
            SizedBox(height: 3),
 | 
						|
            Text(toText,
 | 
						|
                textAlign: TextAlign.center,
 | 
						|
                style: TextStyle(
 | 
						|
                    fontSize: 12,
 | 
						|
                    color: Theme.of(context).textTheme.bodySmall?.color))
 | 
						|
          ],
 | 
						|
        ));
 | 
						|
  }
 | 
						|
}
 |