当前位置:  编程技术>移动开发

如何在android中使用html作布局文件

    来源: 互联网  发布时间:2014-10-21

    本文导语:  在android开发中,通常使用xml格式来描述布局文件。就目前而言,熟悉android布局及美化的人员少之又少,出现了严重的断层。大部分企业,其实还是程序员自己动手布局。这样既浪费时间和精力,也未必能达到理想的效果。但...

在android开发中,通常使用xml格式来描述布局文件。就目前而言,熟悉android布局及美化的人员少之又少,出现了严重的断层。大部分企业,其实还是程序员自己动手布局。这样既浪费时间和精力,也未必能达到理想的效果。但是,在企业级的android开发中,使用html页面进行布局,也有很多的优势(例如:简单,大部分开发人员及美工都熟悉,方便统一进行更新,管理)。据笔者了解,已经有不少的公司在使用这种方式进行布局开发。这也可能是一种趋势。

下面,我将给出一个实例代码,供大家学习使用html页面给android应用布局。

代码如下:

package com.dazhuo.ui;

import java.util.List;

import org.json.JSONArray;
import org.json.JSONObject;

import com.dazhuo.domain.Person;
import com.dazhuo.service.PersonService;

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.webkit.WebView;


public class MainActivity extends Activity {
   private PersonService service;
   private WebView webview;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        service =new PersonService();
        webview = (WebView) this.findViewById(R.id.webView);//android内置浏览器对象
        webview.getSettings().setJavaScriptEnabled(true);//启用javascript支持
        //添加一个js交互接口,方便html布局文件中的javascript代码能与后台java代码直接交互访问
        webview.addJavascriptInterface(new PersonPlugin() , "Person");//new类名,交互访问时使用的别名
       //
        webview.loadUrl("file:///android_asset/index.html");//加载本地的html布局文件
        //其实可以把这个html布局文件放在公网中,这样方便随时更新维护  例如 webview.loadUrl("/tech-mobile-dev/www.xxxx.com/index.html");
    }
    //定义一个内部类,从java后台(可能是从网络,文件或者sqllite数据库) 获取List集合数据,并转换成json字符串,调用前台js代码
    private final class PersonPlugin{
     public void getPersonList(){
      List list = service.getPersonList();//获得List数据集合
      //将List泛型集合的数据转换为JSON数据格式
       try {
   JSONArray arr =new JSONArray();
   for(Person person :list)
   {
    JSONObject json =new JSONObject();
    json.put("id", person.getId());
    json.put("name", person.getName());
    json.put("mobile",person.getMobile());
    arr.put(json);

   }
   String JSONStr =arr.toString();//转换成json字符串
   webview.loadUrl("javascript:show('"+ JSONStr +"')");//执行html布局文件中的javascript函数代码--
    Log.i("MainActivity", JSONStr);
       } catch (Exception e) {
   // TODO: handle exception
  }

     }
     //打电话的方法
  public void call(String mobile){
      Intent intent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:"+ mobile));
      startActivity(intent);
     }
    }
}


代码如下:

package com.dazhuo.domain;

public class Person {
    private Integer id;
    public Integer getId() {
  return id;
 }
 public Person(Integer id, String name, String mobile) {
  super();
  this.id = id;
  this.name = name;
  this.mobile = mobile;
 }
 public void setId(Integer id) {
  this.id = id;
 }
 public String getName() {
  return name;
 }
 public void setName(String name) {
  this.name = name;
 }
 public String getMobile() {
  return mobile;
 }
 public void setMobile(String mobile) {
  this.mobile = mobile;
 }
 private String name;
    private String mobile;
}


代码如下:

package com.dazhuo.service;

import java.util.ArrayList;
import java.util.List;

import com.dazhuo.domain.Person;

public class PersonService {
   public List getPersonList()
   {

    List list =new ArrayList();
    list.add(new Person(32, "aa", "13675574545"));
    list.add(new Person(32, "bb", "13698874545"));
    list.add(new Person(32, "cc", "13644464545"));
    list.add(new Person(32, "dd", "13908978877"));
    list.add(new Person(32, "ee", "15908989898"));
     return list;
   }
}


代码如下:





Insert title here

 function show(jsondata){
         var jsonobjs = eval(jsondata);
         var table = document.getElementById("personTable");
         for(var y=0; y

    
 
 

您可能感兴趣的文章:

  • 手写android布局示例
  • android动态加载布局文件示例
  • android layout 按比例布局的代码
  • Android自定义View设定到FrameLayout布局中实现多组件显示的方法 分享
  • Android 布局控件之LinearLayout详细介绍
  • android Activity相对布局的使用方法
  • Android中使用include标签和merge标签重复使用布局
  • android LinearLayout和RelativeLayout组合实现精确布局方法介绍
  • Android布局——Preference自定义layout的方法
  • android Activity线性布局和表格布局实例讲解
  • Android自定义格式显示Button的布局思路
  • android布局属性详解分享
  • android界面布局之实现文本块布局效果示例
  • Android RelativeLayout相对布局属性简析
  • android LinearLayout 布局实例代码
  • Android实现加载广告图片和倒计时的开屏布局
  • android 布局属性详解
  • 深入Android 五大布局对象的应用
  • android 线性布局LinearLayout实例代码
  • android自定义RadioGroup可以添加多种布局的实现方法
  • Android创建文件实现对文件监听示例
  • Android文件管理器 雪梦文件管理器
  • Android中删除文件以及文件夹的命令记录
  • Android文件管理器 Astro
  • Android文件管理器 AndFileManage
  • android通过配置文件设置应用安装到SD卡上的方法
  • android开发教程之系统资源的使用方法 android资源文件
  • android保存Bitmap图片到指定文件夹示例
  • android读取assets文件示例
  • Android 工程内嵌资源文件的两种方法
  • android下跑ubuntu下的可执行文件
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 申请Android Map 的API Key(v2)的最新申请方式(SHA1密钥)
  • Android瀑布流实例 android_waterfall
  • Android开发需要的几点注意事项总结
  • Android系统自带样式 (android:theme)
  • android 4.0 托管进程介绍及优先级和回收机制
  • Android网络共享软件 Android Wifi Tether
  • Android访问与手机通讯相关类的介绍
  • Android 图标库 Android GraphView
  • Android及andriod无线网络Wifi开发的几点注意事项
  • 轻量级Android开发工具 Android Tools
  • Android 2.3 下StrictMode介绍
  • Android 开发环境 Android Studio
  • IDEA的Android开发插件 idea-android
  • Android手机事件提醒 Android Notifier
  • XBMC的Android客户端 android-xbmcremote
  • Android小游戏 Android Shapes
  • Android电池监控 Android Battery Dog
  • android开发:“android:WindowTitle”没有对应项no resource
  • Android 上类似IOS 的开关控件。 Android ToggleButton
  • Android 将 android view 的位置设为右下角的解决方法
  • Android 2D游戏引擎 Android Angle


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3