Listener 與 GestureDetector

  • Listener:
  • GestureDetector:
import 'package:flutter/material.dart';

void main() {
  runApp(const MaterialApp(
    home: ListenerWidget(),
  ));
}

class ListenerWidget extends StatefulWidget {
  const ListenerWidget({Key? key}) : super(key: key);

  @override
  State createState() => _ListenerWidgetSate();
}

class _ListenerWidgetSate extends State<ListenerWidget> {
  late String _operation = "No Gesture detected!";

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Column(
        children: [
          Listener(
            child: ConstrainedBox(
              constraints: BoxConstraints.tight(const Size(100.0, 100.0)),
              child: const DecoratedBox(
                  decoration: BoxDecoration(color: Colors.deepOrange)),
            ),
            onPointerDown: (event) => print("點擊事件"),
          ),
          GestureDetector(
            child: Container(
              alignment: Alignment.center,
              color: Colors.blue,
              width: 200.0,
              height: 100.0,
              child: Text(
                _operation,
                style: const TextStyle(color: Colors.white),
              ),
            ),
            onTap: () => updateText("Tap"),
            onDoubleTap: () => updateText("DoubleTap"),
            onLongPress: () => updateText("LongPress"),
          ),
        ],
      ),
    );
  }

  void updateText(String text) {
    //更新顯示的事件名
    setState(() {
      _operation = text;
    });
  }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容