Android学习教程之动态GridView控件使用(6)

本文实例为大家分享了Android动态GridView控件使用的具体代码,供大家参考,具体内容如下

MainActivity.java代码:

package siso.haha;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {
 private Button btnStaggeredGridView;

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

 btnStaggeredGridView=(Button)findViewById(R.id.btnStaggeredGridView);
 btnStaggeredGridView.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
  Intent intent = new Intent();
  intent.setClass(MainActivity.this,staggeredgridviewActivity.class);
  //直接启动一个Activity
  startActivity(intent);
  }
 });

 }
}

staggeredgridviewActivity.java代码:

package siso.haha;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;

import java.util.Random;

import viewHelper.StaggeredGridView;
import viewHelper.StaggeredGridView.LayoutParams;

public class staggeredgridviewActivity extends Activity
{
 private final static String TAG = staggeredgridviewActivity.class.getSimpleName();
 private StaggeredGridView mSGV;
 private SGVAdapter mAdapter;

 private StaggeredGridView.OnScrollListener mScrollListener = new StaggeredGridView.OnScrollListener() {

 @Override
 public void onScrollStateChanged(ViewGroup view, int scrollState) {
  Log.d(TAG, "[onScrollStateChanged] scrollState:" + scrollState);
  switch (scrollState) {
  case SCROLL_STATE_IDLE:
   setTitle("SCROLL_STATE_IDLE");
   break;

  case SCROLL_STATE_FLING:
   setTitle("SCROLL_STATE_FLING");
   break;

  case SCROLL_STATE_TOUCH_SCROLL:
   setTitle("SCROLL_STATE_TOUCH_SCROLL");
   break;

  default:
   break;
  }

 }

 @Override
 public void onScroll(ViewGroup view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
  Log.d(TAG, "[onScroll] firstVisibleItem:" + firstVisibleItem + " visibleItemCount:"+visibleItemCount + " totalItemCount:" + totalItemCount);

 }
 };

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

 mAdapter = new SGVAdapter(this);
 mSGV = (StaggeredGridView) findViewById(R.id.grid);
 mSGV.setColumnCount(4);
 mSGV.setAdapter(mAdapter);
 mSGV.setOnScrollListener(mScrollListener);
 }

 @Override
 public boolean onCreateOptionsMenu(Menu menu)
 {
 // Inflate the menu; this adds items to the action bar if it is present.
 // getMenuInflater().inflate(R.menu.activity_main, menu);
 return true;
 }

 private final class SGVAdapter extends BaseAdapter
 {

 LayoutInflater mInflater;

 public SGVAdapter(Context ctx)
 {
  mInflater = LayoutInflater.from(ctx);
 }

 @Override
 public int getCount()
 {
  return 30;
 }

 @Override
 public Object getItem(int position)
 {
  return null;
 }

 @Override
 public long getItemId(int position)
 {
  return 0;
 }

 Random r = new Random();

 @Override
 public View getView(int position, View convertView, ViewGroup parent)
 {
  //LayoutParams相当于一个Layout的信息包,它封装了Layout的位置、高、宽等信息。假设在屏幕上一块区域是由一个Layout占领的,如果将一个View添加到一个Layout中,最好告诉Layout用户期望的布局方式,也就是将一个认可的layoutParams传递进去。
  /*可以这样去形容LayoutParams,在象棋的棋盘上,每个棋子都占据一个位置,也就是每个棋子都有一个位置的信息,如这个棋子在4行4列,这里的“4行4列”就是棋子的LayoutParams。
  但LayoutParams类也只是简单的描述了宽高,宽和高都可以设置成三种值:
  1,一个确定的值;
  2,FILL_PARENT,即填满(和父容器一样大小);
  3,WRAP_CONTENT,即包裹住组件就好。*/
  final LayoutParams lp;
  final View v;
  switch (position)
  {
  case 0:
  case 29:
   v = mInflater.inflate(R.layout.element_header, parent, false);
   lp = new LayoutParams(v.getLayoutParams());
   lp.span = mSGV.getColumnCount();
   break;
  case 8:
  case 9:
  case 18:
  case 19:
   v = mInflater.inflate(R.layout.element_item_small, parent, false);
   lp = new LayoutParams(v.getLayoutParams());
   lp.span = 1;
   break;
  case 10:
  case 20:
   v = mInflater.inflate(R.layout.element_item_large, parent, false);
   lp = new LayoutParams(v.getLayoutParams());
   lp.span = 4;
   break;
  default:
   v = mInflater.inflate(R.layout.element_item, parent, false);
   lp = new LayoutParams(v.getLayoutParams());
   lp.span = 2;
   break;
  }
  v.setLayoutParams(lp);
  return v;
 }
 }

}

