AndroidStudio之xml解析天气预报(AS第4章实验2) - 小浣熊博客

AndroidStudio之xml解析天气预报(AS第4章实验2)

发布者: 小浣熊

全网最全的网络资源分享网站

手机扫码查看

特别声明:文章多为网络转载,资源使用一般不提供任何帮助,特殊资源除外,如有侵权请联系!

这篇文章总字数为:12988 字,有 17 张图存于本站服务器

首先,这是一个作业
其次,作业截止时间请看上面活动倒计时。
Good luck.

效果图:

weather1.gif

上代码前得看一下文件结构

文件结构图:

QQ图片20200408185348.png

第一步新建activity_main.xml文件

文件路径:res/layout/

<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="@drawable/weather"
    tools:context=".MainActivity">
    <TextView
        android:id="@+id/tv_city"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignEnd="@+id/tv_weather"
        android:layout_alignParentTop="true"
        android:layout_alignRight="@+id/tv_weather"
        android:layout_marginTop="39dp"
        android:text="上海"
        android:textSize="50sp"/>
    <ImageView
        android:id="@+id/iv_icon"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:layout_alignLeft="@+id/ll_btn"
        android:layout_alignStart="@+id/ll_btn"
        android:layout_below="@+id/tv_city"
        android:layout_marginLeft="44dp"
        android:layout_marginStart="44dp"
        android:layout_marginTop="42dp"
        android:paddingBottom="5dp"
        android:src="@mipmap/ic_launcher"/>
    <TextView
        android:id="@+id/tv_weather"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignRight="@+id/iv_icon"
        android:layout_below="@+id/iv_icon"
        android:layout_marginRight="15dp"
        android:layout_marginTop="18dp"
        android:gravity="center"
        android:text="多云"
        android:textSize="18sp"/>
    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignTop="@+id/iv_icon"
        android:layout_marginLeft="39dp"
        android:layout_marginStart="39dp"
        android:layout_toEndOf="@+id/iv_icon"
        android:layout_toRightOf="@+id/iv_icon"
        android:gravity="center"
        android:orientation="vertical">
        <TextView
            android:id="@+id/tv_temp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="10dp"
            android:gravity="center_vertical"
            android:text="-7℃"
            android:textSize="22sp"/>
        <TextView
            android:id="@+id/tv_wind"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="风力:3级"
            android:textSize="18sp"/>
        <TextView
            android:id="@+id/tv_pm"
            android:layout_width="73dp"
            android:layout_height="wrap_content"
            android:text="pm"
            android:textSize="18sp"/>
    </LinearLayout>
    <LinearLayout
        android:id="@+id/ll_btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:orientation="horizontal">
        <Button
            android:id="@+id/btn_bj"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="北京"/>
        <Button
            android:id="@+id/btn_sh"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="上海"/>
        <Button
            android:id="@+id/btn_gz"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="广州"/>
    </LinearLayout>
</RelativeLayout>

第二步创建weather.xml文件

文件路径:res/raw/

你会不会问raw怎么创建?帮你准备了图解

QQ图片20200408185359.png

QQ图片20200408185403.png

QQ图片20200408185406.pngQQ图片20200408185409.pngQQ图片20200408185412.pngQQ图片20200408185416.png

raw和weather.xml就是这么创建滴,可以复制下面代码了

<?xml version="1.0" encoding="utf-8"?>
<infos>
    <city id="sh">
        <temp>20℃/30℃</temp>
        <weather>晴天多云</weather>
        <name>上海</name>
        <pm>80</pm>
        <wind>1级</wind>
    </city>
    <city id="bj">
        <temp>26℃/32℃</temp>
        <weather>晴天</weather>
        <name>北京</name>
        <pm>98</pm>
        <wind>3级</wind>
    </city>
    <city id="gz">
        <temp>15℃/24℃</temp>
        <weather>多云</weather>
        <name>广州</name>
        <pm>30</pm>
        <wind>5级</wind>
    </city>
