【问题标题】:Flutter: Is there a way to prevent the screen from turning off?Flutter:有没有办法防止屏幕关闭?
【发布时间】:2019-05-27 12:13:40
【问题描述】:

我想构建一个“床头柜时钟”应用程序,并且我希望只要应用程序处于活动状态而不关闭屏幕,手机就会显示时钟。

有没有办法在 Flutter 中做到这一点?

我找到了this SO 答案,但使用“屏幕”插件对我不起作用。 将依赖项添加到“pubspecc.yaml”并运行flutter packages get 后,我的应用程序不再运行,Android SDK 卡在“解决依赖项”阶段。

不管怎样,除了'screen'插件之外,还有其他方法可以在flutter中做到这一点吗?

【问题讨论】:

  • 顺便说一句,屏幕插件解决方案对我有用。我认为您应该调查依赖关系问题,因为这种类型的事情只会再次发生,您最好了解正在发生的事情以及如何解决。
  • @Ian 谢谢!原来我只是把'Screen.keepOn(true);'选项在错误的地方。我试图把它放在根小部件的build 方法中。这就是应用程序没有运行的原因。在你告诉我它对你有用之后,我试着把它放在 main 函数中,现在它可以工作了!谢谢!
  • 也许它不准时 =) 这是另一种方法stackoverflow.com/a/56918918/4207348

标签: android flutter dart


【解决方案1】:

来自同一个SO post,提到screen plugin遇到了一些问题。我检查了插件,它似乎自 2019 年 3 月 13 日以来没有更新。另一个可以提供您需要的相同功能的插件是 wakelock plugin。它目前仍由作者维护。事实上,最新版本 0.5.0+2 于 2021 年 3 月 7 日发布。

嗨,我仍在维护它 :) 我们最近添加了 macOS 支持作为 ? 另外,Flutter 是开源的——他们有第一方插件, 然而,他们确实说他们自己会放弃他们的 如果存在更好的第三方项目,则提供第一方解决方案。所以为什么 他们会想为完美运行的东西创建一个吗? – 创意创造者或可能不是 2 月 8 日 16:17

我已经测试了wakelock package中给出的样本:

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

void main() {
  runApp(WakelockExampleApp());
}

class WakelockExampleApp extends StatefulWidget {
  @override
  _WakelockExampleAppState createState() => _WakelockExampleAppState();
}

class _WakelockExampleAppState extends State<WakelockExampleApp> {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Wakelock example app'),
        ),
        body: Center(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.spaceEvenly,
            children: <Widget>[
              const Spacer(
                flex: 3,
              ),
              OutlinedButton(
                onPressed: () {
                  setState(() {
                    Wakelock.enable();
                  });
                },
                child: const Text('enable wakelock'),
              ),
              const Spacer(),
              OutlinedButton(
                onPressed: () {
                  setState(() {
                    Wakelock.disable();
                  });
                },
                child: const Text('disable wakelock'),
              ),
              const Spacer(
                flex: 2,
              ),
              FutureBuilder(
                future: Wakelock.enabled,
                builder: (context, AsyncSnapshot<bool> snapshot) {
                  final data = snapshot.data;
                  if (data == null) {
                    return Container();
                  }

                  return Text('The wakelock is currently '
                      '${data ? 'enabled' : 'disabled'}.');
                },
              ),
              const Spacer(
                flex: 3,
              ),
            ],
          ),
        ),
      ),
    );
  }
}

这是 Android 中的输出:

iOS 中的输出:

此外,您似乎已经解决了代码中的上一个问题。很高兴分享a minimal, complete and verifiable example 让社区更好地了解这个问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-11-11
    • 2015-08-22
    • 2013-01-15
    • 1970-01-01
    • 1970-01-01
    • 2011-09-24
    • 2019-02-15
    • 1970-01-01
    相关资源
    最近更新 更多