android开发,使用kotlin学习WebView(详细)

随着后台技术的不断发展,App前端的应用都布置了Web页面的界面,这个界面就是由WebView组件渲染出来的。WebView由如下优点:可以直接显示和渲染Web页面或者网页;可以直接调用网络上或者本地的html文件,也可以和JavaScript交互使用。

1、WebView类提供的常用方法

2、 WebView的简单用法实现浏览网页

步骤:

布局文件

<WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
         />
MainActivity.kt文件

1、启用JavaScript的支持

       调用WebSetting类的setJavaScriptEnabled()方法,设置启动JavaScript的支持

val webView:WebView=findViewById(R.id.webView)
webView.settings.javaScriptEnabled=true

2、目标的网页仍然在当前WebView中显示

      调用WebView的setWebViewClient()方法,从一个网页跳转到另一个网页时,跳转的网页也在webView中显示

webView.webViewClient= WebViewClient()

3.将网址传入

     调用WebView的loadUrl方法,将网址传入,显示网页内容

webView.loadUrl("https://www.baidu.com")

AndroidManifest文件

加入权限声明

     访问网络时需要声明权限的,在AndroidManifest中加入以下权限声明

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

3、结合WebView方法做一个迷你浏览器

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:orientation="vertical">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">
        <Button
            android:id="@+id/back"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="back"/>
        <Button
            android:id="@+id/forward"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="forward"/>
        <Button
            android:id="@+id/refresh"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="refresh"/>
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <EditText
            android:id="@+id/edittext"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="2" />
        <Button
            android:id="@+id/go"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="go" />
    </LinearLayout>
    <WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
         />
</LinearLayout>
class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        //控件
        val webView:WebView=findViewById(R.id.webView)
        val back:Button=findViewById(R.id.back)
        val forward:Button=findViewById(R.id.forward)
        val refresh:Button=findViewById(R.id.refresh)
        val go:Button=findViewById(R.id.go)
        val edittext:EditText=findViewById(R.id.edittext)
        //浏览网页
        webView.settings.javaScriptEnabled=true//启用JavaScript的支持
        webView.webViewClient= WebViewClient()//目标的网页仍然在当前WebView中显示
        webView.loadUrl("https://www.baidu.com")//.将网址传入
        //按键的点击事件
        back.setOnClickListener {
            webView.goBack()//返回
        }
        forward.setOnClickListener {
            webView.goForward()//前进
        }
        refresh.setOnClickListener {
            webView.reload()//重新加载当前页面
        }
        go.setOnClickListener {
            if(edittext.text.toString()!=null) {//判断是否输入网址
                webView.loadUrl("http://" +edittext.text.toString())//加载输入的网址
                webView.webViewClient=WebViewClient()
            }
        }
    }
}
 <uses-permission android:name="android.permission.INTERNET"/>

最终的效果图如下

 

 4、加载本地html页面

新建html的方法(android studio)

右键点击main->"New"->"Folder"->"Assets Folder"

在文件名的后面加".html"

步骤

1.在布局文件中添加WebView组件

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

2、调用WebView的loadUrl()方法(注意是三条///)

val webView:WebView=findViewById(R.id.webView)
        webView.loadUrl("file:///android_asset/a.html")

5、于JavaScript交互调用

WebSetting类提供的常用方法

 

步骤

在布局文件中添加WebView, 调用WebSetting类的setJavaScriptEnabled()方法,设置启动JavaScript的支持,调用WebView的setWebViewClient()方法,调用WebView的loadUrl方法,将html文件传入,新建JavaScriptObject类,调用addJavascriptInterface方法,这样,我们就可以通过js直接使用app,执行JavaScriptObject类里面的方法。

例子展示JavaScript调用Android的通话功能

html文件

<html>
  <head>
    <title>JavaScript交互</title>
  </head>
   <body>
      hello
   </body>
</html>
<script language="JavaScript">
    app.call("10086");
</script>

布局文件(上面已有,就不多放代码了)

AndroidManifest文件

class MainActivity : AppCompatActivity() {
    class JavaScriptObject(var context: Context) {
        @JavascriptInterface//一定要添加这个标签,将该方法暴露给JavaScript
           fun call(n:String)
           {
               var intent= Intent(Intent.ACTION_DIAL).setData(Uri.parse("tel:" + n));
               startActivity(context,intent,null);
           }
    }
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        val webView:WebView=findViewById(R.id.webView)
        webView.webViewClient=WebViewClient()
        webView.settings.javaScriptEnabled=true;
        webView.loadUrl("file:///android_asset/a.html")
        webView.addJavascriptInterface(JavaScriptObject(this),"app")
    }
}

