1 /* 2 * Copyright (C) 2007 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.webkit; 18 19 import android.annotation.IntDef; 20 import android.annotation.Nullable; 21 import android.annotation.SystemApi; 22 import android.compat.annotation.ChangeId; 23 import android.compat.annotation.EnabledSince; 24 import android.compat.annotation.UnsupportedAppUsage; 25 import android.content.Context; 26 27 import java.lang.annotation.ElementType; 28 import java.lang.annotation.Retention; 29 import java.lang.annotation.RetentionPolicy; 30 import java.lang.annotation.Target; 31 32 /** 33 * Manages settings state for a WebView. When a WebView is first created, it 34 * obtains a set of default settings. These default settings will be returned 35 * from any getter call. A {@code WebSettings} object obtained from 36 * {@link WebView#getSettings()} is tied to the life of the WebView. If a WebView has 37 * been destroyed, any method call on {@code WebSettings} will throw an 38 * {@link IllegalStateException}. 39 */ 40 // This is an abstract base class: concrete WebViewProviders must 41 // create a class derived from this, and return an instance of it in the 42 // WebViewProvider.getWebSettingsProvider() method implementation. 43 public abstract class WebSettings { 44 /** 45 * Enum for controlling the layout of html. 46 * <ul> 47 * <li>{@code NORMAL} means no rendering changes. This is the recommended choice for maximum 48 * compatibility across different platforms and Android versions.</li> 49 * <li>{@code SINGLE_COLUMN} moves all content into one column that is the width of the 50 * view.</li> 51 * <li>{@code NARROW_COLUMNS} makes all columns no wider than the screen if possible. Only use 52 * this for API levels prior to {@link android.os.Build.VERSION_CODES#KITKAT}.</li> 53 * <li>{@code TEXT_AUTOSIZING} boosts font size of paragraphs based on heuristics to make 54 * the text readable when viewing a wide-viewport layout in the overview mode. 55 * It is recommended to enable zoom support {@link #setSupportZoom} when 56 * using this mode. Supported from API level 57 * {@link android.os.Build.VERSION_CODES#KITKAT}</li> 58 * </ul> 59 */ 60 // XXX: These must match LayoutAlgorithm in Settings.h in WebCore. 61 public enum LayoutAlgorithm { 62 NORMAL, 63 /** 64 * @deprecated This algorithm is now obsolete. 65 */ 66 @Deprecated 67 SINGLE_COLUMN, 68 /** 69 * @deprecated This algorithm is now obsolete. 70 */ 71 @Deprecated 72 NARROW_COLUMNS, 73 TEXT_AUTOSIZING 74 } 75 76 /** 77 * Enum for specifying the text size. 78 * <ul> 79 * <li>SMALLEST is 50%</li> 80 * <li>SMALLER is 75%</li> 81 * <li>NORMAL is 100%</li> 82 * <li>LARGER is 150%</li> 83 * <li>LARGEST is 200%</li> 84 * </ul> 85 * 86 * @deprecated Use {@link WebSettings#setTextZoom(int)} and {@link WebSettings#getTextZoom()} instead. 87 */ 88 @Deprecated 89 public enum TextSize { 90 SMALLEST(50), 91 SMALLER(75), 92 NORMAL(100), 93 LARGER(150), 94 LARGEST(200); TextSize(int size)95 TextSize(int size) { 96 value = size; 97 } 98 @UnsupportedAppUsage 99 int value; 100 } 101 102 /** 103 * Enum for specifying the WebView's desired density. 104 * <ul> 105 * <li>{@code FAR} makes 100% looking like in 240dpi</li> 106 * <li>{@code MEDIUM} makes 100% looking like in 160dpi</li> 107 * <li>{@code CLOSE} makes 100% looking like in 120dpi</li> 108 * </ul> 109 */ 110 public enum ZoomDensity { 111 FAR(150), // 240dpi 112 MEDIUM(100), // 160dpi 113 CLOSE(75); // 120dpi ZoomDensity(int size)114 ZoomDensity(int size) { 115 value = size; 116 } 117 118 /** 119 * @hide Only for use by WebViewProvider implementations 120 */ getValue()121 public int getValue() { 122 return value; 123 } 124 125 int value; 126 } 127 128 /** @hide */ 129 @IntDef(prefix = { "LOAD_" }, value = { 130 LOAD_DEFAULT, 131 LOAD_NORMAL, 132 LOAD_CACHE_ELSE_NETWORK, 133 LOAD_NO_CACHE, 134 LOAD_CACHE_ONLY 135 }) 136 @Retention(RetentionPolicy.SOURCE) 137 public @interface CacheMode {} 138 139 /** 140 * Enable web content to apply light or dark style according to the app's theme 141 * and WebView to attempt to darken web content by algorithmic darkening when 142 * appropriate. 143 * 144 * Refer to {@link #setAlgorithmicDarkeningAllowed} for detail. 145 * 146 * @hide 147 */ 148 @ChangeId 149 @EnabledSince(targetSdkVersion = android.os.Build.VERSION_CODES.TIRAMISU) 150 @SystemApi 151 public static final long ENABLE_SIMPLIFIED_DARK_MODE = 214741472L; 152 153 /** 154 * Default cache usage mode. If the navigation type doesn't impose any 155 * specific behavior, use cached resources when they are available 156 * and not expired, otherwise load resources from the network. 157 * Use with {@link #setCacheMode}. 158 */ 159 public static final int LOAD_DEFAULT = -1; 160 161 /** 162 * Normal cache usage mode. Use with {@link #setCacheMode}. 163 * 164 * @deprecated This value is obsolete, as from API level 165 * {@link android.os.Build.VERSION_CODES#HONEYCOMB} and onwards it has the 166 * same effect as {@link #LOAD_DEFAULT}. 167 */ 168 @Deprecated 169 public static final int LOAD_NORMAL = 0; 170 171 /** 172 * Use cached resources when they are available, even if they have expired. 173 * Otherwise load resources from the network. 174 * Use with {@link #setCacheMode}. 175 */ 176 public static final int LOAD_CACHE_ELSE_NETWORK = 1; 177 178 /** 179 * Don't use the cache, load from the network. 180 * Use with {@link #setCacheMode}. 181 */ 182 public static final int LOAD_NO_CACHE = 2; 183 184 /** 185 * Don't use the network, load from the cache. 186 * Use with {@link #setCacheMode}. 187 */ 188 public static final int LOAD_CACHE_ONLY = 3; 189 190 public enum RenderPriority { 191 NORMAL, 192 HIGH, 193 LOW 194 } 195 196 /** 197 * The plugin state effects how plugins are treated on a page. ON means 198 * that any object will be loaded even if a plugin does not exist to handle 199 * the content. ON_DEMAND means that if there is a plugin installed that 200 * can handle the content, a placeholder is shown until the user clicks on 201 * the placeholder. Once clicked, the plugin will be enabled on the page. 202 * OFF means that all plugins will be turned off and any fallback content 203 * will be used. 204 */ 205 public enum PluginState { 206 ON, 207 ON_DEMAND, 208 OFF 209 } 210 211 /** 212 * In this mode, the WebView will allow a secure origin to load content from any other origin, 213 * even if that origin is insecure. This is the least secure mode of operation for the WebView, 214 * and where possible apps should not set this mode. 215 * 216 * @see #setMixedContentMode 217 */ 218 public static final int MIXED_CONTENT_ALWAYS_ALLOW = 0; 219 220 /** 221 * In this mode, the WebView will not allow a secure origin to load content from an insecure 222 * origin. This is the preferred and most secure mode of operation for the WebView and apps are 223 * strongly advised to use this mode. 224 * 225 * @see #setMixedContentMode 226 */ 227 public static final int MIXED_CONTENT_NEVER_ALLOW = 1; 228 229 /** 230 * In this mode, the WebView will attempt to be compatible with the approach of a modern web 231 * browser with regard to mixed content. Some insecure content may be allowed to be loaded by 232 * a secure origin and other types of content will be blocked. The types of content are allowed 233 * or blocked may change release to release and are not explicitly defined. 234 * 235 * This mode is intended to be used by apps that are not in control of the content that they 236 * render but desire to operate in a reasonably secure environment. For highest security, apps 237 * are recommended to use {@link #MIXED_CONTENT_NEVER_ALLOW}. 238 * 239 * @see #setMixedContentMode 240 */ 241 public static final int MIXED_CONTENT_COMPATIBILITY_MODE = 2; 242 243 /** @hide */ 244 @IntDef(prefix = { "FORCE_DARK_" }, value = { 245 FORCE_DARK_OFF, 246 FORCE_DARK_AUTO, 247 FORCE_DARK_ON 248 }) 249 @Retention(RetentionPolicy.SOURCE) 250 public @interface ForceDark {} 251 252 /** 253 * Disable force dark, irrespective of the force dark mode of the WebView parent. In this mode, 254 * WebView content will always be rendered as-is, regardless of whether native views are being 255 * automatically darkened. 256 * 257 * @see #setForceDark 258 * @deprecated refer to {@link #setForceDark} 259 */ 260 public static final int FORCE_DARK_OFF = 0; 261 262 /** 263 * Enable force dark dependent on the state of the WebView parent view. If the WebView parent 264 * view is being automatically force darkened 265 * (see: {@link android.view.View#setForceDarkAllowed}), then WebView content will be rendered 266 * so as to emulate a dark theme. WebViews that are not attached to the view hierarchy will not 267 * be inverted. 268 * 269 * @see #setForceDark 270 * @deprecated refer to {@link #setForceDark} 271 */ 272 public static final int FORCE_DARK_AUTO = 1; 273 274 /** 275 * Unconditionally enable force dark. In this mode WebView content will always be rendered so 276 * as to emulate a dark theme. 277 * 278 * @see #setForceDark 279 * @deprecated refer to {@link #setForceDark} 280 */ 281 public static final int FORCE_DARK_ON = 2; 282 283 /** 284 * Enables dumping the pages navigation cache to a text file. The default 285 * is {@code false}. 286 * 287 * @deprecated This method is now obsolete. 288 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 289 */ 290 @SuppressWarnings("HiddenAbstractMethod") 291 @SystemApi 292 @Deprecated setNavDump(boolean enabled)293 public abstract void setNavDump(boolean enabled); 294 295 /** 296 * Gets whether dumping the navigation cache is enabled. 297 * 298 * @return whether dumping the navigation cache is enabled 299 * @see #setNavDump 300 * @deprecated This method is now obsolete. 301 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 302 */ 303 @SuppressWarnings("HiddenAbstractMethod") 304 @SystemApi 305 @Deprecated getNavDump()306 public abstract boolean getNavDump(); 307 308 /** 309 * Sets whether the WebView should support zooming using its on-screen zoom 310 * controls and gestures. The particular zoom mechanisms that should be used 311 * can be set with {@link #setBuiltInZoomControls}. This setting does not 312 * affect zooming performed using the {@link WebView#zoomIn()} and 313 * {@link WebView#zoomOut()} methods. The default is {@code true}. 314 * 315 * @param support whether the WebView should support zoom 316 */ setSupportZoom(boolean support)317 public abstract void setSupportZoom(boolean support); 318 319 /** 320 * Gets whether the WebView supports zoom. 321 * 322 * @return {@code true} if the WebView supports zoom 323 * @see #setSupportZoom 324 */ supportZoom()325 public abstract boolean supportZoom(); 326 327 /** 328 * Sets whether the WebView requires a user gesture to play media. 329 * The default is {@code true}. 330 * 331 * @param require whether the WebView requires a user gesture to play media 332 */ setMediaPlaybackRequiresUserGesture(boolean require)333 public abstract void setMediaPlaybackRequiresUserGesture(boolean require); 334 335 /** 336 * Gets whether the WebView requires a user gesture to play media. 337 * 338 * @return {@code true} if the WebView requires a user gesture to play media 339 * @see #setMediaPlaybackRequiresUserGesture 340 */ getMediaPlaybackRequiresUserGesture()341 public abstract boolean getMediaPlaybackRequiresUserGesture(); 342 343 /** 344 * Sets whether the WebView should use its built-in zoom mechanisms. The 345 * built-in zoom mechanisms comprise on-screen zoom controls, which are 346 * displayed over the WebView's content, and the use of a pinch gesture to 347 * control zooming. Whether or not these on-screen controls are displayed 348 * can be set with {@link #setDisplayZoomControls}. The default is {@code false}. 349 * <p> 350 * The built-in mechanisms are the only currently supported zoom 351 * mechanisms, so it is recommended that this setting is always enabled. 352 * However, on-screen zoom controls are deprecated in Android (see 353 * {@link android.widget.ZoomButtonsController}) so it's recommended to 354 * disable {@link #setDisplayZoomControls}. 355 * 356 * @param enabled whether the WebView should use its built-in zoom mechanisms 357 */ 358 // This method was intended to select between the built-in zoom mechanisms 359 // and the separate zoom controls. The latter were obtained using 360 // {@link WebView#getZoomControls}, which is now hidden. setBuiltInZoomControls(boolean enabled)361 public abstract void setBuiltInZoomControls(boolean enabled); 362 363 /** 364 * Gets whether the zoom mechanisms built into WebView are being used. 365 * 366 * @return {@code true} if the zoom mechanisms built into WebView are being used 367 * @see #setBuiltInZoomControls 368 */ getBuiltInZoomControls()369 public abstract boolean getBuiltInZoomControls(); 370 371 /** 372 * Sets whether the WebView should display on-screen zoom controls when 373 * using the built-in zoom mechanisms. See {@link #setBuiltInZoomControls}. 374 * The default is {@code true}. However, on-screen zoom controls are deprecated 375 * in Android (see {@link android.widget.ZoomButtonsController}) so it's 376 * recommended to set this to {@code false}. 377 * 378 * @param enabled whether the WebView should display on-screen zoom controls 379 */ setDisplayZoomControls(boolean enabled)380 public abstract void setDisplayZoomControls(boolean enabled); 381 382 /** 383 * Gets whether the WebView displays on-screen zoom controls when using 384 * the built-in zoom mechanisms. 385 * 386 * @return {@code true} if the WebView displays on-screen zoom controls when using 387 * the built-in zoom mechanisms 388 * @see #setDisplayZoomControls 389 */ getDisplayZoomControls()390 public abstract boolean getDisplayZoomControls(); 391 392 /** 393 * Enables or disables file access within WebView. 394 * Note that this enables or disables file system access only. Assets and resources 395 * are still accessible using file:///android_asset and file:///android_res. 396 * <p class="note"> 397 * <b>Note:</b> Apps should not open {@code file://} URLs from any external source in 398 * WebView, don't enable this if your app accepts arbitrary URLs from external sources. 399 * It's recommended to always use 400 * <a href="{@docRoot}reference/androidx/webkit/WebViewAssetLoader"> 401 * androidx.webkit.WebViewAssetLoader</a> to access files including assets and resources over 402 * {@code http(s)://} schemes, instead of {@code file://} URLs. To prevent possible security 403 * issues targeting {@link android.os.Build.VERSION_CODES#Q} and earlier, you should explicitly 404 * set this value to {@code false}. 405 * <p> 406 * The default value is {@code true} for apps targeting 407 * {@link android.os.Build.VERSION_CODES#Q} and below, and {@code false} when targeting 408 * {@link android.os.Build.VERSION_CODES#R} and above. 409 */ setAllowFileAccess(boolean allow)410 public abstract void setAllowFileAccess(boolean allow); 411 412 /** 413 * Gets whether this WebView supports file access. 414 * 415 * @see #setAllowFileAccess 416 */ getAllowFileAccess()417 public abstract boolean getAllowFileAccess(); 418 419 /** 420 * Enables or disables content URL access within WebView. Content URL 421 * access allows WebView to load content from a content provider installed 422 * in the system. The default is enabled. 423 */ setAllowContentAccess(boolean allow)424 public abstract void setAllowContentAccess(boolean allow); 425 426 /** 427 * Gets whether this WebView supports content URL access. 428 * 429 * @see #setAllowContentAccess 430 */ getAllowContentAccess()431 public abstract boolean getAllowContentAccess(); 432 433 /** 434 * Sets whether the WebView loads pages in overview mode, that is, 435 * zooms out the content to fit on screen by width. This setting is 436 * taken into account when the content width is greater than the width 437 * of the WebView control, for example, when {@link #getUseWideViewPort} 438 * is enabled. The default is {@code false}. 439 */ setLoadWithOverviewMode(boolean overview)440 public abstract void setLoadWithOverviewMode(boolean overview); 441 442 /** 443 * Gets whether this WebView loads pages in overview mode. 444 * 445 * @return whether this WebView loads pages in overview mode 446 * @see #setLoadWithOverviewMode 447 */ getLoadWithOverviewMode()448 public abstract boolean getLoadWithOverviewMode(); 449 450 /** 451 * Sets whether the WebView will enable smooth transition while panning or 452 * zooming or while the window hosting the WebView does not have focus. 453 * If it is {@code true}, WebView will choose a solution to maximize the performance. 454 * e.g. the WebView's content may not be updated during the transition. 455 * If it is false, WebView will keep its fidelity. The default value is {@code false}. 456 * 457 * @deprecated This method is now obsolete, and will become a no-op in future. 458 */ 459 @Deprecated setEnableSmoothTransition(boolean enable)460 public abstract void setEnableSmoothTransition(boolean enable); 461 462 /** 463 * Gets whether the WebView enables smooth transition while panning or 464 * zooming. 465 * 466 * @see #setEnableSmoothTransition 467 * 468 * @deprecated This method is now obsolete, and will become a no-op in future. 469 */ 470 @Deprecated enableSmoothTransition()471 public abstract boolean enableSmoothTransition(); 472 473 /** 474 * Sets whether the WebView uses its background for over scroll background. 475 * If {@code true}, it will use the WebView's background. If {@code false}, it will use an 476 * internal pattern. Default is {@code true}. 477 * 478 * @deprecated This method is now obsolete. 479 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 480 */ 481 @SuppressWarnings("HiddenAbstractMethod") 482 @SystemApi 483 @Deprecated setUseWebViewBackgroundForOverscrollBackground(boolean view)484 public abstract void setUseWebViewBackgroundForOverscrollBackground(boolean view); 485 486 /** 487 * Gets whether this WebView uses WebView's background instead of 488 * internal pattern for over scroll background. 489 * 490 * @see #setUseWebViewBackgroundForOverscrollBackground 491 * @deprecated This method is now obsolete. 492 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 493 */ 494 @SuppressWarnings("HiddenAbstractMethod") 495 @SystemApi 496 @Deprecated getUseWebViewBackgroundForOverscrollBackground()497 public abstract boolean getUseWebViewBackgroundForOverscrollBackground(); 498 499 /** 500 * Sets whether the WebView should save form data. In Android O, the 501 * platform has implemented a fully functional Autofill feature to store 502 * form data. Therefore, the Webview form data save feature is disabled. 503 * 504 * Note that the feature will continue to be supported on older versions of 505 * Android as before. 506 * 507 * @deprecated In Android O and afterwards, this function does not have 508 * any effect, the form data will be saved to platform's autofill service 509 * if applicable. 510 */ 511 @Deprecated setSaveFormData(boolean save)512 public abstract void setSaveFormData(boolean save); 513 514 /** 515 * Gets whether the WebView saves form data. 516 * 517 * @return whether the WebView saves form data 518 * @see #setSaveFormData 519 */ 520 @Deprecated getSaveFormData()521 public abstract boolean getSaveFormData(); 522 523 /** 524 * Sets whether the WebView should save passwords. The default is {@code true}. 525 * @deprecated Saving passwords in WebView will not be supported in future versions. 526 */ 527 @Deprecated setSavePassword(boolean save)528 public abstract void setSavePassword(boolean save); 529 530 /** 531 * Gets whether the WebView saves passwords. 532 * 533 * @return whether the WebView saves passwords 534 * @see #setSavePassword 535 * @deprecated Saving passwords in WebView will not be supported in future versions. 536 */ 537 @Deprecated getSavePassword()538 public abstract boolean getSavePassword(); 539 540 /** 541 * Sets the text zoom of the page in percent. The default is 100. 542 * 543 * @param textZoom the text zoom in percent 544 */ setTextZoom(int textZoom)545 public abstract void setTextZoom(int textZoom); 546 547 /** 548 * Gets the text zoom of the page in percent. 549 * 550 * @return the text zoom of the page in percent 551 * @see #setTextZoom 552 */ getTextZoom()553 public abstract int getTextZoom(); 554 555 /** 556 * Sets policy for third party cookies. 557 * Developers should access this via {@link CookieManager#setShouldAcceptThirdPartyCookies}. 558 * @hide Internal API. 559 */ 560 @SuppressWarnings("HiddenAbstractMethod") 561 @SystemApi setAcceptThirdPartyCookies(boolean accept)562 public abstract void setAcceptThirdPartyCookies(boolean accept); 563 564 /** 565 * Gets policy for third party cookies. 566 * Developers should access this via {@link CookieManager#getShouldAcceptThirdPartyCookies}. 567 * @hide Internal API 568 */ 569 @SuppressWarnings("HiddenAbstractMethod") 570 @SystemApi getAcceptThirdPartyCookies()571 public abstract boolean getAcceptThirdPartyCookies(); 572 573 /** 574 * Sets the text size of the page. The default is {@link TextSize#NORMAL}. 575 * 576 * @param t the text size as a {@link TextSize} value 577 * @deprecated Use {@link #setTextZoom} instead. 578 */ 579 @Deprecated setTextSize(TextSize t)580 public synchronized void setTextSize(TextSize t) { 581 setTextZoom(t.value); 582 } 583 584 /** 585 * Gets the text size of the page. If the text size was previously specified 586 * in percent using {@link #setTextZoom}, this will return the closest 587 * matching {@link TextSize}. 588 * 589 * @return the text size as a {@link TextSize} value 590 * @see #setTextSize 591 * @deprecated Use {@link #getTextZoom} instead. 592 */ 593 @Deprecated getTextSize()594 public synchronized TextSize getTextSize() { 595 TextSize closestSize = null; 596 int smallestDelta = Integer.MAX_VALUE; 597 int textSize = getTextZoom(); 598 for (TextSize size : TextSize.values()) { 599 int delta = Math.abs(textSize - size.value); 600 if (delta == 0) { 601 return size; 602 } 603 if (delta < smallestDelta) { 604 smallestDelta = delta; 605 closestSize = size; 606 } 607 } 608 return closestSize != null ? closestSize : TextSize.NORMAL; 609 } 610 611 /** 612 * Sets the default zoom density of the page. This must be called from the UI 613 * thread. The default is {@link ZoomDensity#MEDIUM}. 614 * 615 * This setting is not recommended for use in new applications. If the WebView 616 * is utilized to display mobile-oriented pages, the desired effect can be achieved by 617 * adjusting 'width' and 'initial-scale' attributes of page's 'meta viewport' 618 * tag. For pages lacking the tag, {@link android.webkit.WebView#setInitialScale} 619 * and {@link #setUseWideViewPort} can be used. 620 * 621 * @param zoom the zoom density 622 * @deprecated This method is no longer supported, see the function documentation for 623 * recommended alternatives. 624 */ 625 @Deprecated setDefaultZoom(ZoomDensity zoom)626 public abstract void setDefaultZoom(ZoomDensity zoom); 627 628 /** 629 * Gets the default zoom density of the page. This should be called from 630 * the UI thread. 631 * 632 * This setting is not recommended for use in new applications. 633 * 634 * @return the zoom density 635 * @see #setDefaultZoom 636 * @deprecated Will only return the default value. 637 */ 638 @Deprecated getDefaultZoom()639 public abstract ZoomDensity getDefaultZoom(); 640 641 /** 642 * Enables using light touches to make a selection and activate mouseovers. 643 * @deprecated From {@link android.os.Build.VERSION_CODES#JELLY_BEAN} this 644 * setting is obsolete and has no effect. 645 */ 646 @Deprecated setLightTouchEnabled(boolean enabled)647 public abstract void setLightTouchEnabled(boolean enabled); 648 649 /** 650 * Gets whether light touches are enabled. 651 * @see #setLightTouchEnabled 652 * @deprecated This setting is obsolete. 653 */ 654 @Deprecated getLightTouchEnabled()655 public abstract boolean getLightTouchEnabled(); 656 657 /** 658 * Controlled a rendering optimization that is no longer present. Setting 659 * it now has no effect. 660 * 661 * @deprecated This setting now has no effect. 662 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 663 */ 664 @Deprecated 665 @UnsupportedAppUsage setUseDoubleTree(boolean use)666 public void setUseDoubleTree(boolean use) { 667 // Specified to do nothing, so no need for derived classes to override. 668 } 669 670 /** 671 * Controlled a rendering optimization that is no longer present. Setting 672 * it now has no effect. 673 * 674 * @deprecated This setting now has no effect. 675 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 676 */ 677 @Deprecated 678 @UnsupportedAppUsage getUseDoubleTree()679 public boolean getUseDoubleTree() { 680 // Returns false unconditionally, so no need for derived classes to override. 681 return false; 682 } 683 684 /** 685 * Sets the user-agent string using an integer code. 686 * <ul> 687 * <li>0 means the WebView should use an Android user-agent string</li> 688 * <li>1 means the WebView should use a desktop user-agent string</li> 689 * </ul> 690 * Other values are ignored. The default is an Android user-agent string, 691 * i.e. code value 0. 692 * 693 * @param ua the integer code for the user-agent string 694 * @deprecated Please use {@link #setUserAgentString} instead. 695 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 696 */ 697 @SuppressWarnings("HiddenAbstractMethod") 698 @SystemApi 699 @Deprecated setUserAgent(int ua)700 public abstract void setUserAgent(int ua); 701 702 /** 703 * Gets the user-agent as an integer code. 704 * <ul> 705 * <li>-1 means the WebView is using a custom user-agent string set with 706 * {@link #setUserAgentString}</li> 707 * <li>0 means the WebView should use an Android user-agent string</li> 708 * <li>1 means the WebView should use a desktop user-agent string</li> 709 * </ul> 710 * 711 * @return the integer code for the user-agent string 712 * @see #setUserAgent 713 * @deprecated Please use {@link #getUserAgentString} instead. 714 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR1} 715 */ 716 @SuppressWarnings("HiddenAbstractMethod") 717 @SystemApi 718 @Deprecated getUserAgent()719 public abstract int getUserAgent(); 720 721 /** 722 * Sets whether the WebView should enable support for the "viewport" 723 * HTML meta tag or should use a wide viewport. 724 * When the value of the setting is {@code false}, the layout width is always set to the 725 * width of the WebView control in device-independent (CSS) pixels. 726 * When the value is {@code true} and the page contains the viewport meta tag, the value 727 * of the width specified in the tag is used. If the page does not contain the tag or 728 * does not provide a width, then a wide viewport will be used. 729 * 730 * @param use whether to enable support for the viewport meta tag 731 */ setUseWideViewPort(boolean use)732 public abstract void setUseWideViewPort(boolean use); 733 734 /** 735 * Gets whether the WebView supports the "viewport" 736 * HTML meta tag or will use a wide viewport. 737 * 738 * @return {@code true} if the WebView supports the viewport meta tag 739 * @see #setUseWideViewPort 740 */ getUseWideViewPort()741 public abstract boolean getUseWideViewPort(); 742 743 /** 744 * Sets whether the WebView whether supports multiple windows. If set to 745 * true, {@link WebChromeClient#onCreateWindow} must be implemented by the 746 * host application. The default is {@code false}. 747 * 748 * @param support whether to support multiple windows 749 */ setSupportMultipleWindows(boolean support)750 public abstract void setSupportMultipleWindows(boolean support); 751 752 /** 753 * Gets whether the WebView supports multiple windows. 754 * 755 * @return {@code true} if the WebView supports multiple windows 756 * @see #setSupportMultipleWindows 757 */ supportMultipleWindows()758 public abstract boolean supportMultipleWindows(); 759 760 /** 761 * Sets the underlying layout algorithm. This will cause a re-layout of the 762 * WebView. The default is {@link LayoutAlgorithm#NARROW_COLUMNS}. 763 * 764 * @param l the layout algorithm to use, as a {@link LayoutAlgorithm} value 765 */ setLayoutAlgorithm(LayoutAlgorithm l)766 public abstract void setLayoutAlgorithm(LayoutAlgorithm l); 767 768 /** 769 * Gets the current layout algorithm. 770 * 771 * @return the layout algorithm in use, as a {@link LayoutAlgorithm} value 772 * @see #setLayoutAlgorithm 773 */ getLayoutAlgorithm()774 public abstract LayoutAlgorithm getLayoutAlgorithm(); 775 776 /** 777 * Sets the standard font family name. The default is "sans-serif". 778 * 779 * @param font a font family name 780 */ setStandardFontFamily(String font)781 public abstract void setStandardFontFamily(String font); 782 783 /** 784 * Gets the standard font family name. 785 * 786 * @return the standard font family name as a string 787 * @see #setStandardFontFamily 788 */ getStandardFontFamily()789 public abstract String getStandardFontFamily(); 790 791 /** 792 * Sets the fixed font family name. The default is "monospace". 793 * 794 * @param font a font family name 795 */ setFixedFontFamily(String font)796 public abstract void setFixedFontFamily(String font); 797 798 /** 799 * Gets the fixed font family name. 800 * 801 * @return the fixed font family name as a string 802 * @see #setFixedFontFamily 803 */ getFixedFontFamily()804 public abstract String getFixedFontFamily(); 805 806 /** 807 * Sets the sans-serif font family name. The default is "sans-serif". 808 * 809 * @param font a font family name 810 */ setSansSerifFontFamily(String font)811 public abstract void setSansSerifFontFamily(String font); 812 813 /** 814 * Gets the sans-serif font family name. 815 * 816 * @return the sans-serif font family name as a string 817 * @see #setSansSerifFontFamily 818 */ getSansSerifFontFamily()819 public abstract String getSansSerifFontFamily(); 820 821 /** 822 * Sets the serif font family name. The default is "sans-serif". 823 * 824 * @param font a font family name 825 */ setSerifFontFamily(String font)826 public abstract void setSerifFontFamily(String font); 827 828 /** 829 * Gets the serif font family name. The default is "serif". 830 * 831 * @return the serif font family name as a string 832 * @see #setSerifFontFamily 833 */ getSerifFontFamily()834 public abstract String getSerifFontFamily(); 835 836 /** 837 * Sets the cursive font family name. The default is "cursive". 838 * 839 * @param font a font family name 840 */ setCursiveFontFamily(String font)841 public abstract void setCursiveFontFamily(String font); 842 843 /** 844 * Gets the cursive font family name. 845 * 846 * @return the cursive font family name as a string 847 * @see #setCursiveFontFamily 848 */ getCursiveFontFamily()849 public abstract String getCursiveFontFamily(); 850 851 /** 852 * Sets the fantasy font family name. The default is "fantasy". 853 * 854 * @param font a font family name 855 */ setFantasyFontFamily(String font)856 public abstract void setFantasyFontFamily(String font); 857 858 /** 859 * Gets the fantasy font family name. 860 * 861 * @return the fantasy font family name as a string 862 * @see #setFantasyFontFamily 863 */ getFantasyFontFamily()864 public abstract String getFantasyFontFamily(); 865 866 /** 867 * Sets the minimum font size. The default is 8. 868 * 869 * @param size a non-negative integer between 1 and 72. Any number outside 870 * the specified range will be pinned. 871 */ setMinimumFontSize(int size)872 public abstract void setMinimumFontSize(int size); 873 874 /** 875 * Gets the minimum font size. 876 * 877 * @return a non-negative integer between 1 and 72 878 * @see #setMinimumFontSize 879 */ getMinimumFontSize()880 public abstract int getMinimumFontSize(); 881 882 /** 883 * Sets the minimum logical font size. The default is 8. 884 * 885 * @param size a non-negative integer between 1 and 72. Any number outside 886 * the specified range will be pinned. 887 */ setMinimumLogicalFontSize(int size)888 public abstract void setMinimumLogicalFontSize(int size); 889 890 /** 891 * Gets the minimum logical font size. 892 * 893 * @return a non-negative integer between 1 and 72 894 * @see #setMinimumLogicalFontSize 895 */ getMinimumLogicalFontSize()896 public abstract int getMinimumLogicalFontSize(); 897 898 /** 899 * Sets the default font size. The default is 16. 900 * 901 * @param size a non-negative integer between 1 and 72. Any number outside 902 * the specified range will be pinned. 903 */ setDefaultFontSize(int size)904 public abstract void setDefaultFontSize(int size); 905 906 /** 907 * Gets the default font size. 908 * 909 * @return a non-negative integer between 1 and 72 910 * @see #setDefaultFontSize 911 */ getDefaultFontSize()912 public abstract int getDefaultFontSize(); 913 914 /** 915 * Sets the default fixed font size. The default is 16. 916 * 917 * @param size a non-negative integer between 1 and 72. Any number outside 918 * the specified range will be pinned. 919 */ setDefaultFixedFontSize(int size)920 public abstract void setDefaultFixedFontSize(int size); 921 922 /** 923 * Gets the default fixed font size. 924 * 925 * @return a non-negative integer between 1 and 72 926 * @see #setDefaultFixedFontSize 927 */ getDefaultFixedFontSize()928 public abstract int getDefaultFixedFontSize(); 929 930 /** 931 * Sets whether the WebView should load image resources. Note that this method 932 * controls loading of all images, including those embedded using the data 933 * URI scheme. Use {@link #setBlockNetworkImage} to control loading only 934 * of images specified using network URI schemes. Note that if the value of this 935 * setting is changed from {@code false} to {@code true}, all images resources referenced 936 * by content currently displayed by the WebView are loaded automatically. 937 * The default is {@code true}. 938 * 939 * @param flag whether the WebView should load image resources 940 */ setLoadsImagesAutomatically(boolean flag)941 public abstract void setLoadsImagesAutomatically(boolean flag); 942 943 /** 944 * Gets whether the WebView loads image resources. This includes 945 * images embedded using the data URI scheme. 946 * 947 * @return {@code true} if the WebView loads image resources 948 * @see #setLoadsImagesAutomatically 949 */ getLoadsImagesAutomatically()950 public abstract boolean getLoadsImagesAutomatically(); 951 952 /** 953 * Sets whether the WebView should not load image resources from the 954 * network (resources accessed via http and https URI schemes). Note 955 * that this method has no effect unless 956 * {@link #getLoadsImagesAutomatically} returns {@code true}. Also note that 957 * disabling all network loads using {@link #setBlockNetworkLoads} 958 * will also prevent network images from loading, even if this flag is set 959 * to false. When the value of this setting is changed from {@code true} to {@code false}, 960 * network images resources referenced by content currently displayed by 961 * the WebView are fetched automatically. The default is {@code false}. 962 * 963 * @param flag whether the WebView should not load image resources from the 964 * network 965 * @see #setBlockNetworkLoads 966 */ setBlockNetworkImage(boolean flag)967 public abstract void setBlockNetworkImage(boolean flag); 968 969 /** 970 * Gets whether the WebView does not load image resources from the network. 971 * 972 * @return {@code true} if the WebView does not load image resources from the network 973 * @see #setBlockNetworkImage 974 */ getBlockNetworkImage()975 public abstract boolean getBlockNetworkImage(); 976 977 /** 978 * Sets whether the WebView should not load resources from the network. 979 * Use {@link #setBlockNetworkImage} to only avoid loading 980 * image resources. Note that if the value of this setting is 981 * changed from {@code true} to {@code false}, network resources referenced by content 982 * currently displayed by the WebView are not fetched until 983 * {@link android.webkit.WebView#reload} is called. 984 * If the application does not have the 985 * {@link android.Manifest.permission#INTERNET} permission, attempts to set 986 * a value of {@code false} will cause a {@link java.lang.SecurityException} 987 * to be thrown. The default value is {@code false} if the application has the 988 * {@link android.Manifest.permission#INTERNET} permission, otherwise it is 989 * {@code true}. 990 * 991 * @param flag {@code true} means block network loads by the WebView 992 * @see android.webkit.WebView#reload 993 */ setBlockNetworkLoads(boolean flag)994 public abstract void setBlockNetworkLoads(boolean flag); 995 996 /** 997 * Gets whether the WebView does not load any resources from the network. 998 * 999 * @return {@code true} if the WebView does not load any resources from the network 1000 * @see #setBlockNetworkLoads 1001 */ getBlockNetworkLoads()1002 public abstract boolean getBlockNetworkLoads(); 1003 1004 /** 1005 * Tells the WebView to enable JavaScript execution. 1006 * <b>The default is {@code false}.</b> 1007 * 1008 * @param flag {@code true} if the WebView should execute JavaScript 1009 */ setJavaScriptEnabled(boolean flag)1010 public abstract void setJavaScriptEnabled(boolean flag); 1011 1012 /** 1013 * Sets whether cross-origin requests in the context of a file scheme URL should be allowed to 1014 * access content from <i>any</i> origin. This includes access to content from other file 1015 * scheme URLs or web contexts. Note that some access such as image HTML elements doesn't 1016 * follow same-origin rules and isn't affected by this setting. 1017 * <p> 1018 * <b>Don't</b> enable this setting if you open files that may be created or altered by 1019 * external sources. Enabling this setting allows malicious scripts loaded in a {@code file://} 1020 * context to launch cross-site scripting attacks, either accessing arbitrary local files 1021 * including WebView cookies, app private data or even credentials used on arbitrary web sites. 1022 * <p class="note"> 1023 * Loading content via {@code file://} URLs is generally discouraged. See the note in 1024 * {@link #setAllowFileAccess}. 1025 * <p> 1026 * The default value is {@code true} for apps targeting 1027 * {@link android.os.Build.VERSION_CODES#ICE_CREAM_SANDWICH_MR1} and below, and {@code false} 1028 * when targeting {@link android.os.Build.VERSION_CODES#JELLY_BEAN} and above. To prevent 1029 * possible violation of same domain policy when targeting 1030 * {@link android.os.Build.VERSION_CODES#ICE_CREAM_SANDWICH_MR1} and earlier, you should 1031 * explicitly set this value to {@code false}. 1032 * 1033 * @param flag whether JavaScript running in the context of a file scheme URL should be allowed 1034 * to access content from any origin 1035 * @deprecated This setting is not secure, please use 1036 * <a href="{@docRoot}reference/androidx/webkit/WebViewAssetLoader.html"> 1037 * androidx.webkit.WebViewAssetLoader</a> to load file content securely. 1038 */ 1039 @Deprecated setAllowUniversalAccessFromFileURLs(boolean flag)1040 public abstract void setAllowUniversalAccessFromFileURLs(boolean flag); 1041 1042 /** 1043 * Sets whether cross-origin requests in the context of a file scheme URL should be allowed to 1044 * access content from other file scheme URLs. Note that some accesses such as image HTML 1045 * elements don't follow same-origin rules and aren't affected by this setting. 1046 * <p> 1047 * <b>Don't</b> enable this setting if you open files that may be created or altered by 1048 * external sources. Enabling this setting allows malicious scripts loaded in a {@code file://} 1049 * context to access arbitrary local files including WebView cookies and app private data. 1050 * <p class="note"> 1051 * Loading content via {@code file://} URLs is generally discouraged. See the note in 1052 * {@link #setAllowFileAccess}. 1053 * <p> 1054 * Note that the value of this setting is ignored if the value of 1055 * {@link #getAllowUniversalAccessFromFileURLs} is {@code true}. The default value is 1056 * {@code true} for apps targeting {@link android.os.Build.VERSION_CODES#ICE_CREAM_SANDWICH_MR1} 1057 * and below, and {@code false} when targeting {@link android.os.Build.VERSION_CODES#JELLY_BEAN} 1058 * and above. To prevent possible violation of same domain policy when targeting 1059 * {@link android.os.Build.VERSION_CODES#ICE_CREAM_SANDWICH_MR1} and earlier, you should 1060 * explicitly set this value to {@code false}. 1061 * 1062 * @param flag whether JavaScript running in the context of a file scheme 1063 * URL should be allowed to access content from other file 1064 * scheme URLs 1065 * @deprecated This setting is not secure, please use 1066 * <a href="{@docRoot}reference/androidx/webkit/WebViewAssetLoader.html"> 1067 * androidx.webkit.WebViewAssetLoader</a> to load file content securely. 1068 */ 1069 @Deprecated setAllowFileAccessFromFileURLs(boolean flag)1070 public abstract void setAllowFileAccessFromFileURLs(boolean flag); 1071 1072 /** 1073 * Sets whether the WebView should enable plugins. The default is {@code false}. 1074 * 1075 * @param flag {@code true} if plugins should be enabled 1076 * @deprecated This method has been deprecated in favor of 1077 * {@link #setPluginState} 1078 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR2} 1079 */ 1080 @SuppressWarnings("HiddenAbstractMethod") 1081 @SystemApi 1082 @Deprecated setPluginsEnabled(boolean flag)1083 public abstract void setPluginsEnabled(boolean flag); 1084 1085 /** 1086 * Tells the WebView to enable, disable, or have plugins on demand. On 1087 * demand mode means that if a plugin exists that can handle the embedded 1088 * content, a placeholder icon will be shown instead of the plugin. When 1089 * the placeholder is clicked, the plugin will be enabled. The default is 1090 * {@link PluginState#OFF}. 1091 * 1092 * @param state a PluginState value 1093 * @deprecated Plugins are not supported in API level 1094 * {@link android.os.Build.VERSION_CODES#KITKAT} or later; 1095 * enabling plugins is a no-op. 1096 */ 1097 @Deprecated setPluginState(PluginState state)1098 public abstract void setPluginState(PluginState state); 1099 1100 /** 1101 * Sets a custom path to plugins used by the WebView. This method is 1102 * obsolete since each plugin is now loaded from its own package. 1103 * 1104 * @param pluginsPath a String path to the directory containing plugins 1105 * @deprecated This method is no longer used as plugins are loaded from 1106 * their own APK via the system's package manager. 1107 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR2} 1108 */ 1109 @Deprecated 1110 @UnsupportedAppUsage setPluginsPath(String pluginsPath)1111 public void setPluginsPath(String pluginsPath) { 1112 // Specified to do nothing, so no need for derived classes to override. 1113 } 1114 1115 /** 1116 * Sets the path to where database storage API databases should be saved. 1117 * In order for the database storage API to function correctly, this method 1118 * must be called with a path to which the application can write. This 1119 * method should only be called once: repeated calls are ignored. 1120 * 1121 * @param databasePath a path to the directory where databases should be 1122 * saved. 1123 * @deprecated Database paths are managed by the implementation and calling this method 1124 * will have no effect. 1125 */ 1126 @Deprecated setDatabasePath(String databasePath)1127 public abstract void setDatabasePath(String databasePath); 1128 1129 /** 1130 * Sets the path where the Geolocation databases should be saved. In order 1131 * for Geolocation permissions and cached positions to be persisted, this 1132 * method must be called with a path to which the application can write. 1133 * 1134 * @param databasePath a path to the directory where databases should be 1135 * saved. 1136 * @deprecated Geolocation database are managed by the implementation and calling this method 1137 * will have no effect. 1138 */ 1139 @Deprecated setGeolocationDatabasePath(String databasePath)1140 public abstract void setGeolocationDatabasePath(String databasePath); 1141 1142 /** 1143 * Sets whether the Application Caches API should be enabled. The default 1144 * is {@code false}. Note that in order for the Application Caches API to be 1145 * enabled, a valid database path must also be supplied to 1146 * {@link #setAppCachePath}. 1147 * 1148 * @param flag {@code true} if the WebView should enable Application Caches 1149 * @deprecated The Application Cache API is deprecated and this method will 1150 * become a no-op on all Android versions once support is 1151 * removed in Chromium. Consider using Service Workers instead. 1152 * See https://web.dev/appcache-removal/ for more information. 1153 * @removed The Application Cache API is no longer supported and this method 1154 * is a no-op on WebView 95 and later. Consider using Service Workers 1155 * instead. See https://web.dev/appcache-removal/ for more information. 1156 */ 1157 @Deprecated setAppCacheEnabled(boolean flag)1158 public void setAppCacheEnabled(boolean flag) {} 1159 1160 /** 1161 * Sets the path to the Application Caches files. In order for the 1162 * Application Caches API to be enabled, this method must be called with a 1163 * path to which the application can write. This method should only be 1164 * called once: repeated calls are ignored. 1165 * 1166 * @param appCachePath a String path to the directory containing 1167 * Application Caches files. 1168 * @see #setAppCacheEnabled 1169 * @deprecated The Application Cache API is deprecated and this method will 1170 * become a no-op on all Android versions once support is 1171 * removed in Chromium. Consider using Service Workers instead. 1172 * See https://web.dev/appcache-removal/ for more information. 1173 * @removed The Application Cache API is no longer supported and this method 1174 * is a no-op on WebView 95 and later. Consider using Service Workers 1175 * instead. See https://web.dev/appcache-removal/ for more information. 1176 */ 1177 @Deprecated setAppCachePath(String appCachePath)1178 public void setAppCachePath(String appCachePath) {} 1179 1180 /** 1181 * Sets the maximum size for the Application Cache content. The passed size 1182 * will be rounded to the nearest value that the database can support, so 1183 * this should be viewed as a guide, not a hard limit. Setting the 1184 * size to a value less than current database size does not cause the 1185 * database to be trimmed. The default size is {@link Long#MAX_VALUE}. 1186 * It is recommended to leave the maximum size set to the default value. 1187 * 1188 * @param appCacheMaxSize the maximum size in bytes 1189 * @deprecated Quota is managed automatically; this method is a no-op. 1190 * @removed Quota is managed automatically; this method is a no-op. 1191 */ 1192 @Deprecated setAppCacheMaxSize(long appCacheMaxSize)1193 public void setAppCacheMaxSize(long appCacheMaxSize) {} 1194 1195 /** 1196 * Sets whether the database storage API is enabled. The default value is 1197 * false. See also {@link #setDatabasePath} for how to correctly set up the 1198 * database storage API. 1199 * 1200 * This setting is global in effect, across all WebView instances in a process. 1201 * Note you should only modify this setting prior to making <b>any</b> WebView 1202 * page load within a given process, as the WebView implementation may ignore 1203 * changes to this setting after that point. 1204 * 1205 * @param flag {@code true} if the WebView should use the database storage API 1206 * @deprecated WebSQL is deprecated and this method will become a no-op on all 1207 * Android versions once support is removed in Chromium. See 1208 * https://developer.chrome.com/blog/deprecating-web-sql for more information. 1209 */ 1210 @Deprecated setDatabaseEnabled(boolean flag)1211 public abstract void setDatabaseEnabled(boolean flag); 1212 1213 /** 1214 * Sets whether the DOM storage API is enabled. The default value is {@code false}. 1215 * 1216 * @param flag {@code true} if the WebView should use the DOM storage API 1217 */ setDomStorageEnabled(boolean flag)1218 public abstract void setDomStorageEnabled(boolean flag); 1219 1220 /** 1221 * Gets whether the DOM Storage APIs are enabled. 1222 * 1223 * @return {@code true} if the DOM Storage APIs are enabled 1224 * @see #setDomStorageEnabled 1225 */ getDomStorageEnabled()1226 public abstract boolean getDomStorageEnabled(); 1227 1228 /** 1229 * Gets the path to where database storage API databases are saved. 1230 * 1231 * @return the String path to the database storage API databases 1232 * @see #setDatabasePath 1233 * @deprecated Database paths are managed by the implementation this method is obsolete. 1234 */ 1235 @Deprecated getDatabasePath()1236 public abstract String getDatabasePath(); 1237 1238 /** 1239 * Gets whether the database storage API is enabled. 1240 * 1241 * @return {@code true} if the database storage API is enabled 1242 * @see #setDatabaseEnabled 1243 * @deprecated WebSQL is deprecated and this method will become a no-op on all 1244 * Android versions once support is removed in Chromium. See 1245 * https://developer.chrome.com/blog/deprecating-web-sql for more information. 1246 */ 1247 @Deprecated getDatabaseEnabled()1248 public abstract boolean getDatabaseEnabled(); 1249 1250 /** 1251 * Sets whether Geolocation is enabled. The default is {@code true}. 1252 * <p> 1253 * Please note that in order for the Geolocation API to be usable 1254 * by a page in the WebView, the following requirements must be met: 1255 * <ul> 1256 * <li>an application must have permission to access the device location, 1257 * see {@link android.Manifest.permission#ACCESS_COARSE_LOCATION}, 1258 * {@link android.Manifest.permission#ACCESS_FINE_LOCATION}; 1259 * <li>an application must provide an implementation of the 1260 * {@link WebChromeClient#onGeolocationPermissionsShowPrompt} callback 1261 * to receive notifications that a page is requesting access to location 1262 * via the JavaScript Geolocation API. 1263 * </ul> 1264 * <p> 1265 * 1266 * @param flag whether Geolocation should be enabled 1267 */ setGeolocationEnabled(boolean flag)1268 public abstract void setGeolocationEnabled(boolean flag); 1269 1270 /** 1271 * Gets whether JavaScript is enabled. 1272 * 1273 * @return {@code true} if JavaScript is enabled 1274 * @see #setJavaScriptEnabled 1275 */ getJavaScriptEnabled()1276 public abstract boolean getJavaScriptEnabled(); 1277 1278 /** 1279 * Gets whether JavaScript running in the context of a file scheme URL can 1280 * access content from any origin. This includes access to content from 1281 * other file scheme URLs. 1282 * 1283 * @return whether JavaScript running in the context of a file scheme URL 1284 * can access content from any origin 1285 * @see #setAllowUniversalAccessFromFileURLs 1286 */ getAllowUniversalAccessFromFileURLs()1287 public abstract boolean getAllowUniversalAccessFromFileURLs(); 1288 1289 /** 1290 * Gets whether JavaScript running in the context of a file scheme URL can 1291 * access content from other file scheme URLs. 1292 * 1293 * @return whether JavaScript running in the context of a file scheme URL 1294 * can access content from other file scheme URLs 1295 * @see #setAllowFileAccessFromFileURLs 1296 */ getAllowFileAccessFromFileURLs()1297 public abstract boolean getAllowFileAccessFromFileURLs(); 1298 1299 /** 1300 * Gets whether plugins are enabled. 1301 * 1302 * @return {@code true} if plugins are enabled 1303 * @see #setPluginsEnabled 1304 * @deprecated This method has been replaced by {@link #getPluginState} 1305 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR2} 1306 */ 1307 @SuppressWarnings("HiddenAbstractMethod") 1308 @SystemApi 1309 @Deprecated getPluginsEnabled()1310 public abstract boolean getPluginsEnabled(); 1311 1312 /** 1313 * Gets the current state regarding whether plugins are enabled. 1314 * 1315 * @return the plugin state as a {@link PluginState} value 1316 * @see #setPluginState 1317 * @deprecated Plugins are not supported in API level 1318 * {@link android.os.Build.VERSION_CODES#KITKAT} or later; 1319 * enabling plugins is a no-op. 1320 */ 1321 @Deprecated getPluginState()1322 public abstract PluginState getPluginState(); 1323 1324 /** 1325 * Gets the directory that contains the plugin libraries. This method is 1326 * obsolete since each plugin is now loaded from its own package. 1327 * 1328 * @return an empty string 1329 * @deprecated This method is no longer used as plugins are loaded from 1330 * their own APK via the system's package manager. 1331 * @hide Since API level {@link android.os.Build.VERSION_CODES#JELLY_BEAN_MR2} 1332 */ 1333 @Deprecated 1334 @UnsupportedAppUsage getPluginsPath()1335 public String getPluginsPath() { 1336 // Unconditionally returns empty string, so no need for derived classes to override. 1337 return ""; 1338 } 1339 1340 /** 1341 * Tells JavaScript to open windows automatically. This applies to the 1342 * JavaScript function {@code window.open()}. The default is {@code false}. 1343 * 1344 * @param flag {@code true} if JavaScript can open windows automatically 1345 */ setJavaScriptCanOpenWindowsAutomatically(boolean flag)1346 public abstract void setJavaScriptCanOpenWindowsAutomatically(boolean flag); 1347 1348 /** 1349 * Gets whether JavaScript can open windows automatically. 1350 * 1351 * @return {@code true} if JavaScript can open windows automatically during 1352 * {@code window.open()} 1353 * @see #setJavaScriptCanOpenWindowsAutomatically 1354 */ getJavaScriptCanOpenWindowsAutomatically()1355 public abstract boolean getJavaScriptCanOpenWindowsAutomatically(); 1356 1357 /** 1358 * Sets the default text encoding name to use when decoding html pages. 1359 * The default is "UTF-8". 1360 * 1361 * @param encoding the text encoding name 1362 */ setDefaultTextEncodingName(String encoding)1363 public abstract void setDefaultTextEncodingName(String encoding); 1364 1365 /** 1366 * Gets the default text encoding name. 1367 * 1368 * @return the default text encoding name as a string 1369 * @see #setDefaultTextEncodingName 1370 */ getDefaultTextEncodingName()1371 public abstract String getDefaultTextEncodingName(); 1372 1373 /** 1374 * Sets the WebView's user-agent string. If the string is {@code null} or empty, 1375 * the system default value will be used. 1376 * 1377 * <p>If the user-agent is overridden in this way, the values of the User-Agent Client Hints 1378 * headers and {@code navigator.userAgentData} for this WebView could be changed. 1379 * <p> See <a href="{@docRoot}reference/androidx/webkit/WebSettingsCompat 1380 * #setUserAgentMetadata(WebSettings,UserAgentMetadata)">androidx.webkit.WebSettingsCompat 1381 * #setUserAgentMetadata(WebSettings,UserAgentMetadata)</a> for details. 1382 * 1383 * <p>Note that starting from {@link android.os.Build.VERSION_CODES#KITKAT} Android 1384 * version, changing the user-agent while loading a web page causes WebView 1385 * to initiate loading once again. 1386 * 1387 * @param ua new user-agent string 1388 */ setUserAgentString(@ullable String ua)1389 public abstract void setUserAgentString(@Nullable String ua); 1390 1391 /** 1392 * Gets the WebView's user-agent string. 1393 * 1394 * @return the WebView's user-agent string 1395 * @see #setUserAgentString 1396 */ getUserAgentString()1397 public abstract String getUserAgentString(); 1398 1399 /** 1400 * Returns the default User-Agent used by a WebView. 1401 * An instance of WebView could use a different User-Agent if a call 1402 * is made to {@link WebSettings#setUserAgentString(String)}. 1403 * 1404 * @param context a Context object used to access application assets 1405 */ getDefaultUserAgent(Context context)1406 public static String getDefaultUserAgent(Context context) { 1407 return WebViewFactory.getProvider().getStatics().getDefaultUserAgent(context); 1408 } 1409 1410 /** 1411 * Tells the WebView whether it needs to set a node to have focus when 1412 * {@link WebView#requestFocus(int, android.graphics.Rect)} is called. The 1413 * default value is {@code true}. 1414 * 1415 * @param flag whether the WebView needs to set a node 1416 */ setNeedInitialFocus(boolean flag)1417 public abstract void setNeedInitialFocus(boolean flag); 1418 1419 /** 1420 * Sets the priority of the Render thread. Unlike the other settings, this 1421 * one only needs to be called once per process. The default value is 1422 * {@link RenderPriority#NORMAL}. 1423 * 1424 * @param priority the priority 1425 * @deprecated It is not recommended to adjust thread priorities, and this will 1426 * not be supported in future versions. 1427 */ 1428 @Deprecated setRenderPriority(RenderPriority priority)1429 public abstract void setRenderPriority(RenderPriority priority); 1430 1431 /** 1432 * Overrides the way the cache is used. The way the cache is used is based 1433 * on the navigation type. For a normal page load, the cache is checked 1434 * and content is re-validated as needed. When navigating back, content is 1435 * not revalidated, instead the content is just retrieved from the cache. 1436 * This method allows the client to override this behavior by specifying 1437 * one of {@link #LOAD_DEFAULT}, 1438 * {@link #LOAD_CACHE_ELSE_NETWORK}, {@link #LOAD_NO_CACHE} or 1439 * {@link #LOAD_CACHE_ONLY}. The default value is {@link #LOAD_DEFAULT}. 1440 * 1441 * @param mode the mode to use 1442 */ setCacheMode(@acheMode int mode)1443 public abstract void setCacheMode(@CacheMode int mode); 1444 1445 /** 1446 * Gets the current setting for overriding the cache mode. 1447 * 1448 * @return the current setting for overriding the cache mode 1449 * @see #setCacheMode 1450 */ 1451 @CacheMode getCacheMode()1452 public abstract int getCacheMode(); 1453 1454 /** 1455 * Configures the WebView's behavior when a secure origin attempts to load a resource from an 1456 * insecure origin. 1457 * 1458 * By default, apps that target {@link android.os.Build.VERSION_CODES#KITKAT} or below default 1459 * to {@link #MIXED_CONTENT_ALWAYS_ALLOW}. Apps targeting 1460 * {@link android.os.Build.VERSION_CODES#LOLLIPOP} default to {@link #MIXED_CONTENT_NEVER_ALLOW}. 1461 * 1462 * The preferred and most secure mode of operation for the WebView is 1463 * {@link #MIXED_CONTENT_NEVER_ALLOW} and use of {@link #MIXED_CONTENT_ALWAYS_ALLOW} is 1464 * strongly discouraged. 1465 * 1466 * @param mode The mixed content mode to use. One of {@link #MIXED_CONTENT_NEVER_ALLOW}, 1467 * {@link #MIXED_CONTENT_ALWAYS_ALLOW} or {@link #MIXED_CONTENT_COMPATIBILITY_MODE}. 1468 */ setMixedContentMode(int mode)1469 public abstract void setMixedContentMode(int mode); 1470 1471 /** 1472 * Gets the current behavior of the WebView with regard to loading insecure content from a 1473 * secure origin. 1474 * @return The current setting, one of {@link #MIXED_CONTENT_NEVER_ALLOW}, 1475 * {@link #MIXED_CONTENT_ALWAYS_ALLOW} or {@link #MIXED_CONTENT_COMPATIBILITY_MODE}. 1476 */ getMixedContentMode()1477 public abstract int getMixedContentMode(); 1478 1479 /** 1480 * Sets whether to use a video overlay for embedded encrypted video. 1481 * In API levels prior to {@link android.os.Build.VERSION_CODES#LOLLIPOP}, encrypted video can 1482 * only be rendered directly on a secure video surface, so it had been a hard problem to play 1483 * encrypted video in HTML. When this flag is on, WebView can play encrypted video (MSE/EME) 1484 * by using a video overlay (aka hole-punching) for videos embedded using HTML <video> 1485 * tag.<br> 1486 * Caution: This setting is intended for use only in a narrow set of circumstances and apps 1487 * should only enable it if they require playback of encrypted video content. It will impose 1488 * the following limitations on the WebView: 1489 * <ul> 1490 * <li> Only one video overlay can be played at a time. 1491 * <li> Changes made to position or dimensions of a video element may be propagated to the 1492 * corresponding video overlay with a noticeable delay. 1493 * <li> The video overlay is not visible to web APIs and as such may not interact with 1494 * script or styling. For example, CSS styles applied to the <video> tag may be ignored. 1495 * </ul> 1496 * This is not an exhaustive set of constraints and it may vary with new versions of the 1497 * WebView. 1498 * @hide 1499 */ 1500 @SuppressWarnings("HiddenAbstractMethod") 1501 @SystemApi setVideoOverlayForEmbeddedEncryptedVideoEnabled(boolean flag)1502 public abstract void setVideoOverlayForEmbeddedEncryptedVideoEnabled(boolean flag); 1503 1504 /** 1505 * Gets whether a video overlay will be used for embedded encrypted video. 1506 * 1507 * @return {@code true} if WebView uses a video overlay for embedded encrypted video. 1508 * @see #setVideoOverlayForEmbeddedEncryptedVideoEnabled 1509 * @hide 1510 */ 1511 @SuppressWarnings("HiddenAbstractMethod") 1512 @SystemApi getVideoOverlayForEmbeddedEncryptedVideoEnabled()1513 public abstract boolean getVideoOverlayForEmbeddedEncryptedVideoEnabled(); 1514 1515 /** 1516 * Sets whether this WebView should raster tiles when it is 1517 * offscreen but attached to a window. Turning this on can avoid 1518 * rendering artifacts when animating an offscreen WebView on-screen. 1519 * Offscreen WebViews in this mode use more memory. The default value is 1520 * false.<br> 1521 * Please follow these guidelines to limit memory usage: 1522 * <ul> 1523 * <li> WebView size should be not be larger than the device screen size. 1524 * <li> Limit use of this mode to a small number of WebViews. Use it for 1525 * visible WebViews and WebViews about to be animated to visible. 1526 * </ul> 1527 */ setOffscreenPreRaster(boolean enabled)1528 public abstract void setOffscreenPreRaster(boolean enabled); 1529 1530 /** 1531 * Gets whether this WebView should raster tiles when it is 1532 * offscreen but attached to a window. 1533 * @return {@code true} if this WebView will raster tiles when it is 1534 * offscreen but attached to a window. 1535 */ getOffscreenPreRaster()1536 public abstract boolean getOffscreenPreRaster(); 1537 1538 1539 /** 1540 * Sets whether Safe Browsing is enabled. Safe Browsing allows WebView to 1541 * protect against malware and phishing attacks by verifying the links. 1542 * 1543 * <p> 1544 * Safe Browsing can be disabled for all WebViews using a manifest tag (read <a 1545 * href="{@docRoot}reference/android/webkit/WebView.html">general Safe Browsing info</a>). The 1546 * manifest tag has a lower precedence than this API. 1547 * 1548 * <p> 1549 * Safe Browsing is enabled by default for devices which support it. 1550 * 1551 * @param enabled Whether Safe Browsing is enabled. 1552 */ setSafeBrowsingEnabled(boolean enabled)1553 public abstract void setSafeBrowsingEnabled(boolean enabled); 1554 1555 /** 1556 * Gets whether Safe Browsing is enabled. 1557 * See {@link #setSafeBrowsingEnabled}. 1558 * 1559 * @return {@code true} if Safe Browsing is enabled and {@code false} otherwise. 1560 */ getSafeBrowsingEnabled()1561 public abstract boolean getSafeBrowsingEnabled(); 1562 1563 1564 /** 1565 * Set the force dark mode for this WebView. 1566 * 1567 * @param forceDark the force dark mode to set. 1568 * @see #getForceDark 1569 * @deprecated The "force dark" model previously implemented by WebView was complex 1570 * and didn't interoperate well with current Web standards for 1571 * {@code prefers-color-scheme} and {@code color-scheme}. In apps with 1572 * {@code targetSdkVersion} ≥ {@link android.os.Build.VERSION_CODES#TIRAMISU} 1573 * this API is a no-op and WebView will always use the dark style defined by web content 1574 * authors if the app's theme is dark. To customize the behavior, refer to 1575 * {@link #setAlgorithmicDarkeningAllowed}. 1576 */ setForceDark(@orceDark int forceDark)1577 public void setForceDark(@ForceDark int forceDark) { 1578 // Stub implementation to satisfy Roboelectrc shadows that don't override this yet. 1579 } 1580 1581 /** 1582 * Get the force dark mode for this WebView. 1583 * The default force dark mode is {@link #FORCE_DARK_AUTO}. 1584 * 1585 * @return the currently set force dark mode. 1586 * @see #setForceDark 1587 * @deprecated refer to {@link #setForceDark}. 1588 */ getForceDark()1589 public @ForceDark int getForceDark() { 1590 // Stub implementation to satisfy Roboelectrc shadows that don't override this yet. 1591 return FORCE_DARK_AUTO; 1592 } 1593 1594 /** 1595 * Control whether algorithmic darkening is allowed. 1596 * 1597 * <p class="note"> 1598 * <b>Note:</b> This API and the behaviour described only apply to apps with 1599 * {@code targetSdkVersion} ≥ {@link android.os.Build.VERSION_CODES#TIRAMISU}. 1600 * 1601 * <p> 1602 * WebView always sets the media query {@code prefers-color-scheme} according to the app's 1603 * theme attribute {@link android.R.styleable#Theme_isLightTheme isLightTheme}, i.e. 1604 * {@code prefers-color-scheme} is {@code light} if isLightTheme is true or not specified, 1605 * otherwise it is {@code dark}. This means that the web content's light or dark style will 1606 * be applied automatically to match the app's theme if the content supports it. 1607 * 1608 * <p> 1609 * Algorithmic darkening is disallowed by default. 1610 * <p> 1611 * If the app's theme is dark and it allows algorithmic darkening, WebView will attempt to 1612 * darken web content using an algorithm, if the content doesn't define its own dark styles 1613 * and doesn't explicitly disable darkening. 1614 * 1615 * <p> 1616 * If Android is applying Force Dark to WebView then WebView will ignore the value of 1617 * this setting and behave as if it were set to true. 1618 * 1619 * <p> 1620 * The deprecated {@link #setForceDark} and related API are no-ops in apps with 1621 * {@code targetSdkVersion} ≥ {@link android.os.Build.VERSION_CODES#TIRAMISU}, 1622 * but they still apply to apps with 1623 * {@code targetSdkVersion} < {@link android.os.Build.VERSION_CODES#TIRAMISU}. 1624 * 1625 * <p> 1626 * The below table summarizes how APIs work with different apps. 1627 * 1628 * <table border="2" width="85%" align="center" cellpadding="5"> 1629 * <thead> 1630 * <tr> 1631 * <th>App</th> 1632 * <th>Web content which uses {@code prefers-color-scheme}</th> 1633 * <th>Web content which does not use {@code prefers-color-scheme}</th> 1634 * </tr> 1635 * </thead> 1636 * <tbody> 1637 * <tr> 1638 * <td>App with {@code isLightTheme} True or not set</td> 1639 * <td>Renders with the light theme defined by the content author.</td> 1640 * <td>Renders with the default styling defined by the content author.</td> 1641 * </tr> 1642 * <tr> 1643 * <td>App with Android forceDark in effect</td> 1644 * <td>Renders with the dark theme defined by the content author.</td> 1645 * <td>Renders with the styling modified to dark colors by an algorithm 1646 * if allowed by the content author.</td> 1647 * </tr> 1648 * <tr> 1649 * <td>App with {@code isLightTheme} False, 1650 * {@code targetSdkVersion} < {@link android.os.Build.VERSION_CODES#TIRAMISU}, 1651 * and has {@code FORCE_DARK_AUTO}</td> 1652 * <td>Renders with the dark theme defined by the content author.</td> 1653 * <td>Renders with the default styling defined by the content author.</td> 1654 * </tr> 1655 * <tr> 1656 * <td>App with {@code isLightTheme} False, 1657 * {@code targetSdkVersion} ≥ {@link android.os.Build.VERSION_CODES#TIRAMISU}, 1658 * and {@code setAlgorithmicDarkening(false)}</td> 1659 * <td>Renders with the dark theme defined by the content author.</td> 1660 * <td>Renders with the default styling defined by the content author.</td> 1661 * </tr> 1662 * <tr> 1663 * <td>App with {@code isLightTheme} False, 1664 * {@code targetSdkVersion} ≥ {@link android.os.Build.VERSION_CODES#TIRAMISU}, 1665 * and {@code setAlgorithmicDarkening(true)}</td> 1666 * <td>Renders with the dark theme defined by the content author.</td> 1667 * <td>Renders with the styling modified to dark colors by an algorithm if allowed 1668 * by the content author.</td> 1669 * </tr> 1670 * </tbody> 1671 * </table> 1672 * </p> 1673 * 1674 * @param allow allow algorithmic darkening or not. 1675 */ setAlgorithmicDarkeningAllowed(boolean allow)1676 public void setAlgorithmicDarkeningAllowed(boolean allow) { 1677 // Stub implementation to satisfy Roboelectrc shadows that don't override this yet. 1678 } 1679 1680 /** 1681 * Get if algorithmic darkening is allowed or not for this WebView. 1682 * The default is false. 1683 * 1684 * @return if the algorithmic darkening is allowed or not. 1685 * @see #setAlgorithmicDarkeningAllowed 1686 */ isAlgorithmicDarkeningAllowed()1687 public boolean isAlgorithmicDarkeningAllowed() { 1688 // Stub implementation to satisfy Roboelectrc shadows that don't override this yet. 1689 return false; 1690 } 1691 1692 /** 1693 * @hide 1694 */ 1695 @IntDef(flag = true, prefix = { "MENU_ITEM_" }, value = { 1696 MENU_ITEM_NONE, 1697 MENU_ITEM_SHARE, 1698 MENU_ITEM_WEB_SEARCH, 1699 MENU_ITEM_PROCESS_TEXT 1700 }) 1701 @Retention(RetentionPolicy.SOURCE) 1702 @Target({ElementType.PARAMETER, ElementType.METHOD}) 1703 private @interface MenuItemFlags {} 1704 1705 /** 1706 * Disables the action mode menu items according to {@code menuItems} flag. 1707 * @param menuItems an integer field flag for the menu items to be disabled. 1708 */ setDisabledActionModeMenuItems(@enuItemFlags int menuItems)1709 public abstract void setDisabledActionModeMenuItems(@MenuItemFlags int menuItems); 1710 1711 /** 1712 * Gets the action mode menu items that are disabled, expressed in an integer field flag. 1713 * The default value is {@link #MENU_ITEM_NONE} 1714 * 1715 * @return all the disabled menu item flags combined with bitwise OR. 1716 */ getDisabledActionModeMenuItems()1717 public abstract @MenuItemFlags int getDisabledActionModeMenuItems(); 1718 1719 /** 1720 * No menu items should be disabled. 1721 * 1722 * @see #setDisabledActionModeMenuItems 1723 */ 1724 public static final int MENU_ITEM_NONE = 0; 1725 1726 /** 1727 * Disable menu item "Share". 1728 * 1729 * @see #setDisabledActionModeMenuItems 1730 */ 1731 public static final int MENU_ITEM_SHARE = 1 << 0; 1732 1733 /** 1734 * Disable menu item "Web Search". 1735 * 1736 * @see #setDisabledActionModeMenuItems 1737 */ 1738 public static final int MENU_ITEM_WEB_SEARCH = 1 << 1; 1739 1740 /** 1741 * Disable all the action mode menu items for text processing. 1742 * By default WebView searches for activities that are able to handle 1743 * {@link android.content.Intent#ACTION_PROCESS_TEXT} and show them in the 1744 * action mode menu. If this flag is set via {@link 1745 * #setDisabledActionModeMenuItems}, these menu items will be disabled. 1746 * 1747 * @see #setDisabledActionModeMenuItems 1748 */ 1749 public static final int MENU_ITEM_PROCESS_TEXT = 1 << 2; 1750 } 1751