</infos>

第三步创建MainActivity.java文件

路径:java/第一个包名/

“这里提醒一下”:.java文件要用自己包名,后面所有.java文件都要用自己包名,别把我包名都copy走啦,包名如下图所示。

QQ图片20200408191413.png

什么?.java文件怎么建?没关系,给你准备好了!

图解如下所示。

QQ图片20200408192750.pngQQ图片20200408192800.pngQQ图片20200408192804.png

其实还有个便捷小妙招,

什么?不早说?

毕竟不符合正常规范,就是复制已有的文件,粘贴出来再改内容,此办法适合所有类型文件----“懒人专用”

QQ图片20200408192754.pngQQ图片20200408192757.png

奥里给!继续上代码

package com.open_open.a17180074weather;

import android.os.Bundle;
import androidx.appcompat.app.AppCompatActivity;
import android.view.View;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MainActivity extends AppCompatActivity implements
        View.OnClickListener {
    private TextView tvCity;
    private TextView tvWeather;
    private TextView tvTemp;
    private TextView tvWind;
    private TextView tvPm;
    private ImageView ivIcon;
    private Map<String, String> map;
    private List<Map<String, String>> list;
    private String temp, weather, name, pm, wind;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 初始化文本控件
        initView();
        try {
            //读取weather1.xml文件
            InputStream is = this.getResources().openRawResource(R.raw.weather);
            //把每个城市的天气信息集合存到weatherInfos中
            List<WeatherInfo> weatherInfos = WeatherServiceDom.getInfosFromXML(is);
            //List<WeatherInfo> weatherInfos = WeatherServiceSax.getInfosFromXML();
            //循环读取weatherInfos中的每一条数据
            list = new ArrayList<Map<String, String>>();
            for (WeatherInfo info : weatherInfos) {
                map = new HashMap<String, String>();
                map.put("temp", info.getTemp());
                map.put("weather", info.getWeather());
                map.put("name", info.getName());
                map.put("pm", info.getPm());
                map.put("wind", info.getWind());
                list.add(map);
            }
        } catch (Exception e) {
            e.printStackTrace();
            Toast.makeText(this, "解析信息失败", Toast.LENGTH_SHORT).show();
        }
        //自定义getMap()方法,显示天气信息到文本控件中,默认显示北京的天气
        getMap(1, R.drawable.sun);
    }
    private void initView() {
        tvCity = (TextView) findViewById(R.id.tv_city);
        tvWeather = (TextView) findViewById(R.id.tv_weather);
        tvTemp = (TextView) findViewById(R.id.tv_temp);
        tvWind = (TextView) findViewById(R.id.tv_wind);
        tvPm = (TextView) findViewById(R.id.tv_pm);
        ivIcon = (ImageView) findViewById(R.id.iv_icon);
        findViewById(R.id.btn_sh).setOnClickListener(this);
        findViewById(R.id.btn_bj).setOnClickListener(this);
        findViewById(R.id.btn_gz).setOnClickListener(this);
    }
    @Override
    public void onClick(View v) {    //按钮的点击事件
        switch (v.getId()) {
            case R.id.btn_sh:
                getMap(0, R.drawable.cloud_sun);
                break;
            case R.id.btn_bj:
                getMap(1, R.drawable.sun);
                break;
            case R.id.btn_gz:
                getMap(2, R.drawable.clouds);
                break;
        }
    }
    //将城市天气信息分条展示到界面上
    private void getMap(int number, int iconNumber) {
        Map<String, String> cityMap = list.get(number);
        temp = cityMap.get("temp");
        weather = cityMap.get("weather");
        name = cityMap.get("name");
        pm = cityMap.get("pm");
        wind = cityMap.get("wind");
        tvCity.setText(name);
        tvWeather.setText(weather);
        tvTemp.setText("" + temp);
        tvWind.setText("风力  : " + wind);
        tvPm.setText("pm: " + pm);
        ivIcon.setImageResource(iconNumber);
    }
}

