Flutter踩坑之旅
这是库的地址 PhilipsHue/flutter_reactive_ble: Flutter library that handles BLE operations for multiple devices. (github.com)安卓主要的坑就是,在使用蓝牙功能的时候,需要获取定位权限,这个需要动态获取。
最近在做个flutter蓝牙功能,用的flutter_blue,在iOS上没有任何问题,照着例子写完,正常运行蓝牙功能,但是在安卓上发现各种坑,用这个插件首先是有些设备拿不到设备名称,还有就是读写特征和ios上拿到的也不一样。
记录下坑 一开始我就使用Future、async、await去做异步操作,以为这样能解决问题,经过一天研究发现他们都还在同一个线程里面,也就是UI线程,导致卡顿,这明显不是我们想要的异步加载数据。
项目环境是flutter开发的,然而阿里云官网并没有flutter相关的SDK,所以选择了集成的插件,这里踩过的坑不多叙述,开始正题。
Flutter-设置Container背景色
Container组件类似于Android中的View,iOS中的UIView。如果你需要一个视图,可以设置背景颜色、图像、固定的尺寸、边框、圆角等效果,那么就可以使用Container组件。
在Flutter项目中,使用Container时发现一个问题,就是如果width: double.maxFinite后,设置color是无效的,或者其子Container里设置width或者color也是无效,这个让我很是困惑。
flutter中基础的widget,可以为子节点设置内间距。当padding没有child的时候,它会产生一个宽为left+right,高为top+bottom的区域,当padding的child不为空的时候会将约束传递给child。一般在使用间距的地方使用。
Stack :取代线性布局 (和Android中的LinearLayout相似),Stack允许子 widget 堆叠, 你可以使用 Positioned 来定位他们相对于 Stack 的上下左右四条边的位置。Container : Container 可让您创建矩形视觉元素。
里面嵌套listView 或者listview里面嵌套listview的时候就容易出现 hasSize的错误 解决方法一:listview 外面添加一个container,并且给定一个指定的高度。
Flutter入门这一篇效率文章就够了
这就是 Flutter 的 热重载 ,在修改完代码之后,通过热重载就能马上在设备上看到修改结果,可以很大程度上增加开发效率。 下面再给大家介绍几个 Flutter 里的常见操作。
flutter将会帮你更容易,更快速的开发出界面美观的移动应用。是谷歌的亲儿子 支持热重载 :android原生开发会遇到编译-打包-安装三个步骤。开发效率迟迟得不到提升。热重载技术在flutter内完美体现。
在上篇 [Flutter] 07-Flutter中反序列化Json 已经通过6个示例分析过了, 这里不再讨论。
Flutter支持稳定的桌面设备开发已经一段时间了,不得不说,Flutter多平台支持的特性真的很香。
(一)布局 Flutter采用深度优先机制遍历渲染对象树,决定渲染对象树中各渲染对象在屏幕上的位置和尺寸。
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,这样的话输入框被聚焦的时候键盘就会把页面顶上去。
分割线默认为1px且居中显示 如果想设置真实的分割线高度,需要把height和thickness设置为一样高即可。 flutter还提供了竖直方向上的分割线组件VerticalDivider,用法一至,不在赘述。
很早在做Demo的时候就想改变下CheckBox的未选中状态的颜色,但是多是设置全局 ThemeData.unselectedWidgetColor 的颜色来设置。不过可以想到的就是一个App中如果有不同颜色的变态需求的话...。
关于flutter设置默认主题色和flutter主题切换的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。