activity_main.xml内容:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:paddingLeft="@dimen/activity_horizontal_margin"
 android:paddingRight="@dimen/activity_horizontal_margin"
 android:paddingTop="@dimen/activity_vertical_margin"
 android:paddingBottom="@dimen/activity_vertical_margin"
 tools:context="siso.haha.MainActivity">

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="动态GridView"
 android:id="@+id/btnStaggeredGridView"
 android:layout_alignParentTop="true"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button2"
 android:layout_below="@+id/btnStaggeredGridView"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button3"
 android:layout_below="@+id/button2"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button4"
 android:layout_below="@+id/button3"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button5"
 android:layout_below="@+id/button4"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button6"
 android:layout_below="@+id/button5"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button7"
 android:layout_below="@+id/button6"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button8"
 android:layout_below="@+id/button7"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button9"
 android:layout_below="@+id/button8"
 android:layout_centerHorizontal="true" />

 <Button
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:text="New Button"
 android:id="@+id/button10"
 android:layout_alignParentBottom="true"
 android:layout_centerHorizontal="true" />
</RelativeLayout>

activity_staggeredgridview.xml内容:

<?xml version="1.0" encoding="utf-8"?>

 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 tools:context=".staggeredgridviewActivity" >

 <viewHelper.StaggeredGridView
  android:id="@+id/grid"
  android:layout_width="match_parent"
  android:layout_height="match_parent" />

 </RelativeLayout>

其他:

element_header.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="56dp"
 android:background="@drawable/bg_white_box"
 android:gravity="center_vertical"
 android:orientation="horizontal" >

 <Button
 android:id="@+id/button1"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_weight="1"
 android:text="做一点事..." />

 <ProgressBar
 android:id="@+id/progressBar1"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:layout_weight="1" />

</LinearLayout>

element_item.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:background="@drawable/bg_white_box"
 android:orientation="vertical"
 android:padding="2dp" >

 <ImageView
 android:id="@+id/imageView1"
 android:layout_width="match_parent"
 android:layout_height="100dp"
 android:src="@android:color/holo_green_light" />

 <TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="56dp"
 android:layout_margin="8dp"
 android:drawableRight="@android:drawable/ic_menu_info_details"
 android:gravity="center_vertical"
 android:lines="2"
 android:text="列表项文本在这里,图像上面"
 android:textAppearance="?android:attr/textAppearance" />

</LinearLayout>

element_item_large.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:background="@drawable/bg_white_box"
 android:orientation="vertical"
 android:padding="2dp" >

 <ImageView
 android:id="@+id/imageView1"
 android:layout_width="match_parent"
 android:layout_height="160dp"
 android:src="@android:color/holo_orange_light" />

 <TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_margin="8dp"
 android:drawableRight="@android:drawable/ic_menu_info_details"
 android:gravity="center_vertical"
 android:lines="2"
 android:text="列表项文本在这里,图像上面"
 android:textAppearance="?android:attr/textAppearance" />

</LinearLayout>

element_item_small.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:background="@drawable/bg_white_box"
 android:orientation="vertical"
 android:padding="2dp" >

 <ImageView
 android:id="@+id/imageView1"
 android:layout_width="match_parent"
 android:layout_height="100dp"
 android:src="@android:color/holo_red_light" />

 <TextView
 android:id="@+id/textView1"
 android:layout_width="match_parent"
 android:layout_height="56dp"
 android:layout_margin="8dp"
 android:drawableRight="@android:drawable/ic_menu_info_details"
 android:gravity="center_vertical"
 android:lines="2"
 android:text="列表项文本在这里,图像上面"
 android:textAppearance="?android:attr/textAppearance" />

</LinearLayout>

bg_white_box.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle" >

 <solid android:color="@android:drawable/screen_background_light" />

 <stroke
 android:width="1dp"
 android:color="@android:color/holo_blue_dark" />

</shape>

