একটি ক্লায়েন্ট অ্যাপ্লিকেশনের একটি অংশ হিসাবে একটি ওয়েব অ্যাপ্লিকেশন বা একটি ওয়েব পৃষ্ঠা সরবরাহ করতে WebView
ব্যবহার করুন৷ WebView
ক্লাস অ্যান্ড্রয়েডের View
ক্লাসের একটি এক্সটেনশন যা আপনাকে আপনার অ্যাক্টিভিটি লেআউটের অংশ হিসেবে ওয়েব পৃষ্ঠাগুলি প্রদর্শন করতে দেয়। এটি একটি সম্পূর্ণরূপে উন্নত ওয়েব ব্রাউজারের বৈশিষ্ট্যগুলি অন্তর্ভুক্ত করে না, যেমন নেভিগেশন নিয়ন্ত্রণ বা একটি ঠিকানা বার৷ সমস্ত WebView
করে, ডিফল্টরূপে, একটি ওয়েব পৃষ্ঠা দেখায়৷
WebView
আপনাকে আপনার অ্যাপে এমন তথ্য প্রদান করতে সাহায্য করতে পারে যা আপনাকে আপডেট করার প্রয়োজন হতে পারে, যেমন একটি শেষ-ব্যবহারকারী চুক্তি বা ব্যবহারকারীর নির্দেশিকা। আপনার অ্যান্ড্রয়েড অ্যাপের মধ্যে, আপনি একটি WebView
ধারণ করে এমন একটি Activity
তৈরি করতে পারেন, তারপর এটি অনলাইনে হোস্ট করা আপনার নথি প্রদর্শন করতে ব্যবহার করুন৷
WebView
এছাড়াও সাহায্য করতে পারে যখন আপনার অ্যাপ ব্যবহারকারীকে ডেটা সরবরাহ করে যার জন্য ইমেলের মতো ডেটা পুনরুদ্ধারের জন্য ইন্টারনেট সংযোগের প্রয়োজন হয়৷ এই ক্ষেত্রে, আপনি খুঁজে পেতে পারেন যে আপনার অ্যান্ড্রয়েড অ্যাপে একটি WebView
তৈরি করা সহজ যা একটি নেটওয়ার্ক অনুরোধ সম্পাদন করার পরিবর্তে সমস্ত ব্যবহারকারীর ডেটা সহ একটি ওয়েব পৃষ্ঠা দেখায়, তারপরে ডেটা পার্স করা এবং এটিকে একটি Android লেআউটে রেন্ডার করা৷ পরিবর্তে, আপনি একটি ওয়েব পৃষ্ঠা ডিজাইন করতে পারেন যা অ্যান্ড্রয়েড-চালিত ডিভাইসগুলির জন্য তৈরি করা হয়েছে এবং তারপরে আপনার অ্যান্ড্রয়েড অ্যাপে একটি WebView
প্রয়োগ করতে পারেন যা ওয়েব পৃষ্ঠাটি লোড করে৷
এই ডকুমেন্টটি বর্ণনা করে কিভাবে WebView
এর সাথে শুরু করতে হয়, কিভাবে JavaScript আপনার ওয়েব পৃষ্ঠা থেকে আপনার Android অ্যাপে ক্লায়েন্ট-সাইড কোডে আবদ্ধ করতে হয়, কিভাবে পৃষ্ঠা নেভিগেশন পরিচালনা করতে হয় এবং WebView
ব্যবহার করার সময় কিভাবে উইন্ডোজ পরিচালনা করতে হয়।
Android এর আগের সংস্করণগুলিতে WebView এর সাথে কাজ করুন
আপনার অ্যাপ যে ডিভাইসে চলছে তাতে সাম্প্রতিক WebView
ক্ষমতাগুলি নিরাপদে ব্যবহার করতে, AndroidX ওয়েবকিট লাইব্রেরি যোগ করুন। এটি একটি স্ট্যাটিক লাইব্রেরি যা আপনি android.webkit
API ব্যবহার করতে আপনার অ্যাপ্লিকেশনে যোগ করতে পারেন যা আগের প্ল্যাটফর্ম সংস্করণগুলির জন্য উপলব্ধ নয়৷
এটিকে আপনার build.gradle
ফাইলে নিম্নরূপ যোগ করুন:
dependencies { implementation("androidx.webkit:webkit:1.8.0") }
dependencies { implementation ("androidx.webkit:webkit:1.8.0") }
আরও বিশদ বিবরণের জন্য GitHub-এ WebView
উদাহরণটি অন্বেষণ করুন।
আপনার অ্যাপে একটি ওয়েবভিউ যোগ করুন
আপনার অ্যাপে একটি WebView
যোগ করতে, আপনি আপনার অ্যাক্টিভিটি লেআউটে <WebView>
উপাদানটি অন্তর্ভুক্ত করতে পারেন বা onCreate()
এ একটি WebView
হিসেবে সমগ্র Activity
উইন্ডো সেট করতে পারেন।
অ্যাক্টিভিটি লেআউটে একটি ওয়েবভিউ যোগ করুন
লেআউটে আপনার অ্যাপে একটি WebView
যোগ করতে, আপনার কার্যকলাপের লেআউট XML ফাইলে নিম্নলিখিত কোড যোগ করুন:
<WebView android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent" />
WebView
এ একটি ওয়েব পৃষ্ঠা লোড করতে, loadUrl()
ব্যবহার করুন, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
val myWebView: WebView = findViewById(R.id.webview) myWebView.loadUrl("http://www.example.com")
WebView myWebView = (WebView) findViewById(R.id.webview); myWebView.loadUrl("http://www.example.com");
onCreate() এ একটি ওয়েবভিউ যোগ করুন
পরিবর্তে একটি কার্যকলাপের onCreate()
পদ্ধতিতে আপনার অ্যাপে একটি WebView
যোগ করতে, নিম্নলিখিতগুলির মতো যুক্তি ব্যবহার করুন:
val myWebView = WebView(activityContext) setContentView(myWebView)
WebView myWebView = new WebView(activityContext); setContentView(myWebView);
তারপর পৃষ্ঠাটি লোড করুন:
myWebView.loadUrl("http://www.example.com")
myWebView.loadUrl("https://www.example.com");
অথবা একটি HTML স্ট্রিং থেকে URL লোড করুন:
// Create an unencoded HTML string, then convert the unencoded HTML string into // bytes. Encode it with base64 and load the data. val unencodedHtml = "<html><body>'%23' is the percent code for ‘#‘ </body></html>"; val encodedHtml = Base64.encodeToString(unencodedHtml.toByteArray(), Base64.NO_PADDING) myWebView.loadData(encodedHtml, "text/html", "base64")
// Create an unencoded HTML string, then convert the unencoded HTML string into // bytes. Encode it with base64 and load the data. String unencodedHtml = "<html><body>'%23' is the percent code for ‘#‘ </body></html>"; String encodedHtml = Base64.encodeToString(unencodedHtml.getBytes(), Base64.NO_PADDING); myWebView.loadData(encodedHtml, "text/html", "base64");
আপনার অ্যাপের ইন্টারনেট অ্যাক্সেস থাকতে হবে। ইন্টারনেট অ্যাক্সেস পেতে, আপনার ম্যানিফেস্ট ফাইলে INTERNET
অনুমতির জন্য অনুরোধ করুন, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
<manifest ... > <uses-permission android:name="android.permission.INTERNET" /> ... </manifest>
আপনি নিম্নলিখিত যে কোনো একটি করে আপনার WebView
কাস্টমাইজ করতে পারেন:
-
WebChromeClient
ব্যবহার করে পূর্ণস্ক্রীন সমর্থন সক্ষম করা হচ্ছে। এই ক্লাসটিও বলা হয় যখন একটিWebView
এর হোস্ট অ্যাপের UI পরিবর্তন করার জন্য অনুমতির প্রয়োজন হয়, যেমন উইন্ডো তৈরি করা বা বন্ধ করা বা ব্যবহারকারীকে JavaScript ডায়ালগ পাঠানো। এই প্রসঙ্গে ডিবাগিং সম্পর্কে আরও জানতে, ডিবাগ ওয়েব অ্যাপস পড়ুন। - বিষয়বস্তু রেন্ডারিংকে প্রভাবিত করে এমন ইভেন্টগুলি পরিচালনা করা, যেমন ফর্ম জমা দেওয়ার ক্ষেত্রে ত্রুটি বা
WebViewClient
ব্যবহার করে নেভিগেশন। আপনি URL লোডিং আটকাতে এই সাবক্লাসটি ব্যবহার করতে পারেন। -
WebSettings
পরিবর্তন করে JavaScript সক্রিয় করা হচ্ছে। - Android ফ্রেমওয়ার্ক অবজেক্ট অ্যাক্সেস করতে JavaScript ব্যবহার করে যা আপনি একটি
WebView
এ ইনজেকশন করেছেন।
WebView এ JavaScript ব্যবহার করুন
আপনি যে ওয়েব পৃষ্ঠাটি আপনার WebView
এ লোড করতে চান সেটি JavaScript ব্যবহার করলে, আপনাকে অবশ্যই আপনার WebView
এর জন্য JavaScript সক্ষম করতে হবে। আপনি JavaScript সক্ষম করার পরে, আপনি আপনার অ্যাপ কোড এবং আপনার JavaScript কোডের মধ্যে ইন্টারফেস তৈরি করতে পারেন।
জাভাস্ক্রিপ্ট সক্রিয় করুন
জাভাস্ক্রিপ্ট ডিফল্টরূপে WebView
অক্ষম করা থাকে। আপনি আপনার WebView
এর সাথে সংযুক্ত WebSettings
মাধ্যমে এটি সক্ষম করতে পারেন। getSettings()
দিয়ে WebSettings
পুনরুদ্ধার করুন, তারপর setJavaScriptEnabled()
দিয়ে JavaScript সক্ষম করুন।
নিম্নলিখিত উদাহরণ দেখুন:
val myWebView: WebView = findViewById(R.id.webview) myWebView.settings.javaScriptEnabled = true
WebView myWebView = (WebView) findViewById(R.id.webview); WebSettings webSettings = myWebView.getSettings(); webSettings.setJavaScriptEnabled(true);
WebSettings
অন্যান্য বিভিন্ন সেটিংসে অ্যাক্সেস প্রদান করে যা আপনার কাজে লাগতে পারে। উদাহরণস্বরূপ, যদি আপনি একটি ওয়েব অ্যাপ্লিকেশন তৈরি করেন যা আপনার Android অ্যাপে WebView
জন্য বিশেষভাবে ডিজাইন করা হয়েছে, তাহলে আপনি setUserAgentString()
দিয়ে একটি কাস্টম ব্যবহারকারী এজেন্ট স্ট্রিং সংজ্ঞায়িত করতে পারেন, তারপর যাচাই করতে আপনার ওয়েব পৃষ্ঠায় কাস্টম ব্যবহারকারী এজেন্টকে জিজ্ঞাসা করুন ক্লায়েন্ট আপনার ওয়েব পেজ অনুরোধ আপনার অ্যান্ড্রয়েড অ্যাপ্লিকেশন.
জাভাস্ক্রিপ্ট কোডকে অ্যান্ড্রয়েড কোডে আবদ্ধ করুন
আপনার Android অ্যাপে WebView
জন্য বিশেষভাবে ডিজাইন করা একটি ওয়েব অ্যাপ্লিকেশন তৈরি করার সময়, আপনি আপনার JavaScript কোড এবং ক্লায়েন্ট-সাইড অ্যান্ড্রয়েড কোডের মধ্যে ইন্টারফেস তৈরি করতে পারেন। উদাহরণস্বরূপ, আপনার JavaScript কোড জাভাস্ক্রিপ্টের alert()
ফাংশন ব্যবহার করার পরিবর্তে একটি Dialog
প্রদর্শন করতে আপনার Android কোডের একটি পদ্ধতিতে কল করতে পারে।
আপনার জাভাস্ক্রিপ্ট এবং অ্যান্ড্রয়েড কোডের মধ্যে একটি নতুন ইন্টারফেস আবদ্ধ করতে, addJavascriptInterface()
কল করুন, এটিকে আপনার জাভাস্ক্রিপ্টে আবদ্ধ করার জন্য একটি ক্লাস ইন্সট্যান্স পাস করে এবং একটি ইন্টারফেসের নাম যা আপনার জাভাস্ক্রিপ্ট ক্লাস অ্যাক্সেস করতে কল করতে পারে।
উদাহরণস্বরূপ, আপনি আপনার অ্যান্ড্রয়েড অ্যাপে নিম্নলিখিত শ্রেণী অন্তর্ভুক্ত করতে পারেন:
/** Instantiate the interface and set the context. */ class WebAppInterface(private val mContext: Context) { /** Show a toast from the web page. */ @JavascriptInterface fun showToast(toast: String) { Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show() } }
public class WebAppInterface { Context mContext; /** Instantiate the interface and set the context. */ WebAppInterface(Context c) { mContext = c; } /** Show a toast from the web page. */ @JavascriptInterface public void showToast(String toast) { Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show(); } }
এই উদাহরণে, WebAppInterface
ক্লাস ওয়েব পেজটিকে showToast()
পদ্ধতি ব্যবহার করে একটি Toast
বার্তা তৈরি করতে দেয়।
আপনি এই ক্লাসটিকে জাভাস্ক্রিপ্টের সাথে আবদ্ধ করতে পারেন যা আপনার WebView
এ addJavascriptInterface()
দিয়ে চলে, যেমনটি নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
val webView: WebView = findViewById(R.id.webview) webView.addJavascriptInterface(WebAppInterface(this), "Android")
WebView webView = (WebView) findViewById(R.id.webview); webView.addJavascriptInterface(new WebAppInterface(this), "Android");
এটি WebView
চলমান জাভাস্ক্রিপ্টের জন্য Android
নামে একটি ইন্টারফেস তৈরি করে। এই মুহুর্তে, আপনার ওয়েব অ্যাপ্লিকেশনটির WebAppInterface
ক্লাসে অ্যাক্সেস রয়েছে। উদাহরণস্বরূপ, এখানে কিছু এইচটিএমএল এবং জাভাস্ক্রিপ্ট রয়েছে যা ব্যবহারকারী যখন একটি বোতামে ট্যাপ করে তখন নতুন ইন্টারফেস ব্যবহার করে একটি টোস্ট বার্তা তৈরি করে:
<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" /> <script type="text/javascript"> function showAndroidToast(toast) { Android.showToast(toast); } </script>
জাভাস্ক্রিপ্ট থেকে Android
ইন্টারফেস আরম্ভ করার কোন প্রয়োজন নেই। WebView
স্বয়ংক্রিয়ভাবে এটি আপনার ওয়েব পৃষ্ঠায় উপলব্ধ করে। সুতরাং, যখন একজন ব্যবহারকারী বোতামে ট্যাপ করে, showAndroidToast()
ফাংশনটি Android
ইন্টারফেস ব্যবহার করে WebAppInterface.showToast()
পদ্ধতিতে কল করে।
পৃষ্ঠা নেভিগেশন হ্যান্ডেল
যখন ব্যবহারকারী আপনার WebView
এ একটি ওয়েব পৃষ্ঠা থেকে একটি লিঙ্কে ট্যাপ করে, ডিফল্টরূপে, Android একটি অ্যাপ চালু করে যা URL গুলি পরিচালনা করে৷ সাধারণত, ডিফল্ট ওয়েব ব্রাউজার খোলে এবং গন্তব্য URL লোড করে। যাইহোক, আপনি আপনার WebView
এর জন্য এই আচরণটি ওভাররাইড করতে পারেন যাতে লিঙ্কগুলি আপনার WebView
মধ্যে খোলা থাকে। তারপরে আপনি ব্যবহারকারীকে তাদের ওয়েব পৃষ্ঠার ইতিহাসের মাধ্যমে পিছনে এবং এগিয়ে যেতে দিতে পারেন যা আপনার WebView
দ্বারা রক্ষণাবেক্ষণ করে।
ব্যবহারকারীর দ্বারা ট্যাপ করা লিঙ্কগুলি খুলতে, setWebViewClient()
ব্যবহার করে আপনার WebView
এর জন্য একটি WebViewClient
প্রদান করুন। সমস্ত লিঙ্ক ব্যবহারকারী ট্যাপ করে আপনার WebView
এ লোড করে। একটি ক্লিক করা লিঙ্ক কোথায় লোড হয় তার উপর আপনি যদি আরও নিয়ন্ত্রণ চান, তাহলে আপনার নিজস্ব WebViewClient
তৈরি করুন যা shouldOverrideUrlLoading()
পদ্ধতিকে ওভাররাইড করে। নিম্নলিখিত উদাহরণটি অনুমান করে যে MyWebViewClient
হল Activity
একটি অভ্যন্তরীণ শ্রেণী।
private class MyWebViewClient : WebViewClient() { override fun shouldOverrideUrlLoading(view: WebView?, url: String?): Boolean { if (Uri.parse(url).host == "www.example.com") { // This is your website, so don't override. Let your WebView load // the page. return false } // Otherwise, the link isn't for a page on your site, so launch another // Activity that handles URLs. Intent(Intent.ACTION_VIEW, Uri.parse(url)).apply { startActivity(this) } return true } }
private class MyWebViewClient extends WebViewClient { @Override public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) { if ("www.example.com".equals(request.getUrl().getHost())) { // This is your website, so don't override. Let your WebView load the // page. return false; } // Otherwise, the link isn't for a page on your site, so launch another // Activity that handles URLs. Intent intent = new Intent(Intent.ACTION_VIEW, request.getUrl()); startActivity(intent); return true; } }
তারপর WebView
জন্য এই নতুন WebViewClient
এর একটি উদাহরণ তৈরি করুন:
val myWebView: WebView = findViewById(R.id.webview) myWebView.webViewClient = MyWebViewClient()
WebView myWebView = (WebView) findViewById(R.id.webview); myWebView.setWebViewClient(new MyWebViewClient());
এখন যখন ব্যবহারকারী একটি লিঙ্কে ট্যাপ করে, সিস্টেমটি shouldOverrideUrlLoading()
পদ্ধতিতে কল করে, যা পূর্ববর্তী উদাহরণে সংজ্ঞায়িত হিসাবে URL হোস্ট একটি নির্দিষ্ট ডোমেনের সাথে মেলে কিনা তা পরীক্ষা করে। যদি এটি মেলে, তাহলে পদ্ধতিটি মিথ্যা ফেরত দেয় এবং URL লোডিং ওভাররাইড করে না। এটি WebView
যথারীতি ইউআরএল লোড করতে দেয়। যদি ইউআরএল হোস্ট মেলে না, তাহলে ইউআরএলগুলি পরিচালনা করার জন্য ডিফল্ট Activity
চালু করার জন্য একটি Intent
তৈরি করা হয়, যা ব্যবহারকারীর ডিফল্ট ওয়েব ব্রাউজারে সমাধান করে।
কাস্টম ইউআরএলগুলি পরিচালনা করুন
রিসোর্স অনুরোধ করার সময় এবং কাস্টম URL স্কিম ব্যবহার করে এমন লিঙ্কগুলির সমাধান করার সময় WebView
বিধিনিষেধ প্রয়োগ করে। উদাহরণস্বরূপ, যদি আপনি shouldOverrideUrlLoading()
বা shouldInterceptRequest()
এর মতো কলব্যাকগুলি প্রয়োগ করেন, তাহলে WebView
শুধুমাত্র বৈধ URL-এর জন্য সেগুলিকে আহ্বান করবে৷
উদাহরণস্বরূপ, WebView
এই ধরনের লিঙ্কগুলির জন্য আপনার shouldOverrideUrlLoading()
পদ্ধতিতে কল নাও করতে পারে:
<a href="showProfile">Show Profile</a>
পূর্ববর্তী উদাহরণে দেখানো একটির মতো অবৈধ URLগুলি, WebView
এ অসঙ্গতভাবে পরিচালনা করা হয়, তাই আমরা পরিবর্তে একটি সুগঠিত URL ব্যবহার করার পরামর্শ দিই৷ আপনার সংস্থা নিয়ন্ত্রণ করে এমন একটি ডোমেনের জন্য আপনি একটি কাস্টম স্কিম বা একটি HTTPS URL ব্যবহার করতে পারেন৷
একটি লিঙ্কে একটি সাধারণ স্ট্রিং ব্যবহার করার পরিবর্তে, আগের উদাহরণের মতো, আপনি নিম্নলিখিতগুলির মতো একটি কাস্টম স্কিম ব্যবহার করতে পারেন:
<a href="example-app:showProfile">Show Profile</a>
তারপর আপনি এইভাবে আপনার shouldOverrideUrlLoading()
পদ্ধতিতে এই URLটি পরিচালনা করতে পারেন:
// The URL scheme must be non-hierarchical, meaning no trailing slashes. const val APP_SCHEME = "example-app:" override fun shouldOverrideUrlLoading(view: WebView?, url: String?): Boolean { return if (url?.startsWith(APP_SCHEME) == true) { urlData = URLDecoder.decode(url.substring(APP_SCHEME.length), "UTF-8") respondToData(urlData) true } else { false } }
// The URL scheme must be non-hierarchical, meaning no trailing slashes. private static final String APP_SCHEME = "example-app:"; @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { if (url.startsWith(APP_SCHEME)) { urlData = URLDecoder.decode(url.substring(APP_SCHEME.length()), "UTF-8"); respondToData(urlData); return true; } return false; }
shouldOverrideUrlLoading()
API প্রাথমিকভাবে নির্দিষ্ট URL-এর জন্য উদ্দেশ্য চালু করার উদ্দেশ্যে তৈরি করা হয়েছে। এটি বাস্তবায়ন করার সময়, WebView
হ্যান্ডেল করা URLগুলির জন্য false
ফেরত নিশ্চিত করুন৷ যদিও আপনি ইন্টেন্ট চালু করার মধ্যে সীমাবদ্ধ নন। আপনি পূর্ববর্তী কোড নমুনাগুলিতে যে কোনো কাস্টম আচরণের সাথে লঞ্চিং ইন্টেন্ট প্রতিস্থাপন করতে পারেন।
ওয়েব পৃষ্ঠার ইতিহাস নেভিগেট করুন
যখন আপনার WebView
ইউআরএল লোডিং ওভাররাইড করে, তখন এটি স্বয়ংক্রিয়ভাবে পরিদর্শন করা ওয়েব পৃষ্ঠাগুলির একটি ইতিহাস জমা করে। আপনি goBack()
এবং goForward()
দিয়ে ইতিহাসের মাধ্যমে পিছনে এবং ফরোয়ার্ড নেভিগেট করতে পারেন।
উদাহরণস্বরূপ, নিম্নলিখিতগুলি দেখায় কিভাবে আপনার Activity
পিছনের দিকে নেভিগেট করতে ডিভাইস ব্যাক বোতাম ব্যবহার করতে পারে:
override fun onKeyDown(keyCode: Int, event: KeyEvent?): Boolean { // Check whether the key event is the Back button and if there's history. if (keyCode == KeyEvent.KEYCODE_BACK && myWebView.canGoBack()) { myWebView.goBack() return true } // If it isn't the Back button or there isn't web page history, bubble up to // the default system behavior. Probably exit the activity. return super.onKeyDown(keyCode, event) }
@Override public boolean onKeyDown(int keyCode, KeyEvent event) { // Check whether the key event is the Back button and if there's history. if ((keyCode == KeyEvent.KEYCODE_BACK) && myWebView.canGoBack()) { myWebView.goBack(); return true; } // If it isn't the Back button or there's no web page history, bubble up to // the default system behavior. Probably exit the activity. return super.onKeyDown(keyCode, event); }
আপনি যদি অ্যাপ্লিকেশান AndroidX AppCompat
1.6.0+ ব্যবহার করেন, তাহলে আপনি আগের স্নিপেটটিকে আরও সহজ করতে পারেন:
onBackPressedDispatcher.addCallback { // Check whether there's history. if (myWebView.canGoBack()) { myWebView.goBack() } }
onBackPressedDispatcher.addCallback { // Check whether there's history. if (myWebView.canGoBack()) { myWebView.goBack(); } }
ব্যবহারকারীর দেখার জন্য ওয়েব পৃষ্ঠার ইতিহাস থাকলে canGoBack()
পদ্ধতিটি সত্য হয়। একইভাবে, আপনি একটি ফরোয়ার্ড ইতিহাস আছে কিনা তা পরীক্ষা করতে canGoForward()
ব্যবহার করতে পারেন। আপনি যদি এই চেকটি না করেন, তাহলে ব্যবহারকারী ইতিহাসের শেষে পৌঁছানোর পরে, goBack()
এবং goForward()
কিছুই করবেন না।
ডিভাইস কনফিগারেশন পরিবর্তন হ্যান্ডেল
রানটাইম চলাকালীন, একটি ডিভাইসের কনফিগারেশন পরিবর্তন হলে কার্যকলাপের অবস্থার পরিবর্তন ঘটে, যেমন ব্যবহারকারীরা যখন ডিভাইসটি ঘোরান বা একটি ইনপুট পদ্ধতি সম্পাদক (IME) খারিজ করেন। এই পরিবর্তনগুলির কারণে একটি WebView
অবজেক্টের কার্যকলাপ ধ্বংস হয়ে যায় এবং একটি নতুন কার্যকলাপ তৈরি করা হয়, যা একটি নতুন WebView
অবজেক্টও তৈরি করে যা ধ্বংস হওয়া বস্তুর URL লোড করে। আপনার কার্যকলাপের ডিফল্ট আচরণ পরিবর্তন করতে, আপনি পরিবর্তন করতে পারেন এটি কীভাবে আপনার ম্যানিফেস্টে orientation
পরিবর্তনগুলি পরিচালনা করে৷ রানটাইম চলাকালীন কনফিগারেশন পরিবর্তনগুলি পরিচালনা করার বিষয়ে আরও জানতে, হ্যান্ডেল কনফিগারেশন পরিবর্তনগুলি পড়ুন।
জানালা পরিচালনা করুন
ডিফল্টরূপে, নতুন উইন্ডো খোলার অনুরোধ উপেক্ষা করা হয়। এটি জাভাস্ক্রিপ্ট দ্বারা বা একটি লিঙ্কে টার্গেট অ্যাট্রিবিউট দ্বারা খোলা হোক না কেন এটি সত্য। আপনি একাধিক উইন্ডো খোলার জন্য আপনার নিজস্ব আচরণ প্রদান করতে আপনার WebChromeClient
কাস্টমাইজ করতে পারেন।
আপনার অ্যাপ্লিকেশানকে আরও সুরক্ষিত রাখতে, পপআপ এবং নতুন উইন্ডোগুলি খোলা থেকে বিরত রাখা ভাল৷ এই আচরণটি বাস্তবায়নের সবচেয়ে নিরাপদ উপায় হল setSupportMultipleWindows()
এ "true"
পাস করা কিন্তু onCreateWindow()
পদ্ধতিকে ওভাররাইড করা নয়, যেটির উপর setSupportMultipleWindows()
নির্ভর করে। এই যুক্তিটি লোড হতে তার লিঙ্কগুলিতে target="_blank"
ব্যবহার করে এমন কোনও পৃষ্ঠাকে বাধা দেয়।