[android] 天气app布局练习(二)
主要练习一下GridView
MainActivity.java
package com.example.weatherreport; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.os.Bundle; import android.widget.GridView; import android.widget.SimpleAdapter; public class MainActivity extends Activity { private GridView gv_airs; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); gv_airs=(GridView) findViewById(R.id.gv_airs); makeGridView(); } /** * 组装GridView */ private void makeGridView() { List<Map<String, String>> data=new ArrayList<>(); Map<String,String> item=null; item=new HashMap<>(); item.put("title", "83"); item.put("desc", "湿度(%)"); data.add(item); item=new HashMap<>(); item.put("title", "11.3"); item.put("desc", "可见度(km)"); data.add(item); item=new HashMap<>(); item.put("title", "2级"); item.put("desc", "东南风"); data.add(item); item=new HashMap<>(); item.put("title", "最弱"); item.put("desc", "紫外线"); data.add(item); item=new HashMap<>(); item.put("title", "1005.5"); item.put("desc", "气压(mb)"); data.add(item); item=new HashMap<>(); item.put("title", "22.4"); item.put("desc", "体感"); data.add(item); SimpleAdapter adapter=new SimpleAdapter(this, data, R.layout.main_grid_item, new String[]{"title","desc"}, new int[]{R.id.tv_title,R.id.tv_desc}); gv_airs.setAdapter(adapter); } }
activity_main.xml
<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:background="#3186D9" tools:context="${relativePackage}.${activityClass}" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="10dp" android:layout_marginTop="10dp" android:src="@drawable/icon_home" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:layout_marginTop="12dp" android:text="北京" android:textColor="#FDFDFD" /> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_marginRight="10dp" android:layout_marginTop="10dp" android:src="@drawable/icon_more" /> <TextView android:id="@+id/tv_number" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:layout_marginTop="70dp" android:text="29" android:textColor="#fff" android:textSize="50sp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignTop="@id/tv_number" android:layout_toRightOf="@id/tv_number" android:text="°" android:textColor="#FDFDFD" android:textSize="30sp" /> <LinearLayout android:id="@+id/ll_weather" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@id/tv_number" android:layout_centerHorizontal="true" android:orientation="horizontal" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:text="多云" android:textColor="#FDFDFD" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:text=" | " android:textColor="#bbb" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerHorizontal="true" android:text="空气优" android:textColor="#FDFDFD" /> </LinearLayout> <View android:id="@+id/gv_airs_top" android:layout_width="match_parent" android:layout_height="1dp" android:layout_below="@id/ll_weather" android:layout_marginTop="20dp" android:background="#ddd" /> <GridView android:id="@+id/gv_airs" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_below="@id/gv_airs_top" android:background="#ddd" android:horizontalSpacing="1dp" android:listSelector="@android:color/transparent" android:numColumns="3" android:verticalSpacing="1dp" /> <View android:layout_width="match_parent" android:layout_height="1dp" android:layout_below="@id/gv_airs" android:background="#ddd" /> </RelativeLayout>
main_grid_item.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#3186D9" android:layout_marginLeft="1dp" > <LinearLayout android:layout_width="wrap_content" android:layout_height="wrap_content" android:paddingTop="25dp" android:paddingBottom="25dp" android:layout_centerInParent="true" android:gravity="center" android:orientation="vertical" > <TextView android:id="@+id/tv_desc" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="湿度(%)" android:textColor="#ddd" android:textSize="12sp" /> <TextView android:id="@+id/tv_title" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="83" android:textColor="#fff" android:textSize="22sp" /> </LinearLayout> </RelativeLayout>
十年开发经验程序员,离职全心创业中,历时三年开发出的产品《唯一客服系统》
一款基于Golang+Vue开发的在线客服系统,软件著作权编号:2021SR1462600。一套可私有化部署的网站在线客服系统,编译后的二进制文件可直接使用无需搭开发环境,下载zip解压即可,仅依赖MySQL数据库,是一个开箱即用的全渠道在线客服系统,致力于帮助广大开发者/公司快速部署整合私有化客服功能。
开源地址:唯一客服(开源学习版)
官网地址:唯一客服官网