flutter平台判断,这次应该没问题了。支持鸿蒙,插件已发布

话不多说,已经发布插件了

这次即便在web环境中也可以判断是否为鸿蒙系统

同时还支持鸿蒙系统判断是PC还是Mobile,但需要在使用之前调用一下

await OS.initHarmonyDeviceType();

避免报错请使用if (OS.isHarmony) await OS.initHarmonyDeviceType();

具体可以看下面的代码示例

代码示例:

dart 复制代码
import 'package:flutter/material.dart';
import 'package:os_type/os_type.dart';

Future<void> main() async {
  WidgetsFlutterBinding.ensureInitialized();
  // 如果需要在鸿蒙上判断是否为PC/Mobile,需要先await OS.initHarmonyDeviceType()
  if (OS.isHarmony) await OS.initHarmonyDeviceType();
  runApp(const MyApp());
}

class MyApp extends StatefulWidget {
  const MyApp({super.key});

  @override
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: const Text('os type example')),
        body: Center(
          child: Column(
            mainAxisSize: MainAxisSize.min,
            children: [
              Text('is android: ${OS.isAndroid}'),
              SizedBox(height: 8),
              Text('is fuchsia: ${OS.isFuchsia}'),
              SizedBox(height: 8),
              Text('is iOS: ${OS.isIOS}'),
              SizedBox(height: 8),
              Text('is linux: ${OS.isLinux}'),
              SizedBox(height: 8),
              Text('is macOS: ${OS.isMacOS}'),
              SizedBox(height: 8),
              Text('is windows: ${OS.isWindows}'),
              SizedBox(height: 8),
              Text('is ohos: ${OS.isHarmony}'),
              SizedBox(height: 8),
              // 上面的列举有更简单的写法:
              // for (var os in TargetPlatform.values) ...[
              //   Text('is ${os.name}: ${OS.value == os}'),
              //   SizedBox(height: 8),
              // ],

              // pc和mobile是相反的,而web环境则等于kIsWeb,与操作系统无关
              SizedBox(height: 20),
              Text('is PC: ${OS.isPCOS}'),
              SizedBox(height: 8),
              Text('is Mobile: ${OS.isMobileOS}'), // isMobileOS == !isPCOS
              SizedBox(height: 8),
              Text('is Web environment: ${OS.isWebEnv}'), // isWebEnv == kIsWeb
              SizedBox(height: 8),
            ],
          ),
        ),
      ),
    );
  }
}

运行截图

相关推荐
Swift社区4 小时前
鸿蒙 App 模块化拆分:架构解析 + 实战案例
华为·架构·harmonyos
不羁的木木4 小时前
HarmonyOS AI开发提效工具:DevEco Code & DevEco CLI - 实战:端侧AI文字识别应用
人工智能·华为·harmonyos
不羁的木木5 小时前
HarmonyOS AI开发提效工具:DevEco Code & DevEco CLI - 初识与配置指南
人工智能·华为·harmonyos
hahjee11 小时前
【鸿蒙PC】KCP应用集成:AtomCode驱动NAPI全流程
华为·harmonyos
木咺吟11 小时前
鸿蒙原生应用实战(五):塔罗牌App开发 — 数据模型、构建配置与工程优化
harmonyos
风华圆舞11 小时前
解析鸿蒙 SpeechRecognitionPlugin:从权限申请到识别回调的完整链路
华为·harmonyos
木咺吟11 小时前
鸿蒙原生应用实战(一):塔罗牌占卜App开发 — 环境搭建与首页开发
华为·harmonyos
木咺吟11 小时前
鸿蒙原生应用实战(二):塔罗牌App开发 — 牌义列表与路由导航
harmonyos
祭曦念11 小时前
【共创季稿事节】鸿蒙ArkTS图片插值布局实战
华为·harmonyos
梦想不只是梦与想12 小时前
鸿蒙 消息推送:Push Token的获取(四)
harmonyos·鸿蒙·推送