前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Canonical通过Flutter启用Linux桌面应用程序支持

Canonical通过Flutter启用Linux桌面应用程序支持

作者头像
老孟Flutter
发布2020-09-11 16:58:17
2.6K0
发布2020-09-11 16:58:17
举报
文章被收录于专栏:FlutterFlutter

子标题:Ubuntu团队为所有Linux发行版上的Flutter应用程序制作了一个新的基于GTK +的主机。 此文翻译自:https://medium.com/flutter/announcing-flutter-linux-alpha-with-canonical-19eb824590a9 作者:克里斯·塞尔斯(Chris Sells)(Google)和肯·范丁(Ken VanDine)(Canonical)

Google 对 Flutter 的目标一直是提供一个可移植的工具包,以构建媲美本机速度运行的精美UI,无论您使用的是哪个平台。为了验证该功能,我们首先关注于Android和iOS移动平台,我们已经在Google Play上看到了8万多个快速,精美的Flutter应用程序。

为了获得成功,一年多来,我们一直将重点扩展到包括桌面级体验,包括针对Web和桌面操作系统(macOS,Windows和Linux)的体验。这项工作包括对引擎进行广泛的重构,以支持桌面样式的鼠标和键盘输入,以及可调整大小的顶级窗口。它还包括新的UI功能,可以很好地适应桌面,例如Material Density支持和NavigationRail,还可以通过Dart:FFI中的实验与基础桌面OS进行深度集成,并可以访问系统菜单栏和标准对话框。所有这些工作是为了确保除了适合移动样式的体验之外,Flutter还准备处理功能齐全的全尺寸桌面应用程序。

为Flutter平台提供动力是我们长期的愿景。我们已经在Google上看到了带有Assistant等产品的清单,所以现在我们很高兴看到其他人利用Flutter来支持更多平台。今天,我们很高兴与全球最流行的台式机Linux发行版Ubuntu的发行商Canonical共同宣布Flutter的Linux alpha版本。

为什么要在Linux上使用Flutter?

去年,当Google宣布对Flutter提供桌面级应用程序支持时,Canonical看到了一个令人振奋的机会来进行Linux发行,包括Ubuntu,这是Flutter应用程序开发人员的有吸引力的目标平台。Flutter的原生跨平台故事正在迅速发展,Canonical希望成为先锋。通过在Flutter中启用桌面Linux支持,Canonical使得应用程序开发人员可以非常轻松地通过Snap Store(Linux应用程序商店)为Linux用户发布他们的应用程序。通过使Linux成为一流的Flutter平台,Canonical邀请应用程序开发人员将其应用程序发布给数百万Linux用户,并扩大可供他们使用的高质量应用程序的可用性。

有关Flutter的许多事情对于Canonical来说是令人兴奋的:

  • 快速发展的应用程序开发人员生态系统
  • 多平台支持
  • 高度优化的本机应用程序
  • 现代的UI框架,支持声明式,反应式和可组合的小部件
  • 使用Visual Studio Code,Android Studio和IntelliJ的丰富开发平台

Google最初宣布的Flutter桌面支持宣布是从支持macOS的Alpha版本以及针对Linux和Windows的计划开始的。Canonical 通过组建一支开发人员团队与Google的开发人员合作,将Flutter的最佳体验带给大多数Linux发行版,从而对Flutter进行了重大投资。Canonical将继续与Google合作,以进一步改善Linux支持并保持与其他受支持平台的功能对等。

Flokk:证明Flutter已为台式机做好准备

为了证明Flutter已为台式机做好了准备,我们与gskinner的设计师和开发人员合作,创建了创新的,精美的Flutter台式机应用程序。Flokk是一个真实世界的应用程序,可处理真实世界的数据,尤其是您的Google联系人列表。

此视频地址:https://www.youtube.com/watch?time_continue=120&v=cTFJcq7UTRY&feature=emb_logo

除了能够管理您的联系人(包括搜索联系人,添加新联系人和编辑现有联系人)之外,Flokk还使您可以将GitHub和Twitter处理与您的联系人信息。

GitHub和Twitter通知的显示将您的联系人变成您自己的个人社交网络。而且,如果您在Flokk Contacts中没有看到您喜欢的社交网络,那么好消息是Flokk是完全开源的,因此您可以提交PR来添加您喜欢的。

