Метод выполнения флаттера, пока кнопка нажата - PullRequest
0 голосов
/ 01 сентября 2018

Мне нужно выполнить метод, когда пользователь нажимает кнопку, и во время этой операции нажатия, другими словами, пользователь нажимает кнопку в течение неизвестного периода времени, и мне нужно выполнить метод в течение этого периода времени. У любого есть представление, как я могу сделать это во Flutter я попробовал GestureDetector, но нет никакой опции, чтобы сделать это, также onLongPress не имеет этой опции, потому что при длинном нажатии срабатывает после нажатия Операция Я напишу псевдокод для того, что мне нужно:

While(Button.isPressed){
 //Execute Method
 }

1 Ответ

0 голосов
/ 02 сентября 2018

Используйте Listener и виджет с сохранением состояния. Я также ввел небольшую задержку после каждого цикла:

import 'dart:async';

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(brightness: Brightness.dark),
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;

  bool _buttonPressed = false;
  bool _loopActive = false;

  void _increaseCounterWhilePressed() async {
    // make sure that only one loop is active
    if (_loopActive) return;

    _loopActive = true;

    while (_buttonPressed) {
      // do your thing
      setState(() {
        _counter++;
      });

      // wait a bit
      await Future.delayed(Duration(milliseconds: 200));
    }

    _loopActive = false;
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(),
      body: Center(
        child: Listener(
          onPointerDown: (details) {
            _buttonPressed = true;
            _increaseCounterWhilePressed();
          },
          onPointerUp: (details) {
            _buttonPressed = false;
          },
          child: Container(
            decoration: BoxDecoration(color: Colors.orange, border: Border.all()),
            padding: EdgeInsets.all(16.0),
            child: Text('Value: $_counter'),
          ),
        ),
      ),
    );
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...