Android原生和Flutter使用过程的差异对比(一)
界面搭建过程中各种大小单位 Android:通常采用dp设置View宽高(和px像素的换算关系是dp值 × density逻辑密度),sp设置字体大小(会随着系统字体设置的大小而改变)。
常用布局的对比 使用下来其他组件大致还算方便,但是相对布局而言使用便利程度上Android原生完胜,ConstraintLayout内部的所有子View可以设置互相之间的位置依赖关系。
Flutter使用谷歌自己的Skia渲染引擎,而Android系统自带Skia引擎,iOS平台上Flutter也会把Skia引擎打包到APP中,从而实现了高效渲染。而React Native通过桥接层访问原生UI,操作频繁就容易出性能问题。
flutter进行广播注册会返回一个streamSubscription类型的对象,该对象可以进行消息的停止,native可在onCancel回调里面收到。
3、Flutter中ThemeData与AppBar
iconTheme :设置appbar icon的颜色,appbar中icon的颜色会根据primaryColor的改变来确定自身的颜色,这里可以在iconTheme中指定icon的颜色。
这里的ThemeData即为控制App的主题,primarySwatch设置即可控制主题的各类颜色,但是这里的颜色是需要MaterialColor,但是纯色种的黑色和白色不是MaterialColor。所以不能设置primarySwatch为Colors.white。
SliverAppBar 控件,一个 MD 的 AppBar 。属性和 AppBar 类似,但做的效果比 AppBar 更加强大。相同的属性具体可以看 Flutter 之 Scaffold 控件 , 里面有 AppBar 控件的介绍。
默认的appbar下方会自带一个阴影效果。要去掉这个阴影的话需要在appbar中设置:核心的思想就是在column中使用expend包裹一次然后child使用listView,这样的话输入框被聚焦的时候键盘就会把页面顶上去。
Flutter_为啥安卓字体效果和iOS不一样?3
除了两个平台的系统默认字体不一样之外。在设置字体字重(字体粗细)时。ios的字体粗细和下面截图中的一一对应。安卓的w500及以下都是正常字体,安卓的w600和w700相当于ios的w500,安卓的w800及以后都是一样粗细。
界面搭建过程中各种大小单位 Android:通常采用dp设置View宽高(和px像素的换算关系是dp值 × density逻辑密度),sp设置字体大小(会随着系统字体设置的大小而改变)。
因为flutter在release模式下的编译方式是AOT,iOS14+的系统是支持这种编译方式的,具体解决方案如下图 再运行就可以了。
支持热重载 :android原生开发会遇到编译-打包-安装三个步骤。开发效率迟迟得不到提升。热重载技术在flutter内完美体现。
原理:我们都知道,Flutter调用原生的API需要通过插件来实现,permission_handler就是获取原生手机权限。
Android 内置了 Skia,但 iOS 没有,所以在打 iOS 安装包的时候,会把 Skia 一起打进去。这就导致了,用同一份 Flutter 代码打包之后,iOS 的包要比 Android 的包大一些。 开发语言 Dart Flutter 使用的开发语言,叫 Dart。
Flutter发布Package(Pub.dev或私有Pub仓库)
1、pub.dev 是 Google 官方的 Dart 仓库,在上面可以找到我们需要的包和插件。 Flutter 本身没有 Toast,我们来接入一个。
2、在使用Flutter开发的时候,希望在浏览器中打开URL,而在pub_env中已经存在 url_launcher 库可以实现该功能。
3、但是我们在使用Flutter管理APP版本时,打开 pubspec.yaml 只看到一个 version 字段。
关于flutter自定义字体和flutter 自定义布局的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。