`
xixinfei
  • 浏览: 414562 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

android之自定义ViewGroup和自动换行的布局的实现

阅读更多

http://www.cnblogs.com/slider/archive/2011/11/24/2262161.html 

viewgroup简单说就是可以装view的view.今天遇到一个问题,就是需要一个可以自动根据一行中view的宽度自动换行的布局,网上 找了下,没有相关的例子,但是找到了思路:自定义一个viewgroup,然后在onlayout文件里面自动检测view的右边缘的横坐标值,和你的 view的parent view的况度判断是否换行显示view就可以了。因为代码比较简单,就不多说了:

  

复制代码
 1 public class MyViewGroup extends ViewGroup {
 2     private final static String TAG = "MyViewGroup";
 3     
 4     private final static int VIEW_MARGIN=2;
 5 
 6     public MyViewGroup(Context context) {
 7         super(context);
 8     }
 9     @Override
10     protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
11         Log.d(TAG, "widthMeasureSpec = "+widthMeasureSpec+" heightMeasureSpec"+heightMeasureSpec);
12         
13         for (int index = 0; index < getChildCount(); index++) {
14             final View child = getChildAt(index);
15             // measure
16             child.measure(MeasureSpec.UNSPECIFIED, MeasureSpec.UNSPECIFIED);
17         }
18 
19         super.onMeasure(widthMeasureSpec, heightMeasureSpec);
20     }
21 
22     @Override
23     protected void onLayout(boolean arg0, int arg1, int arg2, int arg3, int arg4) {
24         Log.d(TAG, "changed = "+arg0+" left = "+arg1+" top = "+arg2+" right = "+arg3+" botom = "+arg4);
25         final int count = getChildCount();
26         int row=0;// which row lay you view relative to parent
27         int lengthX=arg1;    // right position of child relative to parent
28         int lengthY=arg2;    // bottom position of child relative to parent
29         for(int i=0;i<count;i++){
30             
31             final View child = this.getChildAt(i);
32             int width = child.getMeasuredWidth();
33             int height = child.getMeasuredHeight();
34             lengthX+=width+VIEW_MARGIN;
35             lengthY=row*(height+VIEW_MARGIN)+VIEW_MARGIN+height+arg2;
36             //if it can't drawing on a same line , skip to next line
37             if(lengthX>arg3){
38                 lengthX=width+VIEW_MARGIN+arg1;
39                 row++;
40                 lengthY=row*(height+VIEW_MARGIN)+VIEW_MARGIN+height+arg2;
41                 
42             }
43             
44             child.layout(lengthX-width, lengthY-height, lengthX, lengthY);
45         }
46 
47     }
48 
49 }
复制代码

  这里有个地方要注意,那就要明白ViewGroup的绘图流程:ViewGroup绘制包括两个步骤:1.measure 2.layout

  在两个步骤中分别调用回调函数:1.onMeasure()   2.onLayout()

  1.onMeasure() 在这个函数中,ViewGroup会接受childView的请求的大小,然后通过childView的 measure(newWidthMeasureSpec, heightMeasureSpec)函数存储到childView中,以便childView的getMeasuredWidth() andgetMeasuredHeight() 的值可以被后续工作得到。

  2.onLayout() 在这个函数中,ViewGroup会拿到childView的getMeasuredWidth() andgetMeasuredHeight(),用来布局所有的childView。

  3.View.MeasureSpec 与 LayoutParams 这两个类,是ViewGroup与childView协商大小用的。其中,View.MeasureSpec是ViewGroup用来部署 childView用的, LayoutParams是childView告诉ViewGroup 我需要多大的地方。

  4.在View 的onMeasure的最后要调用setMeasuredDimension()这个方法存储View的大小,这个方法决定了当前View的大小。

  

  效果图:

                                 

分享到:
评论

相关推荐

    android 自动换行的自定义viewgroup

    标题"android 自动换行的自定义viewgroup"所指的,就是创建一个能够根据子视图的数量和大小自动调整布局,实现自动换行效果的自定义 ViewGroup 类。这样的组件通常用于展示网格或者流式布局,例如商品列表、图片墙等...

    android自定义控件自动换行效果实现 简化版demo

    在Android开发中,...总之,实现一个自定义的自动换行控件,需要理解Android布局机制,熟练掌握ViewGroup的测量和布局过程。通过自定义ViewGroup,我们可以灵活地创建满足特定需求的复杂布局,提高应用的用户体验。

    Android 标签,可以自动换行的ViewGroup

    在Android开发中,"标签(Tags)"通常指的是在用户界面上用于表示多个选项或类别的元素,类似于传统的HTML中...开发者可以利用现有的开源库或自定义ViewGroup来实现这一功能,以创建更加灵活、美观的Android应用程序。

    Android 自定义控件实现自动换行效果

    在自定义ViewGroup时,我们需要重写几个关键方法,如`onMeasure()`和`onLayout()`,以实现特定的布局逻辑。 1. **onMeasure()**:此方法用于测量每个子View的大小。我们需要遍历所有子View,根据其属性和约束计算出...

    AndroidAutoLayout自动换行viewgroup

    然后在布局XML文件中声明并使用这个自定义ViewGroup,通过设置子View和选择模式,即可实现自动换行和选择功能。 总之,"AndroidAutoLayout"是一个强大且灵活的组件,它解决了Android开发中多元素自动布局的问题,...

    android自定义控件实现自动换行效果

    本教程将探讨如何通过自定义一个`ViewGroup`来实现类似电商平台商品属性的自动换行效果。这种效果通常用于展示商品的多维度信息,如颜色、尺寸、材质等,当一行无法容纳所有信息时,它们会自动换行到下一行。 首先...

    Android自定义流式布局/自动换行布局实例

    实现 Android 自定义流式布局/自动换行布局实例需要继承 ViewGroup,重写 onMeasure 和 onLayout 方法。onMeasure 方法中需要测量子 View 的宽高,确定此容器的宽高。onLayout 方法中需要确定子 View 的摆放位置。 ...

    android自定义控件自动换行效果实现

    本教程将探讨如何实现一个自定义控件,它具有自动换行的效果,使得在有限的屏幕空间内,元素能够整齐地排列成多行。参考链接为:。 首先,我们需要创建一个新的`ViewGroup`子类,例如`AutoWrapLayout`。这个自定义...

    android自定义viewgroup实现等分格子布局

    "android自定义viewgroup实现等分格子布局"这个话题涉及到如何利用自定义ViewGroup类来创建一个能够平均分配屏幕空间的网格布局。下面我们将深入探讨这个过程,以及相关的关键知识点。 首先,了解ViewGroup。在...

    Android 自定义ViewGroup 实战篇 -> 实现FlowLayout源码程序

    在Android开发中,自定义ViewGroup是实现复杂布局和交互的关键技术之一。本实战篇将聚焦于如何实现一个名为FlowLayout的自定义布局,它允许子视图按行排列,类似于HTML中的`&lt;div&gt;`标签。在Android应用设计中,...

    Android 实现View的排列自动换行

    总之,“Android实现View的排列自动换行”是一个涉及自定义View组、测量、布局和性能优化的综合性问题。通过理解并实现这样的功能,开发者能够更好地掌握Android UI的底层机制,从而设计出更加灵活和个性化的用户...

    Android自定义ViewGroup-----流式布局

    在Android开发中,自定义ViewGroup是实现复杂布局或创新交互设计的重要手段。本文将深入探讨如何创建一个自定义的“流式布局”(MyFlowLayout),这个布局会根据屏幕尺寸自动调整子视图的位置,使其从左到右、从上到...

    Android自定义组件之自动换行View

    本篇文章将深入探讨如何实现一个自动换行的View,这种组件通常用于显示一行排满后自动换行的文本或小图标。在Android应用设计中,这样的组件能够提供更灵活的布局和更丰富的用户体验。 首先,我们需要创建一个新的...

    多个view自动换行

    总之,“多个view自动换行”是Android布局设计中的一个重要特性,它涉及到对`ViewGroup`和布局管理器的深入理解。通过自定义`ViewGroup`,我们可以实现更复杂的布局逻辑,比如自动换行,以满足各种UI设计需求。在...

    Android自定义标签view——可自动换行

    通过深入研究这个项目,开发者不仅可以学习到自定义View和布局管理的相关知识,还能掌握如何实现自动换行的功能,这对于优化Android应用的界面布局和提高用户体验具有很大的价值。同时,从开源社区获取和贡献代码也...

    Android自动换行标签控件(二)

    总之,创建一个自动换行的标签控件涉及到了Android自定义视图、布局管理、事件监听等多个知识点。通过合理的布局计算和视图管理,我们可以构建出一款既实用又美观的标签控件,以满足用户在不同场景下的需求。

    自动换行的ViewGroup

    为了实现自动换行,我们需要扩展LinearLayout并重写其测量和布局流程。关键在于`onMeasure()`方法,这里我们需要计算每个子视图的宽度和高度,以及当前行的总宽度。当当前行的总宽度达到容器的宽度时,我们需要开始...

    Android textView根据长度自动换行-IT计算机-毕业设计.zip

    4. **自定义ViewGroup**:如果你需要更复杂的布局逻辑,例如根据屏幕宽度自动调整TextView的行数,可以创建一个自定义的ViewGroup,重写`onMeasure()`方法来测量子视图,并根据需要调整它们的大小。 5. **单行显示...

    android 实现自动换行的流布局

    通过这样的方式,开发者可以轻松创建一个符合需求的自定义流式布局,实现自动换行并支持padding和margin,极大地提高了布局的灵活性和可定制性。在实际项目中,这可以为用户带来更好的视觉体验,提高应用的整体质量...

    Android 控件可以根据长度自动换行

    9. **自定义ViewGroup**: 如果需要更精细的控制,可以考虑创建一个自定义的ViewGroup,它能监听子View的大小变化,自动调整布局以适应控件的换行。 通过以上步骤,我们可以实现一个根据控件长度自动换行的ListView...

Global site tag (gtag.js) - Google Analytics