Android NestedScrollView has wrong size after app:layout_behavior

后端 未结 4 1357
眼角桃花
眼角桃花 2020-12-13 04:49

Since Google has published the design support library for android, there are many nice things that can be done without implementing custom code. While i\'ve tested the custo

相关标签:
4条回答
  • 2020-12-13 05:20

    Workaround

    Before showing my NestedScrollView and after binding the data to the NestedScrollView content, I call the method fullScroll(int direction) of my NestedScrollView instance with the View.FOCUS_UP direction as argument.

    Code example for a fragment:

    NestedScrollView scrollView = (NestedScrollView) getActivity().findViewById(R.id.scroll_view); scrollView.fullScroll(View.FOCUS_UP);

    0 讨论(0)
  • 2020-12-13 05:23

    using the answer by @natario If you instead set a padding for the child (LinearLayout in my case) it will look better:

    <androidx.core.widget.NestedScrollView
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    app:layout_behavior="@string/appbar_scrolling_view_behavior"
                    android:layout_gravity="fill_vertical">
                    <LinearLayout
                        android:layout_width="match_parent"
                        android:layout_height="match_parent"
                        android:paddingBottom="?attr/actionBarSize">
                    <!--Rest of the code-->
    

    Or in Kotlin you can do something like this:

     coordinator.doOnLayout {
            nestedScrollView.minimumHeight = resources.displayMetrics.heightPixels - with(TypedValue().also {theme.resolveAttribute(android.R.attr.actionBarSize, it, true)}) {
                TypedValue.complexToDimensionPixelSize(data, resources.displayMetrics)}
        }
    
    0 讨论(0)
  • 2020-12-13 05:23

    use RecyclerView replace NestedScrollView fix this bug set item count 1,that ViewHolder return your real contentView;

    my code:

        RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
    
        recyclerView.setLayoutManager(new LinearLayoutManager(getApplicationContext()));
        // 添加分割线
        recyclerView.addItemDecoration(new DividerItemDecoration(getApplicationContext()));
    
        recyclerView.setAdapter(new Adapter<ViewHolder>() {
    
            @Override
            public int getItemCount() {
                return 1;
            }
    
            @Override
            public void onBindViewHolder(ViewHolder holder, int arg1) {
                WebView view = (WebView) holder.itemView;
                view.getSettings().setJavaScriptEnabled(true);
                view.loadUrl("http://www.baidu.com");
            }
    
            @Override
            public ViewHolder onCreateViewHolder(ViewGroup arg0, int arg1) {
                return new ViewHolder(inflater.inflate(R.layout.webview, arg0, false)) {
                };
            }
        });
    
    0 讨论(0)
  • 2020-12-13 05:26

    I had this problem and fixed adding:

    android:layout_gravity="fill_vertical"
    

    to the NestedScrollView. Then it starts behaving correctly, as I explained here also. Of course the NestedScrollView needs some kind of child (i.e. it must not be empty), otherwise the toolbar won't collapse.

    Update

    While this works well with small content, I noticed it has some problems showing longer contents, e.g. like the full activity_detail.xml above. The problem is that you can't scroll to the very bottom part of the content - it is unreachable at the bottom.

    From my tests I could find that the missing part is as big as the collapsed toolbar (or at least that's what it looks to me). To fix this is issue, and having a solution reliable for both small and big contents, you should add a layout_marginBottom to the ScrollView, so that it gets measured and releases the missing bottom part. Thus:

    android:layout_gravity="fill_vertical"
    android:layout_marginBottom="?attr/actionBarSize"
    

    or whatever size you gave to the Toolbar.

    But still

    Scrolling with small contents with this solution, even if the content is justly aligned at the top, isn't really smooth as scrolling with large contents. I'll use until a library fix comes.

    Update2

    Looks like this was fixed in v22.2.1 .

    0 讨论(0)
提交回复
热议问题