不知道各位有没有碰到过这样的问题:在一个布局中添加多个子布局,每个子布局有两种样式,比如正面一个样式,点击后,替换到背面又是另一种样式。且需要使得这些子布局始终只有一个是保持背面的状态,点击其他子布局时它才会回到正面样式。

最开始,我选择了用xml布局文件先拟好一个空的布局框架,然后再在代码中动态的添加不同信息,但是这样的话,涉及一个问题,我不停的在将内容(文字、图片)添加进去,那么我的内存消耗会非常大,而前面所占用的内存又不能销毁,这样,程序很容易报内存溢出的错。

一般占内存的都是图片,所以我先想到的,是将图片再压缩小一倍,这样试下来的结果不错,运行的时候没有再报错了,但是当我回退到前一个activity后,再点击这个模块,点击几次后,又开始报内存溢出的错误,于是我不得不重新寻找其他的方法来解决Android上最令人头疼的内存溢出报错。

后来, 决定将每个子布局封装成一个ViewGroup,要用到这个布局的时候,才将它显示,不用的时候便它从parent布局中remove掉,这样不需要重复的去创建添加,不会浪费内存,而且可以省去重复代码的工作,下面言归正传。



1、  先将子布局封装:


• <span style="font-size:13px;">private ViewGroup builtView(int index,int width,intheight,int x,int y,Boolean clicks)  
• </span>




index为子布局的id,width、height为该子布局的宽、高,x、y为该子布局在屏幕中的坐标,clicks则是判断该子布局的正面是否被点击。





2、  用代码编写布局文件:



• <span style="font-size:13px;">RelativeLayout parent = newRelativeLayout(getApplicationContext());  
•   
• Parent.setId(index);//设定id  
•   
• //设定布局的宽、高,并将它添加到父布局中  
•   
• RelativeLayout.LayoutParams rl = newRelativeLayout.LayoutParams(width,height);  
•   
• parent.setLayoutPramas(rl);  
•   
• //设定子布局的坐标  
•   
• rl.leftMargin = x;  
•   
• rl.leftMaigin = y;  
•   
• //判断点击的是正面还是反面  
•   
• if(clicktime == true){  
•   
•   //先将之前的内容remove掉  
•   
• parent.removeAllViews();  
•   
•   //例如:添加一段文字在布局中  
•   
•   TextView tv = newTextView(getApplicationContext());  
•   
•   tv.setId(index +1);  
•   
•   tv.setText(“TextView1”);  
•   
•   tv.setTextSize(20);  
•   
• tv.setTextColor(Color.WHITE);  
•   
•   //TextView布局  
•   
• RelativeLayout.LayoutParams tv_params = new RelativeLayout.LayoutParams(  
•   
• RelativeLayout.LayoutParams.FILL_PARENT,  
•   
• RelativeLayout.LayoutParams.WRAP_CONTENT);  
•   
•          tv_params.addRule(RelativeLayout.ALIGN_PARENT_BOTOOM);  
•   
•          tv.setLayoutParams(tv_params);  
•   
•          //将TextVIew添加到布局中  
•   
•          Parent.addView(tv);  
•   
• }else{  
•   
•    //反面布局  
•   
•    … …  
•   
• }</span>



3、  //指定在哪个布局文件中进行动态更新


• <span style="font-size:13px;">LayoutInflater inflater = getLayoutInflater();  
•   
• View mainView = inflater.inflate(R.layout.main,null);  
•   
• setContentView(mainView);  
•   
• //将封装的ViewGroup放到ArrayList中,一个List存放正面,一个List存放背面:  
•   
• ArrayList<ViewGroup> lsit1 = newArrayList<ViewGroup>();  
•   
• ArrayList<ViewGroup> lsit2 = newArrayList<ViewGroup>();  
•   
• //将参数设进布局:  
•   
• ViewGroup vg1 = builtView(0,width,height,x,y,true);  
•   
• //将ViewGroup放入list1中:  
•   
• list1.add(vg1);  
•   
• //背面同上  
•   
• … …</span>


4、  对子布局进行操作:先将确定对list1中哪个ViewGroup进行操作,对该ViewGroup进行点击监听,在监听的时候,先判断是正面还是反面,如果是正面,就显示正面的样式,如果是反面就显示反面的样式。


5、  在点击替换样式的时候,先将布局清空,在将ViewGroup添加进去进行显示。

实现后的效果很好,没有再报内存溢出的错。