除了在社交空间中进行创新外,Flokk还使用Flutter功能使外观看起来很棒。仅作为一个示例,深色主题不仅可以切换颜色,还可以对更改进行动画处理。

Flokk Contacts应用程序背后的创意团队由Grant Skinner领导,他以出色的设计和实施创新的用户体验而闻名。Grant曾说过关于在Linux上使用Flutter:

“构建Flokk Contacts应用程序非常容易!我们几乎无需进行任何调整就可以将我们在Flutter上的所有专业知识应用于目标Linux,并且该应用程序运行出色。与Canonical团队合作是一次很棒的经历。他们热心,投入并热衷于使Flutter不仅针对Linux,而且针对每个平台都变得更好。这是一个了不起的项目,我很高兴能够使用Flutter定位另一个主要的操作系统。” —Grant Skinner

如果您想在Linux机器上使用Flokk应用,则可以在GitHub上下载最新版本。或者,如果您正在快速运行,则可以从Snap Store下载Flokk应用。

在Linux上轻松安装Flutter

现在,您已经了解了Flutter在桌面类应用程序(尤其是Linux)上的运行情况,您将希望使其在自己的Linux机器上运行。为使操作尽可能简单,我们很高兴在Snap Store中提供Linux版Flutter SDK。Flutter SDK快照提供了在您喜欢的Linux发行版上开发Flutter应用程序所需的一切。无需安装大量开发依赖项;只需安装Flutter SDK快照和您最喜欢的IDE,便拥有了创建,构建和发布Linux应用程序所需的一切。

例如,如果您想开始为Linux开发Flutter应用程序,并且您选择的IDE是Visual Studio Code,那么这就是您在Linux终端上需要做的一切:

代码语言:javascript
复制
$ snap install --classic flutter
$ snap install --classic code
$ code --install-extension dart-code.flutter

如果您还想使用Linux开发移动应用程序,则可以通过安装Android SDK或Android Studio(包括Android SDK)来实现。有关Flutter SDK的更多信息,请访问https://snapcraft.io/flutter

适用于Linux桌面的Flutter

在Linux机器上安装Flutter SDK之后,要构建桌面应用程序,您需要升级到Flutter开发人员或主渠道。然后启用Linux桌面支持:

代码语言:javascript
复制
$ flutter channel dev
$ flutter upgrade
$ flutter config --enable-linux-desktop

现在,当您创建一个新的Flutter项目时,您将获得一个linux子目录,该目录可让您在Linux桌面上运行该应用程序:

代码语言:javascript
复制
$ flutter create counter
$ cd counter
$ flutter run -d linux

您将获得一个运行在Flutter上且运行于最新稳定版本GTK +上的闪亮的Linux新应用程序。如果您有一个现有的Flutter项目,并且希望在启用Linux之后向其添加Linux支持,则可以添加linux子目录,如下所示:

代码语言:javascript
复制
$ cd my_flutter_app
$ flutter create .

这将使用需要在Linux桌面上构建和运行Flutter应用程序的Runner项目创建linux子目录。

从Flutter访问Linux中的本机代码

除了通过编写Dart来创建Flutter小部件来支持桌面之外,您的Linux桌面应用还可以使用平台渠道或C / C ++的Dart外部功能接口访问所有本机Linux。或者,如果您想重复使用现有代码,则可以在pub.dev,Dart和Flutter的程序包管理器网站上找到该代码。在pub.dev上可以找到的大多数软件包都是纯Dart的,大多数都可以在Linux应用程序中正常工作。有些软件包(称为插件)中包含特定于一个或多个平台的本机代码。作为此版本的一部分,我们在pub.dev上发布了三个使用Linux本机功能的插件:

  • url_launcher: 在提供的URL上启动默认浏览器
  • shared_preferences: 应用会话之间共享的用户首选项
  • path_provider: 有关专用目录的路径信息,例如下载,图片等

您可以在应用程序中使用这些插件中的每个插件,并作为如何从Flutter代码本地访问Linux的示例,例如 Linux implementation of url_launcher。

部署到 Snap Store

要将Flutter应用程序部署到Snap Store,首先需要安装Snapcraft,该工具将用于快速构建和发布应用程序:

代码语言:javascript
复制
$ sudo snap install snapcraft --classic

