當前位置:
首頁 > 最新 > 使用C#開發Android應用之WebApp

使用C#開發Android應用之WebApp

近段時間了解了一下VS2017開發安卓應用的一些技術,特地把C#開發WebApp的一些過程記錄下來,歡迎大家一起指教、討論,廢話少說,是時候開始表演真正的技術了。。


1、新建空白Android應用




4.1打開MainActivity.cs,在OnCreate方法里添加2行代碼

protected override void OnCreate(Bundle savedInstanceState)

{

base.OnCreate(savedInstanceState);

// Set our view from the "main" layout resource

SetContentView(Resource.Layout.Main);

var web = FindViewById(Resource.Id.webView1);

}

載入網頁就是這樣簡單,F5調試,就可以看到模擬器有了變化,打開了我們的應用,並如期載入了網頁


5.1打開MainActivity.cs,重寫OnCreate為如下

protected override void OnCreate(Bundle savedInstanceState)

{

base.OnCreate(savedInstanceState);

var webView = new WebView(this);

SetContentView(webView);

webView.Settings.JavaScriptEnabled = true;

webView.AddJavascriptInterface(new CustomJSInterface(this), "CSharp");

webView.LoadUrl("http://192.168.0.113:8080/");

}

標紅的是實現前端調用後台方法的關鍵,新建CustomJSInterface.cs

public class CustomJSInterface : Java.Lang.Object

{

Context context;

public CustomJSInterface(Context context)

{

this.context = context;

}

[Export]

[JavascriptInterface]

public void ShowToast(string message)

{

Toast.MakeText(context, message, ToastLength.Short).Show();

}

}

而"http://192.168.0.113:8080/"是我們的Web站點,大部分業務邏輯在網站里處理,WebApp只是在外表包了一個殼

5.2我們再新建一個本地Web站點

改動首頁HTML,主要功能是點擊按鈕,會調用後台ShowToast,這是個提示功能

@{

ViewBag.Title = "Home Page";

}

由前端調用C#後台方法

瀏覽器預覽

5.3 VS2017按F5部署,可以看的模擬器也正常把本地站點載入進來了

點擊"獲取前端JS返回的數據"

6.1重寫OnCreate

// 必須重寫WebView客戶端

webView.SetWebViewClient(new CustomWebViewClient());

// 先打開首頁

webView.LoadUrl("http://192.168.0.113:8080/");

// APP主動獲取前端數據

var btn = FindViewById(Resource.Id.button1);

btn.Click += delegate

{

var callback = new ReceiveValueCallback();

callback.OnReceiveValueCallback += (message) =>

{

Toast.MakeText(this.ApplicationContext, message, ToastLength.Short).Show();

};

webView.EvaluateJavascript("GetData()", callback);

};

6.2新建CustomWebViewClient.cs

class CustomWebViewClient : WebViewClient

{

public override bool ShouldOverrideUrlLoading(WebView view, String url)

{

view.LoadUrl(url);

return true;

}

}

6.3 新建ReceiveValueCallback.cs,這個類主要負責處理前端返回的數據

public class ReceiveValueCallback : Java.Lang.Object, IValueCallback

{

public delegate void OnReceiveValueCallbackHandler(string message);

public event OnReceiveValueCallbackHandler OnReceiveValueCallback;

// 重寫ReceiveValue方法

public void OnReceiveValue(Java.Lang.Object value)

{

OnReceiveValueCallback(value.ToString());

}

}

6.4修改Index.html

@{

ViewBag.Title = "Home Page";

}

由前端調用C#後台方法

function GetData() {

}

6.5 VS2017按F5部署

6.6 點擊按鈕"獲取前端JS返回的數據"


7.1細心的人可能注意到:前端代碼完全可以自己處理完業務,那還有WebApp什麼事情呢?這時的APP完全就跟一個瀏覽器差不多!

7.2確實是這樣的WebApp相對與其他安卓APP來說,是輕量級的,只是一個殼子,但是他也是有其合適的使用範圍;

比如:如果前端並沒有數據持久化功能(如純JS前端),這時要保存數據只能調用其他的WebApi,而由於JS的特性可能會引起一些安全問題。

或者根本沒有第三方API,數據需要保存在手機端,JS也沒有這種許可權。

所以既兼顧了像升級Web站點那樣簡便,又有一些手機端的操作許可權,WebApp應運而生。

原文:https://www.cnblogs.com/lanxiaoke/p/8725370.html


喜歡這篇文章嗎?立刻分享出去讓更多人知道吧!

本站內容充實豐富,博大精深,小編精選每日熱門資訊,隨時更新,點擊「搶先收到最新資訊」瀏覽吧!


請您繼續閱讀更多來自 dotNET跨平台 的精彩文章:

【ASP.NET Core】處理異常
Entity Framework Core 之資料庫遷移

TAG:dotNET跨平台 |