第四步创建WeatherInfo.java文件

路径:java/第一个包名/

package com.open_open.a17180074weather;
public class WeatherInfo {
    private String id;
    private String temp;
    private String weather;
    private String name;
    private String pm;
    private String wind;
    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getTemp() {
        return temp;
    }

    public void setTemp(String temp) {
        this.temp = temp;
    }

    public String getWeather() {
        return weather;
    }

    public void setWeather(String weather) {
        this.weather = weather;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPm() {
        return pm;
    }

    public void setPm(String pm) {
        this.pm = pm;
    }

    public String getWind() {
        return wind;
    }

    public void setWind(String wind) {
        this.wind = wind;
    }
    @Override
    public String toString(){
        System.out.println("id:"+getId()+"temp:"+getTemp()+"name:"+getName()+"pm:"+getPm()+"weather"+getWeather()+"wind:"+getWind());
        return null;
    }
}

第五步创建WeatherServiceDom.java文件

路径:java/第一个包名/

package com.open_open.a17180074weather;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

public class WeatherServiceDom {
    public static List<WeatherInfo> getInfosFromXML (InputStream is) throws ParserConfigurationException, IOException, SAXException {
        List<WeatherInfo> weatherInfos = null;
        WeatherInfo weatherInfo = null;
        //建立DocumentBuilderFactor,用于获得DocumentBuilder对象:
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        //2.建立DocumentBuidler:
        DocumentBuilder builder = factory.newDocumentBuilder();
        //3.建立Document对象,获取树的入口:
        Document doc = builder.parse(is);
        //4.建立NodeList:
        NodeList node = doc.getElementsByTagName("city");
        weatherInfos = new ArrayList<WeatherInfo>();
        //5.进行xml信息获取
        for(int i=0;i<node.getLength();i++){
            Element e = (Element)node.item(i);
            weatherInfo=new WeatherInfo();
            //String id=e.getAttribute("id");
            //weatherInfo.setId(id);
            String temp=e.getElementsByTagName("temp").item(0).getFirstChild().getNodeValue();
            weatherInfo.setTemp(temp);
            String weather=e.getElementsByTagName("weather").item(0).getFirstChild().getNodeValue();
            weatherInfo.setWeather(weather);
            String name=e.getElementsByTagName("name").item(0).getFirstChild().getNodeValue();
            weatherInfo.setName(name);
            String pm=e.getElementsByTagName("pm").item(0).getFirstChild().getNodeValue();
            weatherInfo.setPm(pm);
            String wind=e.getElementsByTagName("wind").item(0).getFirstChild().getNodeValue();
            weatherInfo.setWind(wind);
            weatherInfos.add(weatherInfo);
        }
        weatherInfo.toString();
        return weatherInfos;
    }
}

第六步创建WeatherServiceSax.java文件

路径:java/第一个包名/

package com.open_open.a17180074weather;

import android.util.Log;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

public class WeatherServiceSax {
    //创建一个LIst容器存放WeatherInfo对象
    static List<WeatherInfo> weatherInfos = null;
    //存放标签名
    static String tagName=null;
    //定义一个对象
    static WeatherInfo weatherInfo = null;

    public static List<WeatherInfo> getInfosFromXML () throws ParserConfigurationException, SAXException, IOException {

        //1.先创建解析器工厂
        SAXParserFactory factory = SAXParserFactory.newInstance();
        //2.利用工厂创建一个解析器
        SAXParser saxParser = factory.newSAXParser();
        //3.调用解析方法,解析文件,该方法有两个参数,第一个参数是要解析的文件,第二个参数是处理类
        try{
            saxParser.parse("raw/weather1.xml",new MyDefaultHandler());
        }catch(SAXException e){
            e.printStackTrace();
        }
        return weatherInfos;
    }
    static class MyDefaultHandler extends DefaultHandler {