在"Manifest"文件添加电话的权限

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

运行结果如图

 

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你可以使用 KotlinAndroid 中的计步传感器 API 来实现每天计步的功能。以下是一个简单的实现步骤: 1. 在 AndroidManifest.xml 中添加计步传感器权限: ```xml <uses-permission android:name="android.permission.ACTIVITY_RECOGNITION" /> ``` 2. 在 build.gradle 文件中添加计步传感器依赖项: ```groovy dependencies { implementation 'com.google.android.gms:play-services-fitness-ktx:20.0.0' } ``` 3. 在 MainActivity.kt 中实现计步器逻辑: ```kotlin import android.os.Bundle import androidx.appcompat.app.AppCompatActivity import com.google.android.gms.auth.api.signin.GoogleSignIn import com.google.android.gms.fitness.Fitness import com.google.android.gms.fitness.data.DataType import com.google.android.gms.fitness.request.DataReadRequest import com.google.android.gms.fitness.request.SensorRequest import com.google.android.gms.fitness.result.DataReadResponse import kotlinx.android.synthetic.main.activity_main.* import java.text.SimpleDateFormat import java.util.* import java.util.concurrent.TimeUnit class MainActivity : AppCompatActivity() { private val dateFormat = SimpleDateFormat("yyyy-MM-dd", Locale.getDefault()) override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) // 获取 Google 帐号 val account = GoogleSignIn.getAccountForExtension(this, Fitness.SENSORS_API) // 注册计步传感器 Fitness.getSensorsClient(this, account) .add( SensorRequest.Builder() .setDataType(DataType.TYPE_STEP_COUNT_DELTA) .setSamplingRate(1, TimeUnit.SECONDS) .build(), null ) .addOnSuccessListener { // 计步传感器注册成功,开始读取步数数据 readStepCountData(account) } .addOnFailureListener { e -> // 计步传感器注册失败 stepCountTextView.text = "Failed to register step sensor: $e" } } private fun readStepCountData(account: GoogleSignInAccount) { // 构造读取步数数据的请求 val today = Date() val endTime = today.time val startTime = dateFormat.parse(dateFormat.format(today))!!.time val request = DataReadRequest.Builder() .read(DataType.TYPE_STEP_COUNT_DELTA) .setTimeRange(startTime, endTime, TimeUnit.MILLISECONDS) .build() // 发送读取步数数据的请求 Fitness.getHistoryClient(this, account) .readData(request) .addOnSuccessListener { response -> // 处理读取到的步数数据 handleStepCountData(response) } .addOnFailureListener { e -> // 读取步数数据失败 stepCountTextView.text = "Failed to read step count data: $e" } } private fun handleStepCountData(response: DataReadResponse) { var totalSteps = 0 for (dataSet in response.getDataSets()) { for (dataPoint in dataSet.getDataPoints()) { totalSteps += dataPoint.getValue(Field.FIELD_STEPS).asInt() } } stepCountTextView.text = "Today's steps: $totalSteps" } } ``` 通过上述代码,你可以实现一个简单的每天计步的功能。当你打开应用时,它将自动注册计步传感器并读取当天的步数数据,并将其显示在界面上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值