- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要更改 ScrollPhysics
对于应用程序中的几乎每个可滚动小部件 BouncingScrollPhysics()
.我试图找到一种方法来做到这一点而不添加 physics
属性(property)无处不在,但我还没有找到好的方法。一种解决方案是使用 flutter_platform_widgets并设置 initialPlatform
到 iOS,但这也会改变很多其他的事情。
有谁知道这是否可能,在这种情况下如何?
最佳答案
您可以在下面复制粘贴运行完整代码
您可以扩展 ScrollBehavior
并输入 builder
的 MaterialApp
在演示代码中,iOS, macOS, android
将使用 BouncingScrollPhysics
代码片段
class ScrollBehaviorModified extends ScrollBehavior {
const ScrollBehaviorModified();
@override
ScrollPhysics getScrollPhysics(BuildContext context) {
switch (getPlatform(context)) {
case TargetPlatform.iOS:
case TargetPlatform.macOS:
case TargetPlatform.android:
return const BouncingScrollPhysics();
case TargetPlatform.fuchsia:
case TargetPlatform.linux:
case TargetPlatform.windows:
return const ClampingScrollPhysics();
}
return null;
}
}
...
builder: (context, widget) {
return ScrollConfiguration(
behavior: ScrollBehaviorModified(), child: widget);
},
工作演示
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
void main() {
runApp(MyApp());
}
class ScrollBehaviorModified extends ScrollBehavior {
const ScrollBehaviorModified();
@override
ScrollPhysics getScrollPhysics(BuildContext context) {
switch (getPlatform(context)) {
case TargetPlatform.iOS:
case TargetPlatform.macOS:
case TargetPlatform.android:
return const BouncingScrollPhysics();
case TargetPlatform.fuchsia:
case TargetPlatform.linux:
case TargetPlatform.windows:
return const ClampingScrollPhysics();
}
return null;
}
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
visualDensity: VisualDensity.adaptivePlatformDensity,
),
builder: (context, widget) {
return ScrollConfiguration(
behavior: ScrollBehaviorModified(), child: widget);
},
home: MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
int _counter = 0;
void _incrementCounter() {
setState(() {
_counter++;
});
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
Expanded(
child: ListView.separated(
itemBuilder: (BuildContext context, int index) {
return Text('Item$index');
},
separatorBuilder: (BuildContext context, int index) {
return Divider();
},
itemCount: 50,
),
),
Text(
'You have pushed the button this many times:',
),
Text(
'$_counter',
style: Theme.of(context).textTheme.headline4,
),
],
),
),
floatingActionButton: FloatingActionButton(
onPressed: _incrementCounter,
tooltip: 'Increment',
child: Icon(Icons.add),
),
);
}
}
关于flutter - 如何更改 flutter 中的默认 ScrollPhysics?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62809540/
我想在每次向前/向后更改页面时应用 NeverScrollableScrollPhysics(),然后在 3 秒后返回到 AlwaysScrollableScrollPhysics()。我将如何实现这
我有一个屏幕,我需要在其中从 Appbar 中搜索一个术语,下面的区域显示了一张卡片,其中包含显示列表中的选项,下面的区域将在可滚动列表中显示返回的所有结果。 问题是,尽管返回的项目放置在 ListV
我需要更改 ScrollPhysics对于应用程序中的几乎每个可滚动小部件 BouncingScrollPhysics() .我试图找到一种方法来做到这一点而不添加 physics属性(propert
我正在尝试动态设置 PageView 边界。这是一个简化的示例,从第 10 页开始,左右边界由随机数生成器(leftEnd,rightEnd)设置。 import 'package:flutter/m
我是一名优秀的程序员,十分优秀!