Android UI使用HTML布局方法实例

作者:junjie 时间:2023-04-07 09:14:11 

很多时候我们用HTML布局会更方便直接,记录一下。
我现在主要是直接调用服务器的网页(实际上是jsp的,只是返回的是html),所以需要联网,第一步添加权限。


<uses-permission android:name="android.permission.INTERNET" />

布局文件直接用一个WebView,如下:


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <WebView
        android:id="@+id/webView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>

下面就可以直接写代码了:


package com.yangshidesign.testgryoscope;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.webkit.JavascriptInterface;
import android.webkit.WebView;
import android.widget.Toast;

public class AddEmojiActivity extends Activity {
 private WebView webView;
 
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  this.setContentView(R.layout.activity_addemoji);
  
  webView = (WebView) this.findViewById(R.id.webView1);
  
  webView.getSettings().setJavaScriptEnabled(true);
  webView.addJavascriptInterface(new WebPlugin(), "WebPlugin");
  
  webView.loadUrl(this.getString(R.string.server_url));
 }
 
 /**
  * 插件类,在html的js里面直接调用
  */
 private class WebPlugin {
  
  @JavascriptInterface
  public void test() {
   Log.e("miquan", "kkkkkk");
   Toast.makeText(AddEmojiActivity.this, "test toast ", Toast.LENGTH_SHORT).show();
  }
  
  @JavascriptInterface
  public String test2() {
   return "something";
  }
 }
}



其中@JavascriptInterface注解是添加在每一个需要用到的方法上面的。
最后就可以直接在HTML网页上调用了。


<script type="text/javascript">
 function test() {
  WebPlugin.test();
  var something = WebPlugin.test2();
 }
</script>

标签:Android,UI,HTML,布局
0
投稿

猜你喜欢

  • 利用Spring Session和redis对Session进行共享详解

    2021-10-18 18:22:45
  • MyBatis的9种动态标签详解

    2021-06-21 19:03:40
  • C# 中AutoMapper的使用方法

    2023-04-06 13:17:04
  • Android UI动态设置带有Stroke渐变色背景Drawable

    2023-12-02 15:44:56
  • 利用 filter 机制给静态资源 url 加上时间戳,来防止js和css文件的缓存问题

    2022-03-16 07:51:24
  • Java 中 hashCode() 与 equals() 的关系(面试)

    2023-08-29 18:03:57
  • TextView显示系统时间(时钟功能带秒针变化

    2022-04-23 08:07:37
  • Android实现二维码扫描和生成的简单方法

    2022-06-18 18:15:52
  • Android中通过样式来去除app的头及界面全屏(备忘)的实现方法

    2023-07-30 00:03:23
  • c#集合快速排序类实现代码分享

    2023-03-30 13:38:51
  • 轻松实现Android仿淘宝地区选择功能

    2022-02-25 03:01:13
  • Java Excel透视表相关操作实现代码

    2022-02-27 00:11:01
  • Spring框架初始化解析

    2021-06-09 16:46:59
  • Android自定义view实现输入控件

    2022-12-11 10:08:06
  • Java容器源码LinkedList原理解析

    2023-06-03 02:06:23
  • android点击无效验证的解决方法

    2022-02-28 03:55:08
  • Java SpringMVC异步处理详解

    2021-08-10 15:03:58
  • C# 获取硬盘号,CPU信息,加密解密技术的步骤

    2023-04-23 10:37:50
  • 举例讲解设计模式中的访问者模式在Java编程中的运用

    2022-04-04 08:00:45
  • java判断String类型是否能转换为int的方法

    2022-08-17 23:45:52
  • asp之家 软件编程 m.aspxhome.com