首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

动态添加scrollview中的scrollview和scrollview中的linearlayout

动态添加scrollview中的scrollview和scrollview中的linearlayout是一种在Android应用开发中常见的操作,用于在运行时向布局中添加和显示视图。在这种情况下,需要特别注意视图的层次结构,以确保滚动功能正常工作。以下是一个简单的示例,说明如何在scrollview中动态添加scrollview和linearlayout:

  1. 在布局文件中添加一个scrollview,例如:
代码语言:xml<ScrollView
复制
    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:id="@+id/scrollView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fillViewport="true">

   <LinearLayout
        android:id="@+id/linearLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:padding="16dp">
    </LinearLayout>
</ScrollView>
  1. 在Activity中动态添加scrollview和linearlayout:
代码语言:java
复制
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;

import androidx.appcompat.app.AppCompatActivity;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        ScrollView scrollView = findViewById(R.id.scrollView);
        LinearLayout linearLayout = findViewById(R.id.linearLayout);

        for (int i = 0; i < 10; i++) {
            ScrollView nestedScrollView = new ScrollView(this);
            nestedScrollView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));

            LinearLayout nestedLinearLayout = new LinearLayout(this);
            nestedLinearLayout.setOrientation(LinearLayout.VERTICAL);
            nestedLinearLayout.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));

            for (int j = 0; j < 5; j++) {
                TextView textView = new TextView(this);
                textView.setText("这是一个动态添加的TextView");
                textView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT));
                nestedLinearLayout.addView(textView);
            }

            nestedScrollView.addView(nestedLinearLayout);
            linearLayout.addView(nestedScrollView);
        }
    }
}

这个示例中,我们在布局文件中定义了一个scrollview,并在其中嵌套了一个linearlayout。然后,在Activity中动态添加了10个scrollview和linearlayout对,每个scrollview中包含5个textview。

注意:在嵌套滚动视图时,需要特别注意滚动冲突。在这个示例中,我们使用了ScrollView,它会拦截触摸事件,以便只有它自己才能滚动。如果需要更复杂的滚动行为,可以考虑使用NestedScrollView,它提供了更好的嵌套滚动支持。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

掌握 SwiftUI 中的 ScrollView:滚动几何

前言本文探讨了如何使用 onScrollGeometryChange 视图修饰符有效地监控和管理滚动位置和几何。通过详细的代码示例和解释,你将学习如何利用这些工具创建动态和响应迅速的用户界面。...SwiftUI 是一个强大的框架,它简化了在苹果平台上构建用户界面的过程。SwiftUI 中的一个基本组件是 ScrollView,它允许用户通过滚动导航内容。...完整代码示例分析下面是一个完整的 SwiftUI Demo,其中包含了我们刚刚讨论的 ScrollView、ScrollGeometry 和 onScrollGeometryChange 的使用示例。...总结今天,我们探讨了 SwiftUI 中的新 ScrollGeometry 类型和 onScrollGeometryChange 视图修饰符。...这些工具为开发者提供了对滚动位置和交互的精确控制和洞察,增强了动态和响应迅速的用户界面的开发。通过利用这些功能,你可以创建更具吸引力和直观的应用程序。

