GridView的使用

GridView网格视图,

是按照行和列的分布方式来显示多个组件的,GridView和ListView有共同的父类AbsListView,区别在于GridView是现实多列的。

同时GridView也是通过Adapter来显示数据的。

GridView的属性有:android:columnWidth设置列的宽度;

android:gravity设置对齐方式;

android:horizontalSpacing设置各个元素之间的水平距离;

android:numColumns设置列数;

android:stretchMode设置拉伸模式

android:verticalSpecing设置各个元素之间的垂直距离;

实例:

布局文件代码如下;

<LinearLayout 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:orientation="vertical"
    android:layout_gravity="center_horizontal"
   >
   <GridView
       android:id="@+id/grid_view1"
      android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:horizontalSpacing="1pt"
android:verticalSpacing="1pt"
android:numColumns="4"
android:gravity="center"
       />
   <ImageView 
       android:id="@+id/imageView"
      android:layout_width="240dp"
android:layout_height="240dp"
android:layout_gravity="center_horizontal"/>


</LinearLayout>

java代码如下:

public class MainActivity extends Activity {
    GridView grid;
    ImageView imageView;
    int imageIds[]=new int[]{
    R.drawable.ic_launcher,R.drawable.aaa,R.drawable.de,
    R.drawable.dx,R.drawable.email,R.drawable.exit,
    R.drawable.help
    };
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.fragment_main);
List<Map<String, Object>> listItems = 
new ArrayList<Map<String, Object>>();
for(int i=0;i<imageIds.length;i++){
Map<String,Object> listItem=new HashMap<String,Object>();
listItem.put("aaa", imageIds[i]);
listItems.add(listItem);
}


imageView=(ImageView) findViewById(R.id.imageView);
SimpleAdapter adapter=new SimpleAdapter(this,listItems,
R.layout.activity_main,
new String[]{"aaa"},
       new int[]{R.id.im_view});
grid=(GridView) findViewById(R.id.grid_view1);
       grid.setAdapter(adapter);


grid.setOnItemSelectedListener(new OnItemSelectedListener() {


@Override
public void onItemSelected(AdapterView<?> parent, View view,
int position, long id) {
// TODO Auto-generated method stub
imageView.setImageResource(imageIds[position]);
}


@Override
public void onNothingSelected(AdapterView<?> arg0) {
// TODO Auto-generated method stub

}
});
     grid.setOnItemClickListener(new OnItemClickListener() {


@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
// TODO Auto-generated method stub
imageView.setImageResource(imageIds[position]);
}
});
}
}

activity_main,下的代码如下

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center_horizontal"
android:padding="2pt"
>
<ImageView
android:id="@+id/im_view"
android:layout_width="50dp" 
android:layout_height="50dp" 
/>
</LinearLayout>

实现一个简单的图片浏览器


、综合实战—使用极轴追踪方式绘制信号灯 实战目标:利用对象捕捉追踪极轴追踪功能创建信号灯形 技术要点:结合两种追踪方式实现精确绘,适用于工程制中需要精确定位的场景 1. 切换至AutoCAD 操作步骤: 启动AutoCAD 2016软件 打开随书光盘中的素材文件 确认工作空间为"草与注释"模式 2. 绘设置 1)草设置对话框 打开方式:通过"工具→绘设置"菜单命令 功能定位:该对话框包含捕捉、追踪等核心绘辅助功能设置 2)对象捕捉设置 关键配置: 启用对象捕捉(F3快捷键) 启用对象捕捉追踪(F11快捷键) 勾选端点、中心、圆心、象限点等常用捕捉模式 追踪原理:命令执行时悬停光标可显示追踪矢量,再次悬停可停止追踪 3)极轴追踪设置 参数设置: 启用极轴追踪功能 设置角度增量为45度 确认后退出对话框 3. 绘制信号灯 1)绘制圆形 执行命令:"绘→圆→圆心、半径"命令 绘制过程: 使用对象捕捉追踪定位矩形中心作为圆心 输入半径值30并按Enter确认 通过象限点捕捉确保圆形位置准确 2绘制直线 操作要点: 选择"绘→直线"命令 捕捉矩形上边中点作为起点 捕捉圆的上象限点作为终点 按Enter结束当前直线命令 重复技巧: 按Enter可重复最近使用的直线命令 通过圆心捕捉极轴追踪绘制放射状直线 最终形成完整的信号灯指示案 3)完成绘制 验证要点: 检查所有直线是否准确连接圆心象限点 确认极轴追踪的45度增量是否体现 保存绘文件(快捷键Ctrl+S)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值