|   |     | 
| (3 intermediate revisions by 2 users not shown) | 
| Line 1: | Line 1: | 
|  | == WebView introduction==
 |  | {{Migrating|https://smartpossdk.gitbook.io/cloudpossdk/faq/firmware/update-pos-webview}} | 
|  | WebView is an important system component on the Android platform that allows Android apps to embed HTML page content and browse websites directly within the app. It uses the Blink rendering engine from Chrome to display webpage content and allows developers to package and distribute webpages as native apps.
 |  | 
|  |   |  | 
|  | The main functions of WebView include:
 |  | 
|  |   |  | 
|  | * Loading and displaying webpage content written in HTML, CSS, and JavaScript within an Android app.
 |  | 
|  | * Supporting common webpage elements and features such as images, videos, audio, tables, forms, etc.
 |  | 
|  | * Providing rich APIs for interactions between JavaScript and Java.
 |  | 
|  | * Caching webpage content and user data to improve access speed and user experience.
 |  | 
|  | WebView has become an essential part of many Android apps, particularly in e-commerce, social networking, news, and other fields.
 |  | 
|  |   |  | 
|  | WebView is often used in Android development to display web content or web applications within an application, mainly for the following reasons:
 |  | 
|  |   |  | 
|  | * Unified interface experience: The web content displayed through WebView can match the UI interface of the native application, improving the user experience.
 |  | 
|  | * Convenient update and maintenance: Unlike native applications that require publishing a new version to update features, web content in WebView can be updated via the server.
 |  | 
|  | * Reuse existing Web technology stack: For companies or individual developers who have invested heavily in frontend resources, they can reuse their existing frontend technology stack to reduce development costs.
 |  | 
|  |   |  | 
|  | In short, WebView can serve as a powerful supplement to native applications under certain scenarios, allowing applications to fully leverage the advantages of Web technologies.
 |  | 
|  |   |  | 
|  | WebView is commonly used in various scenarios in Android development, including:
 |  | 
|  |   |  | 
|  | * In-app browsing: Displaying external website content within an application, providing users with a seamless browsing experience without leaving the application.
 |  | 
|  | * Hybrid apps: Combining native app functionality with web content to create hybrid apps, which can provide better performance than traditional web-based apps while still leveraging the benefits of web technologies.
 |  | 
|  | * Single-page applications (SPA): Building single-page applications within a WebView, allowing for faster loading times and smoother user interactions compared to loading multiple pages.
 |  | 
|  | * Webviews in widgets: Using WebViews to display dynamic content in home screen widgets, such as weather updates or news headlines.
 |  | 
|  | Overall, WebView is a versatile tool that can be utilized in a wide range of use cases in Android development, depending on the specific needs and requirements of each project.
 |  | 
|  |   |  | 
|  | Here is an example code snippet demonstrating how to use a WebView:
 |  | 
|  | <syntaxhighlight lang="java">
 |  | 
|  | // Create a new WebView object
 |  | 
|  | WebView webView = new WebView(this);
 |  | 
|  |   |  | 
|  | // Set the layout parameters for the WebView
 |  | 
|  | webView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
 |  | 
|  |         ViewGroup.LayoutParams.MATCH_PARENT));
 |  | 
|  |   |  | 
|  | // Load the specified URL into the WebView
 |  | 
|  | webView.loadUrl("https://www.example.com");
 |  | 
|  |   |  | 
|  | // Add the WebView to the layout
 |  | 
|  | ((ViewGroup) findViewById(R.id.activity_main)).addView(webView);
 |  | 
|  | </syntaxhighlight>
 |  | 
|  | The above code creates a new WebView object and sets its layout parameters so that it fills the entire screen. We then call the loadUrl() method to load the specified URL into the WebView and add the WebView object to the layout.
 |  | 
|  |   |  | 
|  | Additionally, if you need to handle JavaScript events inside the web page, you can set a WebViewClient and/or a WebChromeClient for the WebView:
 |  | 
|  |   |  | 
|  | <syntaxhighlight lang="java">
 |  | 
|  | webView.setWebViewClient(new WebViewClient() {
 |  | 
|  |     @Override
 |  | 
|  |     public boolean shouldOverrideUrlLoading(WebView view, String url) {
 |  | 
|  |         // Handle URL navigation events here
 |  | 
|  |         return super.shouldOverrideUrlLoading(view, url);
 |  | 
|  |     }
 |  | 
|  | });
 |  | 
|  |   |  | 
|  | webView.setWebChromeClient(new WebChromeClient());
 |  | 
|  | </syntaxhighlight>
 |  | 
|  | In this code, we set a new WebViewClient instance and override the shouldOverrideUrlLoading() method to handle URL navigation events. We also set a new WebChromeClient instance to handle other interactive events inside the web page, such as JavaScript dialog boxes.
 |  | 
|  |   |  | 
|  | Note that these examples demonstrate basic usage of the WebView. Depending on the requirements of your project, you may need to implement additional functionality, such as handling network errors or caching web content.
 |  | 
|  |   |  | 
|  | == Update WebView ==
 |  | 
|  | WebView is a native component provided by the operating system, and upgrading to a higher version requires installation of a WebView signed by the system signature to succeed. Customers may provide their preferred versions( download the latest version of WebView from the Google Developer website (https://developers.google.com/android/guides/webview) ) for review and signing by us, or select from several signed versions offered by us to attempt installation. 
 |  | 
|  |   |  | 
|  | Please note that updating the system WebView involves modifying the device's operating system, which can be risky and void warranties.
 |  | 
|  |   |  | 
|  | Note that the version of the system WebView is dependent on the Android OS version running on POS. Some older devices may not support the latest version of the WebView. 
 |  | 
|  |   |  | 
|  | Another alternative is to use a third-party WebView library, such as Crosswalk, which includes its own version of the WebView component that you can integrate into your application. This way, you can bypass the limitations imposed by the system WebView and have more control over the WebView version used in your app. However, keep in mind that using a third-party library may increase your app size and could potentially introduce stability issues.
 |  | 
|  |   |  | 
|  | == WebView versions in different model==
 |  | 
|  | {| class="wikitable"
 |  | 
|  | |-
 |  | 
|  | ! Model!! Default version
 |  | 
|  | |-
 |  | 
|  | | Q2 Android 6 || 74.0.3729.186
 |  | 
|  | |-
 |  | 
|  | | Q2 Android 7 || 74.0.3729.186
 |  | 
|  | |-
 |  | 
|  | | Q2 Android 12 || 95.0.4638.74
 |  | 
|  | |-
 |  | 
|  | | Q3 Android 7||74.0.3729.186
 |  | 
|  | |}
 |  | 
|  |   |  | 
|  | == Avaliable WebView versions ==
 |  | 
|  |   |  | 
|  | {| class="wikitable"
 |  | 
|  | |-
 |  | 
|  | ! Download URL!! Version!!Android requirement
 |  | 
|  | |-
 |  | 
|  | | [http://ftp.wizarpos.com/advanceSDK/com.android.webview_102.0.5005.96-q2_releasekey.apk WebView version 102 download] || 102.0.5005.96 || Android version < 12
 |  | 
|  | |-
 |  | 
|  | | [http://ftp.wizarpos.com/advanceSDK/com.android.webview_106.0.5249.126-q1_re....apk WebView version 106 download] || 106.0.5249.126 || None
 |  | 
|  | |-
 |  | 
|  | | [http://ftp.wizarpos.com/advanceSDK/com.android.webview_119.0.6045.134-60451...-q1_releasekey.apk WebView version 119 download] || 119.0.6045.134 || Android version >= 7
 |  | 
|  | |}
 |  |