17611
  • SwiftUI 中掌握 ScrollView 的使用:滚动可见性

    前言我们的滚动 API 中又有一个重要的新增功能:滚动可见性。现在,你可以获取可见标识符列表,或者快速检查并监控 ScrollView 内视图的可见性状态。...要了解有关 scrollTargetLayout 视图修饰符的更多信息,请查看我的文章《掌握 SwiftUI 中的 ScrollView:滚动几何》。...onScrollVisibilityChange 视图修饰符来跟踪 ScrollView 中的视图可见性。...ContentViewScrollView 和 LazyVStack:使用 ScrollView 包裹一个 LazyVStack,在其中放置 1 到 99 的数字。...总结今天,我们学习了如何跟踪 ScrollView 内特定视图的可见性,并监控可见标识符列表。示例展示了如何使用 SwiftUI 的滚动可见性修饰符来增强用户体验和交互性。希望能对你有所帮助。

    22421

    深入了解 SwiftUI 5 中 ScrollView 的新功能

    在 SwiftUI 5.0 中,苹果大幅强化了 ScrollView 功能。新增了大量新颖、完善的 API。本文将对这些新功能进行介绍,希望能够让它们更多、更早的帮助到有需要的开发者。...不限于 ScrollView,支持所有可滚动容器(包括 List、TextEditor 等)。 将可滚动容器内的所有子视图视为一个整体,并为其添加 margin。...例如,在下面的代码中,为 ScrollView 的 leading 方向添加安全区域的两种方式效果是一致的。...例如,下面的两种实现中,ScrollView 的底部空间是不同的。...总结 我完全没有想到,在 SwiftUI 5 中,苹果对 ScrollView 进行了全面增强。值得赞赏的是,他们不仅提供了一些一直期待的功能,而且在 API 的设计和实现完成度上都非常出色。

    92120

    如何判断 ScrollView、List 是否正在滚动中

    和 List .introspectScrollView { scrollView in scrollView.delegate = delegate...} }}// 添加与 ScrollView、List 的子视图之上,用于在位置发生变化时发送信息func scrollSensor() -> some View { overlay(...ScrollView + VStack( HStack )这类的组合,只需为可滚动视图添加一个 scrollSensor 即可。...对于 List、ScrollView + LazyVStack( LazyHStack )这类的组合,需要为每个子视图都添加一个 scrollSensor。...判断的准确度没有前两种方式高当可滚动组件中的内容出现了非滚动引起的尺寸或位置的变化( 例如 List 中某个视图的尺寸发生了动态变化 ),本方式会误判断为发生了滚动,但在视图的变化结束后,状态会马上恢复到滚动结束滚动开始后

    3.8K40

    Android ScrollView设置初始position的方法

    刚听到这个需求的时候,觉得这个很简单,直接设置ScrollView的初始滚动值即可。然而,当真正实现的时候却发现,Android压根没有方法可以设置ScrollView的初始滚动值。...但是为难的是如何做到初始化ScrollView的默认滚动值。如果在onCreate里面调用scrollTo是无效的,因为这时候ScrollView都没有布局好。...难道是通过反射scrollY这个成员变量动态修改它的value? 于是自己动手在onCreate的时候通过反射修改ScrollView的scollY属性。...也就是说其实Animator是通过setScollY这个方法来实现动态滚动ScrollView的。而setScrollY的底层其实就是调用scrollTo。 ? 到此似乎饶了个大圈子又回到了起点。...通过断点和查看源码确认,这个保存ScrollView当前滚动位置的scrollY属性全名叫做mScrollY,而这个mScrollY并不是ScrollView的成员,而是其父类View的属性成员。

    4K80

    Android的ScrollView简单使用实例(附Demo)

    1.垂直滚动:Scroll 新建一个应用程序: 在MainActivity的布局文件上做个实验,现在设置了按钮1和按钮2后还剩下一些空位: ? 再设置一个按钮3让他超出屏幕之外: ?...1.改变这个布局文件的根布局:把根布局改成:ScrollView 注意:ScrollView的子元素只能有一个,所以得增加一个LinearLayout布局,把其他按键放在这个LinearLayout中,...那么ScrollViewd的子元素就只有一个LinearLayout了,而LinearLayout的子元素不限制。...所以在HorizontalScrollView布局中再加一个子布局LinearLayout,且LinearLayout为水平方向: ? 代码如下: LinearLayout> ScrollView> 运行应用程序,因为外面还嵌套了一层ScrollView所以能垂直滚动和水平滚动

    1.6K20

    基础篇章:React Native之 ScrollView 的讲解

    (友情提示:RN学习,从最基础的开始,大家不要嫌弃太基础,会的同学请自行略过,希望不要耽误已经会的同学的宝贵时间) 编者按:其实我并不太喜欢在周末发公众号,毕竟大家都在休息和放松,不想学习,但是今天在群里我看到有人说...回馈给一直跟着我学习的程序员和开发者。...onScroll function 在滚动的过程中,每帧最多调用一次此回调函数。调用的频率可以用scrollEventThrottle属性来控制。...我的穿衣打扮 来,一起来看看,我有哪些外在的服饰和化妆品,可以使用更佳美观和漂亮,修饰我的内在和外在。...,还有几个和android相关,还有很多与ios相关的属性,我就不再介绍了,自己去官方文档查查吧。

    1.9K50

    android scrollview嵌套listview计算高度的问题

    ScrollView中只能放一个控件,一般都放LinearLayout,orientation属性值为vertical。在LinearLayout中放需要呈现的内容。...但是为啥在scrollview中嵌套listview会出现只显示第一条listitem的高度呢,原因是:scrollview的ontach方法的滚动事件消费处理,ListView控件的高度设定问题 从谷歌那里找到的...ScrollView嵌套ListView只显示一行的解决办法相信很多人都遇到过,然后大部分都是用这位博主的办法解决的吧 刚开始我也是用这个办法解决的,首先感谢这位哥的大私奉献,贴上地址 http:/...)this.getParent()).getPaddingLeft();   float paddingReft = ((LinearLayout)this.getParent()).getPaddingRight...layout = new LinearLayout(getContext()); layout.setLayoutParams(params); layout.setOrientation(VERTICAL

    2.3K60

    onTouchEvent(二) 使用Scroller实现黏性滑动的ScrollView

    前言 本篇文章是之前投稿的一位读者的第二篇文章,也是他的实践之路,自己去实现一些滑动的特效,是掌握Android触控知识的一个非常好的方法,希望大家能够从他的Demo中获得一些新的感悟。...上一篇博文onTouchEvent(一) 你所必须知道的坐标详解介绍了onTouchEvent()手势控制相关的一些坐标概念,这篇文章结合上一篇内容加上Scroller实现一个简单的带黏性滑动的ScrollView...思路 滑动的时候判断最终偏移量是不是超出了子view(ViewGroup内容)的范围,如果超出了就限制不让其超出,这样就可以做出一个滑动的ScrollView并且不会滑出界 当松手(action_up)...onMeasure() 2. onLayout() 3. onTouchEvent() 4. computeScroll() 因为是ViewGroup需要计算、定位子View所以需要复写1和2...computeScroll()是一个空实现的函数,父控件调用用于更新子View,操作的是mScrollX和mScrollY,也就是移动偏移量。 ?

    1K30

    View的有效曝光监控(下)|ScrollView NestScrollView篇

    Scrollview和NestScrollView怎么监控呢。 我:???黑人老哥又特么来了。 image.png 分析问题 还是和上篇文章一样,我们先看下要解决哪些问题。...ScrollView NestScrollView 的滑动监控怎么做。 View有没有像RecyclerView一样的attach和detch方法,超过1.5s的曝光时间。 View出现一半。...onScrollChanged也是View的protected的方法,而当ScrollView和NestScrollView的滑动状态被改变的时候就会调用这个方法,而这个方法内则就会把状态设置成true...测试结果 经过在下的测试吧,OnScrollChangedListener在ScrollView和NestScrollView滑动的时候都会触发回调哦。...我:谦虚有理的小菜逼。 面试官:这种方式感觉还是不够智能,如果让你用动态插桩呢。 我:打扰了,二营长,把我的意大利炮抬过来。 面试官:回家继续等通知把。

    1.3K30

    让你的布局滚动起来—ScrollView

    在使用的过程中,可能会遇到这样的场景,当绘制的UI控件超出手机屏幕尺寸的时候,就会导致此UI控件无法显示。...↳android.widget.ScrollView 可以看出, ScrollView原来是一个 FrameLayout的容器,不过在他的基础上添加了滚动,允许显示的比实际多的内容。...> ScrollView> 通过 AndroidStudio的 Preview视图也可以看出,5个 Button已超出屏幕显示,在不使用 ScrollView的情况下,父布局直接使用 LinearLayout...可以看出, HorizontalScrollView中的图片内容,可以横向滑动,并且整个布局由于外部嵌套了 ScrollView,整体页可以竖直方向滑动。...注意:同 ScrollView, HorizontalScrollView中的子元素也只能有一个,否则报错。

    3.7K30

    uniapp 中 ScrollView 组件上拉分页不滚动到最顶部

    介绍: 在UniApp中,如果想要实现类似微信聊天页面的上拉加载更多历史聊天记录功能,每次上拉到顶部时,界面不会自动滚动到最顶部,而是停留在当前位置。...本指南将展示如何使用ScrollView组件实现这一功能。步骤:在scroll-view组件中绑定scroll-into-view属性,并设置为一个变量scrollViewIntoView。...>CSS:#scroll-view-content { display: flex; flex-direction: column-reverse;}在数据绑定中,...根据上拉加载的数据,将其添加到list数组中,并将变量scrollViewIntoView设置为加载前最后一个元素的id。...(加载前最后一个元素) }}通过以上步骤,您可以实现在UniApp中使用ScrollView组件进行上拉加载更多历史记录时,界面不会滚动到最顶部,而是停留在当前位置。

    1.2K31
    领券