专栏首页陶士涵的菜地[android] 天气app布局练习(二)

[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>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • [android] 天气app布局练习

    陶士涵
  • [android] 天气app布局练习(三)

    陶士涵
  • [android] 短信发送器

    /*****************2016年4月23日 更新********************************/

    陶士涵
  • Android实现两个数相加功能

    本文实例为大家分享了Android实现两个数相加的具体代码,供大家参考,具体内容如下

    砸漏
  • 解决异常Circular dependencies cannot exist in RelativeLayout

    今天碰到这个error:E/AndroidRuntime( 4657): Uncaught handler: thread main exiting due ...

    梦_之_旅
  • HorizontalScrollView水平滚动控件使用方法详解

    1、在layout布局文件的最外层建立一个HorizontalScrollView控件

    砸漏
  • Android垂直滚动控件ScrollView使用方法详解

    2、在ScrollView控件中加入一个LinearLayout控件,并且把它的orientation设置为vertical

    砸漏
  • Android 自定义弹出菜单和对话框功能实例代码

    Android 开发当中,可能会存在许多自定义布局的需求,比如自定义弹出菜单(popupWindow),以及自定义对话框(Dialog)。

    砸漏
  • TableLayout(表格布局)基础知识点详解

    前面我们已经学习了平时实际开发中用得较多的线性布局(LinearLayout)与相对布局(RelativeLayout), 其实学完这两个基本就够用了,笔者在实...

    砸漏
  • Android--TableLayout的基本使用

    aruba

扫码关注云+社区

领取腾讯云代金券