要驱动Snapcraft工具,您需要在应用程序的项目目录中创建一个snapcraft.yaml文件。例如,这是Flokk的snapcraft.yaml文件:

代码语言:javascript
复制
name: flokk-contacts
version: 1.0.1
summary: Flokk Contacts
description: A fresh and modern Google Contacts manager that integrates with GitHub and Twitter.
confinement: strict
base: core18
grade: stable
apps:
  flokk-contacts:
    command: flokk-contacts
    extensions: [flutter-master]
    plugs:
    - network
parts:
  flokk-contacts:
    source: .
    plugin: flutter
    flutter-target: lib/main.dart # app's main entry-point file

现在,在带有snapcraft.yaml文件的目录中,您可以运行snapcraft来构建应用程序的快照。

代码语言:javascript
复制
$ snapcraft

如果一切顺利,这将在您当前的工作目录中生成一个文件,例如flokk-contacts_1.0.1_amd64.snap。

设置好要在Snap Store中发布的帐户后,即可发布snap:

代码语言:javascript
复制
$ snapcraft login
$ snapcraft register flokk-contacts
$ snapcraft upload flokk-contacts_1.0.1_amd64.snap --release edge

此命令会将应用程序上载到Snap Store,并尝试将其发布到边缘通道。在边缘通道中发布应用程序后,可以通过Snap Store Desktop客户端或使用命令行来安装它:

代码语言:javascript
复制
$ snap install --edge flokk-contacts

有关构建第一个快照并将其发布在Snap Store中的更多详细信息,请参阅 https://snapcraft.io/first-snap#flutter 以获取指导教程。

Flutter Linux桌面案例

Flokk应用程序是针对Linux桌面的真实Flutter应用程序的绝佳示例。对于更简单的示例,您可以查看照片搜索应用程序,该应用程序还专门用于展示桌面功能。

Photo Search是一个简单的在线照片搜索应用程序,它使用多个插件来访问本机平台功能,同时支持macOS和Linux。

对于带有分步说明的示例Linux桌面应用程序,我建议编写Write Flutter桌面应用程序代码实验室,该教程将指导您使用OAuth和GraphQL在Flutter中构建GitHub客户端。

对于一个功能更全面的应用程序,该应用程序可以使用Flutter的更多表面积并提供几个小程序,我推荐Flutter Gallery,该软件去年进行了重新设计,以支持台式机和移动设备。如果您希望看到它的实际效果,也可以在Snap Store中查看。

Thorsten Lorenz制作的一款名为batufo的多人游戏是另一个展示Flutter有趣之处的桌面应用程序。游戏以美丽的背景为背景,使来自世界各地的玩家可以实时相互竞争。

Thorsten一直在开发该游戏,以支持多个Flutter平台,包括Linux,macOS,Android和iOS。如果您想了解他的工作方式并了解未来的更新,那么他可以将他的编码会议作为视频提供,而将代码提供给GitHub。要从Linux安装游戏,您可以从Snap Store中将其下拉。

摘要

通过此Alpha版本以及Google与Canonical之间的紧密合作,Linux开发人员可以为其选择的操作系统获得Flutter支持。通过快照安装Flutter SDK。使用Visual Studio Code或Android Studio在Linux上构建和测试您的桌面应用程序。将您的应用程序部署到Snap Store。有关最新详细信息,请参见flutter.dev上的桌面页面。最重要的是,确保提供反馈,以便我们能够继续努力为每个受支持的Flutter平台做最好的Flutter。

来自Canonical团队的Linux Flutter,对于我们的梦想是向前迈出了一大步,无论您将目标对准哪个平台,Flutter都是构建应用程序的最佳方法。针对台式机的定位使得Flutter引擎更加适应Google本身无法直接支持的长尾设备,但我们计划为此继续建立合作伙伴关系并实现生态系统。

无论哪里的设备都需要快速,精美的应用程序,这就是我们希望Flutter成为的地方。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-07-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 老孟Flutter 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么要在Linux上使用Flutter?
  • Flokk:证明Flutter已为台式机做好准备
  • 在Linux上轻松安装Flutter
  • 适用于Linux桌面的Flutter
  • 从Flutter访问Linux中的本机代码
  • 部署到 Snap Store
  • Flutter Linux桌面案例
  • 摘要
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档