        @Override
        public void startDocument()throws SAXException{
            Log.v("sax","startDocument开始解析...");
            weatherInfos = new ArrayList<WeatherInfo>();
        }
        @Override
        public void endDocument() throws SAXException {
            Log.v("sax","endDocument解析完毕...");
        }
        //开始标签
        @Override
        public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
            if(qName.equals("city")) {                 //拿到一个Employee对象
                weatherInfo = new WeatherInfo();                 //就创建一个对象
                String id = attributes.getValue("id");     //获取属性值
            }else {
                tagName = qName;
            }
        }
        //解析一个weatherInfo结束标签
        @Override
        public void endElement(String uri, String localName, String qName) throws SAXException {

            if(qName.equals("city")) {    //此时说明一个对象已经解析完,我们就将当前对象存放到容器中
                weatherInfos.add(weatherInfo);
            }else {
                //因为SAX解析也会识别空文本,所以每次遇到尾标签,需要将tagName值空,避免,将当前的值被空文本给覆盖掉
                tagName = null;
            }
        }
        //当前文本内容
        @Override
        public void characters(char[] ch, int start, int length) throws SAXException {
            //构建当前读取到文本内容
            String msg = new String(ch,start,length);
            //tagName存放这当前的qName,判断当前拿取到的是哪个值
            if(tagName.equals("temp")) {
                weatherInfo.setTemp(msg);
            }else if(tagName.equals("weather")) {
                weatherInfo.setWeather(msg);
            }else if(tagName.equals("name")) {
                weatherInfo.setName(msg);
            }else if(tagName.equals("pm")) {
                weatherInfo.setPm(msg);
            }else if(tagName.equals("wind")) {
                weatherInfo.setWind(msg);
            }
        }

    }
}

第七步创建AndroidManifest.xml文件

路径:app/manifests/,这里再次提醒,第四行package="com.open_open.a17180074weather"不要用我的,不要copy我的包名否则运行失败!!!

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:dist="http://schemas.android.com/apk/distribution"
    package="com.open_open.a17180074weather">
    <dist:module dist:instant="true" />
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".WeatherInfo">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
        <activity android:name=".WeatherServiceDom">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".WeatherServiceSax">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

第八步把下载的附件中资源图片导入

全选图片ctrl+c复制,打开AS中左侧文件栏资源文件夹

路径是res/drawable/

点击文件夹drawable,ctrl+v粘贴图片,导入成功。

图片演示:

QQ图片20200407193709.png

QQ图片20200408173902.pngQQ图片20200407193703.png

源码word文件和图片资源文件我已经打包好了,

下载附件就可以带走啦。

写教程不易!该附件评论后刷新页面可下载,多谢支持!!!

如何快捷评论?

输入QQ号系统自动获取资料,

输入评语,点击发表。

本文最后更新于2020-4-7,已超过 1 年没有更新,如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢!
分享到:
打赏
-版权声明-

阅读时间:  发布于:2020-4-7
文章标题:《AndroidStudio之xml解析天气预报(AS第4章实验2)》
本文链接:https://www.mua222.cn/post-20.html
本文编辑: 小浣熊,转载请注明超链接和出处小浣熊博客
收录状态:[百度已收录][360已收录][搜狗已收录]

评论

     快速回复: 支持 感谢 学习 不错 高兴 给力 加油 惊喜
  1. #55
    ......游客 Lv.1  

  2. #54
    ......游客 Lv.1  

  3. #53
    ......游客 Lv.1  

  4. #52
    这是名字游客 Lv.1  

  5. #51
    这是名字游客 Lv.1  

  6. #50
    这是名字游客 Lv.1  

  7. #49
    给生活加油!游客 Lv.2  

  8. #48
    给生活加油!游客 Lv.2  

  9. #47
    给生活加油!游客 Lv.2  

  10. #46
    给生活加油!游客 Lv.2  

切换注册

登录

忘记密码?

您也可以使用第三方帐号快捷登录

切换登录

注册

AndroidStudio之xml解析天气预报(AS第4章实验2)

长按图片转发给朋友

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