如何构建Lite应用程序,例如Twitter Lite或Facebook Lite

时间:2019-05-26 09:47:42

标签: android-layout

我目前正在为Android操作系统开发应用程序,并且正在使用某些功能,因此它只能在Android 5.0及更高版本上运行。 Ans也很大(目前31.23 MB)。我从Facebook Lite开发人员那里读了一篇帖子,他们在其中解释了使用Lite应用程序版本的优势以及他们如何构建自己的版本。我想为我的应用程序做同样的事情。但是我不知道如何创建UI渲染引擎,正如他们所解释的那样,该应用程序必须使用LTS协议在2G网络上下载该应用程序用户界面,就像DOM对象一样。那么,问题是如何从DOM构建用户界面?从他们的帖子中,我们可以了解到使用WebView不是一个好方法。请帮帮我。我们的大多数客户使用2G。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:0)

您的问题不太清楚。但是据我了解,您需要知道如何制作一个可以使用DOM Parser解析XML数据的Android应用程序,不是吗? 因此,由于我不知道您的应用程序确切基于什么,因此我将给出一个简单的代码示例。也许这可以帮助您适应项目逻辑。

假设您要在Android Studio中使用DOM Parser解析用户数据,因此您需要制作一个如下示例的应用程序:

  1. 在Android Studio中创建一个新项目,并将其重命名为 MyParserApp

enter image description here

  1. 将其夹在项目视图中,并找到 src / main 文件夹,右键单击以创建一个新目录,并将其命名为 assets ,如thhis。

enter image description here

  1. 然后,右键单击 assets 文件夹并创建一个新的 Andoid资源文件,为其命名为 myusers.xml ,如下所示:< / li>

enter image description here

  1. 您现在可以打开文件 myusers.xml 并进行如下编码:
<?xml version="1.0" encoding="utf-8"?>

<users>

<user>

<name>Félix Maroy</name>

<fonction>CEO</fonction>

<city>Bukavu</city>

</user>

<user>

<name>Mbuyi Beya</name>

<fonction>Developer</fonction>

<city>Kinshasa</city>

</user>

<user>

<name>John Doe</name>

<fonction>Accountant</fonction>

<city>New York</city>

</user>

</users>
  1. src / layout 中创建一个 Layout资源文件,并将其命名为 users_list.xml ,打开它并像下面这样编写代码:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    android:padding="5dip" >
    <TextView
        android:id="@+id/name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textStyle="bold"
        android:textSize="17dp" />
    <TextView
        android:id="@+id/fonction"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@id/name"
        android:layout_marginTop="7dp"
        android:textColor="#343434"
        android:textSize="14dp" />
    <TextView
        android:id="@+id/city"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/fonction"
        android:layout_alignBottom="@+id/fonction"
        android:layout_alignParentRight="true"
        android:textColor="#343434"
        android:textSize="14dp" />
</RelativeLayout>

它看起来像这样:

enter image description here

  1. 然后在 src / layout 中将您的 activity_main.xml 编码如下:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >
    <ListView
        android:id="@+id/user_list"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:dividerHeight="1dp" />
</LinearLayout>

它看起来像这样:

enter image description here

  1. 最后一步是这样编写 MainActivity.java
package com.mercipro.myparserapp;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
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.HashMap;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        try{
            ArrayList<HashMap<String, String>> userList = new ArrayList<>();
            ListView lv = (ListView) findViewById(R.id.user_list);
            InputStream istream = getAssets().open("myusers.xml");
            DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
            DocumentBuilder docBuilder = builderFactory.newDocumentBuilder();
            Document doc = docBuilder.parse(istream);
            NodeList nList = doc.getElementsByTagName("user");
            for(int i =0;i<nList.getLength();i++){
                if(nList.item(0).getNodeType() == Node.ELEMENT_NODE){
                    HashMap<String,String> user = new HashMap<>();
                    Element elm = (Element)nList.item(i);
                    user.put("name", getNodeValue("name",elm));
                    user.put("fonction", getNodeValue("fonction",elm));
                    user.put("city", getNodeValue("city",elm));
                    userList.add(user);
                }
            }
            ListAdapter adapter = new SimpleAdapter(MainActivity.this, userList, R.layout.users_list,new String[]{"name","fonction","city"}, new int[]{R.id.name, R.id.fonction, R.id.city});
            lv.setAdapter(adapter);
        }
        catch (IOException e) {
            e.printStackTrace();
        } catch (ParserConfigurationException e) {
            e.printStackTrace();
        } catch (SAXException e) {
            e.printStackTrace();
        }
    }
    protected String getNodeValue(String tag, Element element) {
        NodeList nodeList = element.getElementsByTagName(tag);
        Node node = nodeList.item(0);
        if(node!=null){
            if(node.hasChildNodes()){
                Node child = node.getFirstChild();
                while (child!=null){
                    if(child.getNodeType() == Node.TEXT_NODE){
                        return  child.getNodeValue();
                    }
                }
            }
        }
        return "";
    }
}

  1. 现在运行您的应用程序,结果将如下所示

enter image description here

希望这会给您一个有关如何在Android Studio中使用DOM Parser解析XML的想法,以便您可以在阅读某处时构建Lite应用程序(我从不编写Lite应用程序)。