gpt4 book ai didi

android - flutter View : AppBarLayout$ScrollingViewBehavior

转载 作者:IT王子 更新时间:2023-10-29 07:04:44 26 4
gpt4 key购买 nike

我们正在决定是否要介绍 Flutter到我们现有的应用程序中。
因此,我们正在进行一些概念验证。

目前,我们有一个带有 CoordinatorLayout 的原生 Android 应用程序,当滚动 RecyclerView 内容时,它会滑开工具栏。

类似于此:

Collapsing toolbar layout

这个想法是只替换 RecyclerView (Android)带有 ListView ( flutter )。
但是,这会破坏 CollapsingToolbar 效果。

enter image description here

enter image description here

代码:

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context=".ScrollingActivity">

<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar"
android:layout_width="match_parent"
android:layout_height="@dimen/app_bar_height"
android:fitsSystemWindows="true"
android:theme="@style/AppTheme.AppBarOverlay">

<android.support.design.widget.CollapsingToolbarLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="?attr/colorPrimary"
app:layout_scrollFlags="scroll|exitUntilCollapsed"
app:toolbarId="@+id/toolbar">

<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/AppTheme.PopupOverlay" />

</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>

<FrameLayout
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:id="@+id/someContainer"
android:layout_width="match_parent"
android:layout_height="wrap_content" />

</android.support.design.widget.CoordinatorLayout>

Kotlin

class ScrollingActivity : AppCompatActivity() {

override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_scrolling)
setSupportActionBar(toolbar)

supportFragmentManager.beginTransaction().apply {
replace(R.id.someContainer, Flutter.createFragment("route1"))
}.commit()
}
}

flutter

void main() => runApp(_widgetForRoute(window.defaultRouteName));

Widget _widgetForRoute(String route) {
return MediaQuery(
data: MediaQueryData.fromWindow(window),
child: Directionality(
textDirection: TextDirection.ltr,
child: Material(
child: ListView.builder(
itemBuilder: (context, index) => Text("index $index"),
itemCount: 100,
),
),
),
);
}

有人知道我们该如何解决这个问题吗?

提前致谢。

最佳答案

您需要CustomScrollView。给你一个想法。

@override
Widget build(BuildContext context) {
return CustomScrollView(
slivers: <Widget>[
SliverAppBar(
flexibleSpace: FlexibleSpaceBar(...),
),
SliverList(
delegate: SliverChildBuilderDelegate((BuildContext context, int index) {
return YourWidget();
},
),
),
],
);
}

关于android - flutter View : AppBarLayout$ScrollingViewBehavior,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54328524/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com