运行结果如图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • android ListView和GridView拖拽移位实现代码

    关于ListView拖拽移动位置,想必大家并不陌生,比较不错的软件都用到如此功能了.如:搜狐,网易,百度等,但是相比来说还是百度的用户体验较好,不偏心了,下面看几个示例:             首先说一下:拖拽ListView的item就不应该可以任意移动,只应该在ListView所在的范围内,而网易的你看看我都可以移动到状态栏了,虽然你做了处理,但是用户体验我个人感觉不好,在看看百度的,不仅控制了移动范围,更不错的百度的移动起来会时时的换位,看起来相当的形象,所以我认为这样相当的棒.说明一点

  • Android之ScrollView嵌套ListView和GridView冲突的解决方法

    那么里面的ScrollView高度计算就会出现问题.我们也就无法得到想要的效果.核心解决方案: 重写ListView或者GridView的OnMesure 方法. 复制代码 代码如下: public class MyListView extends ListView {        public MyListView(Context context) {                super(context);        }        public MyListView(Conte

  • Android自定义View实现可以拖拽的GridView

    先看看效果图 主要思想: 1.监听触碰事件 2.用WindowManager添加拖曳的图片 3.用Collections.swap()交换List数据 自定义代码: public class DragGridVeiw extends GridView { private final int PRESS_TIME = 1000;//长按时间 private int mDownX;//触碰时的X坐标 private int mDownY;//触碰时的Y坐标 private int mMoveX;//

  • android中GridView的用法示例

    在Android程序设计中GridView跟ListView都是比较常用的多控件布局,而GridView更是实现九宫图的首选!本文就是介绍如何使用GridView实现九宫图.GridView的用法很多,网上介绍最多的方法就是自己实现一个ImageAdapter继承BaseAdapter,再供GridView使用,类似这种的方法本文不再重复,本文介绍的GridView用法跟之前介绍过的ListView极其类似. 我们先来看看本文代码运行的结果: 本文需要添加/修改3个文件:main.xml.nig

  • android GridView多选效果的实例代码

    具体代码如下: main.xml 复制代码 代码如下: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:background="#000000" android:layout_width="fill_parent"

  • Android GridView仿微信朋友圈显示图片

    最近项目要求上传多图并且多图显示,而且要规则的显示,就像微信朋友圈的图片显示一样. 利用GridView再适合不过了,GridView可以动态加载图片的数量,而且还比较规律,下面说一下自己的思路: 1.获取网络图片 2.初始化gridview,自定义适配器 3.根据图片数量设置gridview的列数 4.更新适配器 下面贴上部分源码并给大家解析一下 一.首先是GridView的item <com.view.SquareLayout xmlns:android="http://schemas

  • Android下拉刷新以及GridView使用方法详解

    GridView是类似于ListView的控件,只是GridView可以使用多个列来呈现内容,而ListView是以行为单位,所以用法上是差不多的. 主布局文件,因为要做下拉刷新,所以加了一个ProgressBar,GridView的numColumns属性是指每一行有多少列 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://sch

  • Android GridView实现滚动到指定位置的方法

    当一个列表项目很多,并且每个项目可以进入到其它Activity或者Fragment时,保存之前列表的位置是一个比较不错的功能, 今天研究了一下怎么保存浏览位置,发现GridView和它的父类中有4个相关的方法: 复制代码 代码如下: public void smoothScrollToPosition (int position) 滚动到position指定的位置,api level 11之下可用 *当你滚动完后,返回列表,能正常滚动,但是你再次从列表的项目返回后,滚动失效,就是只能滚动一次,我

  • Android中实现多行、水平滚动的分页的Gridview实例源码

    功能要求: (1)比如每页显示2X2,总共2XN,每个item显示图片+文字(点击有链接). 如果单行水平滚动,可以用Horizontalscrollview实现. 如果是多行水平滚动,则结合Gridview(一般是垂直滚动的)和Horizontalscrollview实现. (2)水平滚动翻页,下面有显示当前页的icon. 1.实现自定义的HorizontalScrollView(HorizontalScrollView.java): 因为要翻页时需要传当前页给调用者,所以fling函数中自己

  • Android GridView不改变背景色实现网格线效果

    项目中需要给GridView添加一个网格线,而且GridView的背景是一张完整的图片,如图所示: 常用的方法是: 1.改变GridView的背景色 2.设置GridView水平或竖直方向的间隔 3设置item的布局文件背景色 上述的方法直接改变了GridView的背景色,显然是不符合项目要求的,我在网上搜索了一下没有找到解决方案,这里给出自己的解决方案: 给item的布局文件添加一个边框背景即可: <shape xmlns:android="http://schemas.android.

随机推荐