簡體   English   中英

Flutter:有沒有辦法防止屏幕關閉?

[英]Flutter: Is there a way to prevent the screen from turning off?

我想構建一個“床頭櫃時鍾”應用程序,並且只要應用程序處於活動狀態,我希望手機在不關閉屏幕的情況下顯示時鍾。

有沒有辦法在 Flutter 中做到這一點?

我找到了這個SO 答案,但使用“屏幕”插件對我不起作用。 將依賴項添加到“pubspecc.yaml”並運行flutter packages get我的應用程序不再運行,Android SDK 卡在“解決依賴項”階段。

無論哪種方式,除了“屏幕”插件之外,還有其他方法可以在顫振中做到這一點嗎?

在同一個SO 帖子中,它提到屏幕插件遇到了一些問題。 我檢查了插件,它似乎自 2019 年 3 月 13 日以來沒有更新。另一個可以提供您需要的相同功能的插件喚醒鎖插件 它仍然可用,目前由作者維護。 事實上,最新版本0.5.0+2已於 2021 年 3 月 7 日發布。

嗨,我仍在維護它 :) 我們最近也添加了 macOS 支持派對項目存在。 那么他們為什么要為完美運行的東西創建一個呢? – creativecreatorormaybenot 2 月 8 日 16:17

我已經測試了wakelock 包中給出的示例:

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中的輸出:

在此處輸入圖片說明

此外,您似乎已經解決了代碼中的上一個問題。 最好能分享一個最小的、完整的和可驗證的例子,讓社區很好地理解這個問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM