手机浏览 RSS 2.0 订阅 膘叔的简单人生 , 腾讯云RDS购买 | 超便宜的Vultr , 注册 | 登陆
浏览模式: 标准 | 列表全部文章

flutter 的dialog如何自定义宽度

比如我们常用的alertDialog,只要显示一个message,不显示title的话,有点象toast。这时候如何自定义宽度 呢?

 

如果你直接在content中包含一个sizedbox,定义宽度为200,或者更小,你会发现其实是没有用的 ,通过翻看源码可以了解到。其他他是在组件上方定义了一个ConstrainedBox,然后设置了minWidth = 280.所以你设置低于280的,怎么都没用。
 
要解决这个问题也不难,在Dialog上面包两个组件UnConstraintedBox,和container。先用uncontraintedbox解除限制,再使用container来定义宽高。问题就这么解决了

flutter 中 getx 如何监听list

 正常情况下,我们都知道,flutter使用getx的时候,只要在Obx方法中都可以监听变量的变更,同时会局部刷新Obx包裹的Widget,但如果GetxController绑定的变量是list的时候,你会发现,无论你怎么 处理,Widget都不刷新。

有个最简单的办法:在设置变量的时候,同时让他refresh一下。比如:

count.value.add(1);

count.refresh();

这时候再看Widget就都更新了。

纯记录

mac触摸版3指以上功能失效的解决方法

 在使用mac的时候,偶尔会出现触摸板3指以上的功能失效,这个太影响使用了,毕竟mac最有用的功能,我感觉就是窗口切换。。。触摸板在外接键盘后,这就是我唯一的功能了,如果他也失效,那实在令人痛苦

 
这时候有一个快速解决方案,那就是:打开活动监视器,找到程序坞,强制退出,这时候程序坞会自动重启,再试一下三指功能,恢复正常~
或者终端,killall Dock。也是同样的原理~

'MACOSX_DEPLOYMENT_TARGET' is set to 10.6, but the range of supported deployment target versions is 10.9 to 12.3.99.

在开发flutter的macOS版时,报这个错误:./macos/Pods/Pods.xcodeproj: warning: The macOS deployment target 'MACOSX_DEPLOYMENT_TARGET' is set to 10.6, but the range of supported deployment target versions is 10.9 to 12.3.99. 

可以很明确的看到文件是:/macos/Pods/Pods.xcodeproj,虽然这个warning并不影响程序的运行,看确实看了不舒服,于是打开/macos/Pods/Pods.xcodeproj,搜索:MACOSX_DEPLOYMENT_TARGET,一共有3处,将他对应的值10.6,修改为10.9,问题解决。

 

flutter 如何设置桌面APP的最小宽高

 在Windows和MacOs上面程序的宽高是可以随便拖拉的,不象ios/android,总归是一定固定的宽高。为了保证部分输入框或者界面在拖拉时不会UI越界,所以就要设定一个最小宽高。当然你要为了保险,你可以  强制设定最小值和最大值一致,也就是让APPi窗口固定大小。但一般我们都只是限定最小值。。。毕竟,最大的话,丑就丑了(反正我没有UI设计师)

基于此,官方的flutter-desktop--embedding有一个插件:window_size,由于他没有发布到pub.dev,因此只能通过手动改pubspec.yml方法来进行加载

修改:pubspec.yml,在dependencies下增加:

XML/HTML代码
  1. window_size:  
  2.   git:  
  3.     url: https://github.com/google/flutter-desktop-embedding.git  
  4.     path: plugins/window_size  
  5.     ref: a738913c8ce2c9f47515382d40827e794a334274  

 

ref的话,可以直接去github上看,用最新的即可。

然后可以在runApp前进行判断,最简单的办法就是2行代码:

XML/HTML代码
  1. if(Platform.isMacOS || Platform.isWindows) {  
  2.     if( MediaQueryData.fromWindow(window).size.width < 640 ||  MediaQueryData.fromWindow(window).size.height < 480){  
  3.         window_size.setWindowSize(const Size(640,480))  
  4.     }  
  5. }  

 

当然实际情况得从自身出发,不能这样随意。。

参考:

1、flutter桌面版开发设置窗口大小(最小尺寸、最大尺寸、固定尺寸),窗口标题。 | 码海无涯 (yefei572.github.io)

2、flutter-desktop-embedding/README.md at master · google/flutter-desktop-embedding (github.com)

后续就要看看这个什么时候更新了:flutter-desktop-embedding/plugins/menubar at master · google/flutter-desktop-embedding (github.com),这个一更新。menubar就可以派用场了。

 ---EOF

后记:目前还没有判断窗口resize的事件,理论上应该要判断这个。后面会尝试加上