WebSettings.java revision f8d4964e45f7e671f4b333386b4269b23ced4750
154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project/* 254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Copyright (C) 2007 The Android Open Source Project 354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * 454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License"); 554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * you may not use this file except in compliance with the License. 654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * You may obtain a copy of the License at 754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * 854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * http://www.apache.org/licenses/LICENSE-2.0 954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * 1054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Unless required by applicable law or agreed to in writing, software 1154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS, 1254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * See the License for the specific language governing permissions and 1454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * limitations under the License. 1554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 1654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 1754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectpackage android.webkit; 1854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 1954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.content.Context; 20972acd0c339db4b6a72c307ae0a0b2b5405376dbAndrei Popescuimport android.content.pm.PackageManager; 2154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.os.Build; 2254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.os.Handler; 2354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.os.Message; 249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimport android.provider.Checkin; 25f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Projectimport java.lang.SecurityException; 2654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport java.util.Locale; 2754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 2854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project/** 2954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Manages settings state for a WebView. When a WebView is first created, it 3054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * obtains a set of default settings. These default settings will be returned 3154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * from any getter call. A WebSettings object obtained from 3254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * WebView.getSettings() is tied to the life of the WebView. If a WebView has 3354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * been destroyed, any method call on WebSettings will throw an 3454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * IllegalStateException. 3554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 3654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectpublic class WebSettings { 3754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 3854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Enum for controlling the layout of html. 3954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * NORMAL means no rendering changes. 4054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * SINGLE_COLUMN moves all content into one column that is the width of the 4154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * view. 4254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * NARROW_COLUMNS makes all columns no wider than the screen if possible. 4354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 4454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // XXX: These must match LayoutAlgorithm in Settings.h in WebCore. 4554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public enum LayoutAlgorithm { 4654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project NORMAL, 4754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project SINGLE_COLUMN, 4854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project NARROW_COLUMNS 4954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 5054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 5154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 5254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Enum for specifying the text size. 5354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * SMALLEST is 50% 5454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * SMALLER is 75% 5554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * NORMAL is 100% 5654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * LARGER is 150% 5754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * LARGEST is 200% 5854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 5954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public enum TextSize { 6054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project SMALLEST(50), 6154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project SMALLER(75), 6254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project NORMAL(100), 6354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project LARGER(150), 6454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project LARGEST(200); 6554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project TextSize(int size) { 6654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project value = size; 6754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 6854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project int value; 6954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 700d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba 710d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba /** 720d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * Enum for specifying the WebView's desired density. 730d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * FAR makes 100% looking like in 240dpi 740d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * MEDIUM makes 100% looking like in 160dpi 750d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * CLOSE makes 100% looking like in 120dpi 760d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @hide Pending API council approval 770d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba */ 780d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba public enum ZoomDensity { 790d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba FAR(150), // 240dpi 800d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba MEDIUM(100), // 160dpi 810d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba CLOSE(75); // 120dpi 820d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba ZoomDensity(int size) { 830d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba value = size; 840d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba } 850d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba int value; 860d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba } 870d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba 8854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 8954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Default cache usage pattern Use with {@link #setCacheMode}. 9054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 9154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public static final int LOAD_DEFAULT = -1; 9254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 9354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 9454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Normal cache usage pattern Use with {@link #setCacheMode}. 9554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 9654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public static final int LOAD_NORMAL = 0; 9754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 9854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 9954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Use cache if content is there, even if expired (eg, history nav) 10054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * If it is not in the cache, load from network. 10154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Use with {@link #setCacheMode}. 10254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 10354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public static final int LOAD_CACHE_ELSE_NETWORK = 1; 10454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 10554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 10654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Don't use the cache, load from network 10754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Use with {@link #setCacheMode}. 10854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 10954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public static final int LOAD_NO_CACHE = 2; 11054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 11154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 11254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Don't use the network, load from cache only. 11354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Use with {@link #setCacheMode}. 11454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 11554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public static final int LOAD_CACHE_ONLY = 3; 11654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 11754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public enum RenderPriority { 11854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project NORMAL, 11954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project HIGH, 12054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project LOW 12154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 12254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 1230d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba // WebView associated with this WebSettings. 1240d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba private WebView mWebView; 12554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // BrowserFrame used to access the native frame pointer. 12654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private BrowserFrame mBrowserFrame; 12754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Flag to prevent multiple SYNC messages at one time. 12854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mSyncPending = false; 12954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Custom handler that queues messages until the WebCore thread is active. 13054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private final EventHandler mEventHandler; 131adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn 13254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Private settings so we don't have to go into native code to 13354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // retrieve the values. After setXXX, postSync() needs to be called. 134adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn // 135adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn // The default values need to match those in WebSettings.cpp 136adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn // If the defaults change, please also update the JavaDocs so developers 137adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn // know what they are. 13854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private LayoutAlgorithm mLayoutAlgorithm = LayoutAlgorithm.NARROW_COLUMNS; 139f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private Context mContext; 14054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private TextSize mTextSize = TextSize.NORMAL; 14154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private String mStandardFontFamily = "sans-serif"; 14254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private String mFixedFontFamily = "monospace"; 14354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private String mSansSerifFontFamily = "sans-serif"; 14454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private String mSerifFontFamily = "serif"; 14554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private String mCursiveFontFamily = "cursive"; 14654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private String mFantasyFontFamily = "fantasy"; 147c27d9b5341b29c1b58c882f0a04b4c519d8a9853Daisuke Miyakawa private String mDefaultTextEncoding; 148f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private String mUserAgent; 149f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private boolean mUseDefaultUserAgent; 150f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private String mAcceptLanguage; 15154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private int mMinimumFontSize = 8; 15254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private int mMinimumLogicalFontSize = 8; 15354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private int mDefaultFontSize = 16; 15454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private int mDefaultFixedFontSize = 13; 15554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mLoadsImagesAutomatically = true; 15654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mBlockNetworkImage = false; 157c39a6e0c51e182338deb8b63d07933b585134929The Android Open Source Project private boolean mBlockNetworkLoads; 15854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mJavaScriptEnabled = false; 15954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mPluginsEnabled = false; 16054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mJavaScriptCanOpenWindowsAutomatically = false; 16154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mUseDoubleTree = false; 16254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mUseWideViewport = false; 16354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mSupportMultipleWindows = false; 164f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private boolean mShrinksStandaloneImagesToFit = false; 165c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu // HTML5 API flags 166c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private boolean mAppCacheEnabled = false; 167c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private boolean mDatabaseEnabled = false; 168c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private boolean mDomStorageEnabled = false; 169c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private boolean mWorkersEnabled = false; // only affects V8. 17009b0ca1ceefde02b9ed50dc4dd12774ba569143fSteve Block private boolean mGeolocationEnabled = true; 171c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu // HTML5 configuration parameters 172c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private long mAppCacheMaxSize = Long.MAX_VALUE; 173c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private String mAppCachePath = ""; 174c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu private String mDatabasePath = ""; 1759d3273f62288fa54536a3928383588398ca2d029Steve Block private String mGeolocationDatabasePath = ""; 17654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Don't need to synchronize the get/set methods as they 17754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // are basic types, also none of these values are used in 17854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // native WebCore code. 1790d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba private ZoomDensity mDefaultZoom = ZoomDensity.MEDIUM; 18054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private RenderPriority mRenderPriority = RenderPriority.NORMAL; 18154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private int mOverrideCacheMode = LOAD_DEFAULT; 18254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mSaveFormData = true; 18354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mSavePassword = true; 18454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mLightTouchEnabled = false; 18554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mNeedInitialFocus = true; 18654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mNavDump = false; 18754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private boolean mSupportZoom = true; 188105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project private boolean mBuiltInZoomControls = false; 189f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private boolean mAllowFileAccess = true; 190f8d4964e45f7e671f4b333386b4269b23ced4750Cary Clark private boolean mLoadWithOverviewMode = false; 19154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 192d875ce6dac3c2e9a671c121c80b40d2536cbb2afSteve Block // Manages interaction of the system setting 'Location & security - Share 193d875ce6dac3c2e9a671c121c80b40d2536cbb2afSteve Block // with Google' and the browser. 194d875ce6dac3c2e9a671c121c80b40d2536cbb2afSteve Block static GoogleLocationSettingManager sGoogleLocationSettingManager; 195d875ce6dac3c2e9a671c121c80b40d2536cbb2afSteve Block 19654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Class to handle messages before WebCore is ready. 19754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private class EventHandler { 19854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Message id for syncing 19954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project static final int SYNC = 0; 20054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Message id for setting priority 20154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project static final int PRIORITY = 1; 20254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Actual WebCore thread handler 20354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private Handler mHandler; 20454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 20554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private synchronized void createHandler() { 20654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // as mRenderPriority can be set before thread is running, sync up 20754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project setRenderPriority(); 20854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 20954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // create a new handler 21054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mHandler = new Handler() { 21154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project @Override 21254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void handleMessage(Message msg) { 21354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project switch (msg.what) { 21454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project case SYNC: 21554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project synchronized (WebSettings.this) { 21654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mBrowserFrame.mNativeFrame != 0) { 21754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project nativeSync(mBrowserFrame.mNativeFrame); 21854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 21954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSyncPending = false; 22054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 22154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project break; 22254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 22354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project case PRIORITY: { 22454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project setRenderPriority(); 22554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project break; 22654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 22754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 22854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 22954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project }; 23054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 23154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 23254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private void setRenderPriority() { 23354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project synchronized (WebSettings.this) { 23454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mRenderPriority == RenderPriority.NORMAL) { 23554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.setThreadPriority( 23654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.THREAD_PRIORITY_DEFAULT); 23754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } else if (mRenderPriority == RenderPriority.HIGH) { 23854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.setThreadPriority( 23954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.THREAD_PRIORITY_FOREGROUND + 24054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.THREAD_PRIORITY_LESS_FAVORABLE); 24154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } else if (mRenderPriority == RenderPriority.LOW) { 24254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.setThreadPriority( 24354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project android.os.Process.THREAD_PRIORITY_BACKGROUND); 24454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 24554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 24654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 24754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 24854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 24954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Send a message to the private queue or handler. 25054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 25154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private synchronized boolean sendMessage(Message msg) { 25254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mHandler != null) { 25354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mHandler.sendMessage(msg); 25454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return true; 25554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } else { 25654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return false; 25754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 25854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 25954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 26054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 26154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // User agent strings. 26254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private static final String DESKTOP_USERAGENT = 263b4f33445b8106f550ade837362c678cf9de2ecd2Grace Kloba "Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10_5_7; en-us)" 264b4f33445b8106f550ade837362c678cf9de2ecd2Grace Kloba + " AppleWebKit/530.17 (KHTML, like Gecko) Version/4.0" 265b4f33445b8106f550ade837362c678cf9de2ecd2Grace Kloba + " Safari/530.17"; 266f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private static final String IPHONE_USERAGENT = 267b4f33445b8106f550ade837362c678cf9de2ecd2Grace Kloba "Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_0 like Mac OS X; en-us)" 268b4f33445b8106f550ade837362c678cf9de2ecd2Grace Kloba + " AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0" 269b4f33445b8106f550ade837362c678cf9de2ecd2Grace Kloba + " Mobile/7A341 Safari/528.16"; 270f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private static Locale sLocale; 271f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private static Object sLockForLocaleSettings; 272f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 27354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 27454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Package constructor to prevent clients from creating a new settings 27554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * instance. 27654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 2770d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba WebSettings(Context context, WebView webview) { 278f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mEventHandler = new EventHandler(); 279f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mContext = context; 2800d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba mWebView = webview; 281c27d9b5341b29c1b58c882f0a04b4c519d8a9853Daisuke Miyakawa mDefaultTextEncoding = context.getString(com.android.internal. 282c27d9b5341b29c1b58c882f0a04b4c519d8a9853Daisuke Miyakawa R.string.default_text_encoding); 283f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 284f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (sLockForLocaleSettings == null) { 285f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project sLockForLocaleSettings = new Object(); 286f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project sLocale = Locale.getDefault(); 287f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 288f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mAcceptLanguage = getCurrentAcceptLanguage(); 289f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mUserAgent = getCurrentUserAgent(); 290f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mUseDefaultUserAgent = true; 291f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 292c39a6e0c51e182338deb8b63d07933b585134929The Android Open Source Project mBlockNetworkLoads = mContext.checkPermission( 293c39a6e0c51e182338deb8b63d07933b585134929The Android Open Source Project "android.permission.INTERNET", android.os.Process.myPid(), 294c39a6e0c51e182338deb8b63d07933b585134929The Android Open Source Project android.os.Process.myUid()) != PackageManager.PERMISSION_GRANTED; 295f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 296f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 297f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 298f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Looks at sLocale and returns current AcceptLanguage String. 299f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @return Current AcceptLanguage String. 300f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 301f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private String getCurrentAcceptLanguage() { 302f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project Locale locale; 303f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project synchronized(sLockForLocaleSettings) { 304f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project locale = sLocale; 305f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 306f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project StringBuffer buffer = new StringBuffer(); 307f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String language = locale.getLanguage(); 308f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (language != null) { 309f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(language); 310f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String country = locale.getCountry(); 311f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (country != null) { 312f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append("-"); 313f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(country); 31454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 315f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 316f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (!locale.equals(Locale.US)) { 317f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(", "); 318f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project java.util.Locale us = Locale.US; 319f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (us.getLanguage() != null) { 320f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(us.getLanguage()); 321f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String country = us.getCountry(); 32254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (country != null) { 323f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append("-"); 324f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(country); 32554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 32654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 327f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 328f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 329f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return buffer.toString(); 330f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 331f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 332f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 333f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Looks at sLocale and mContext and returns current UserAgent String. 334f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @return Current UserAgent String. 335f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 336f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private synchronized String getCurrentUserAgent() { 337f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project Locale locale; 338f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project synchronized(sLockForLocaleSettings) { 339f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project locale = sLocale; 340f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 341f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project StringBuffer buffer = new StringBuffer(); 342f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project // Add version 343f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String version = Build.VERSION.RELEASE; 344f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (version.length() > 0) { 345f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(version); 346f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else { 347f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project // default to "1.0" 348f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append("1.0"); 349f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 350f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append("; "); 351f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String language = locale.getLanguage(); 352f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (language != null) { 353f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(language.toLowerCase()); 354f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String country = locale.getCountry(); 355f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (country != null) { 356f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append("-"); 357f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append(country.toLowerCase()); 35854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 359f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else { 360f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project // default to "en" 361f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project buffer.append("en"); 36254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 363ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba // add the model for the release build 364ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba if ("REL".equals(Build.VERSION.CODENAME)) { 365ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba final String model = Build.MODEL; 366ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba if (model.length() > 0) { 367ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba buffer.append("; "); 368ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba buffer.append(model); 369ce761d3219d1a091e6177ff852d9f0636777f04fGrace Kloba } 3709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 3719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project final String id = Build.ID; 3729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (id.length() > 0) { 3739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project buffer.append(" Build/"); 3749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project buffer.append(id); 375f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 376f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project final String base = mContext.getResources().getText( 377f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project com.android.internal.R.string.web_user_agent).toString(); 378f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return String.format(base, buffer); 37954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 380f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 38154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 38254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Enables dumping the pages navigation cache to a text file. 38354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 38454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setNavDump(boolean enabled) { 38554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mNavDump = enabled; 38654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 38754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 38854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 38954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Returns true if dumping the navigation cache is enabled. 39054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 39154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public boolean getNavDump() { 39254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mNavDump; 39354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 39454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 39554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 39654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set whether the WebView supports zoom 39754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 39854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setSupportZoom(boolean support) { 39954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSupportZoom = support; 40054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 40154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 40254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 40354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Returns whether the WebView supports zoom 40454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 40554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public boolean supportZoom() { 40654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mSupportZoom; 40754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 40854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 40954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 410105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project * Sets whether the zoom mechanism built into WebView is used. 411105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project */ 412105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project public void setBuiltInZoomControls(boolean enabled) { 413105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project mBuiltInZoomControls = enabled; 414105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project } 415105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project 416105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project /** 417105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project * Returns true if the zoom mechanism built into WebView is being used. 418105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project */ 419105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project public boolean getBuiltInZoomControls() { 420105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project return mBuiltInZoomControls; 421105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project } 422105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project 423105925376f8d0f6b318c9938c7b83ef7fef094daThe Android Open Source Project /** 424f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Enable or disable file access within WebView. File access is enabled by 425f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * default. 426f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 427f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public void setAllowFileAccess(boolean allow) { 428f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mAllowFileAccess = allow; 429f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 430f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 431f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 432f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Returns true if this WebView supports file access. 433f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 434f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public boolean getAllowFileAccess() { 435f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return mAllowFileAccess; 436f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 437f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 438f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 439e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba * Set whether the WebView loads a page with overview mode. 440e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba * @hide Pending API council approval 441e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba */ 442e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba public void setLoadWithOverviewMode(boolean overview) { 443e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba mLoadWithOverviewMode = overview; 444e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba } 445e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba 446e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba /** 447e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba * Returns true if this WebView loads page with overview mode 448e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba * @hide Pending API council approval 449e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba */ 450e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba public boolean getLoadWithOverviewMode() { 451e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba return mLoadWithOverviewMode; 452e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba } 453e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba 454e397a88e4fd65ee7d346f63a43e6608dba943ee9Grace Kloba /** 45554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Store whether the WebView is saving form data. 45654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 45754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setSaveFormData(boolean save) { 45854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSaveFormData = save; 45954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 46054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 46154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 46254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Return whether the WebView is saving form data. 46354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 46454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public boolean getSaveFormData() { 46554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mSaveFormData; 46654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 46754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 46854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 46954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Store whether the WebView is saving password. 47054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 47154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setSavePassword(boolean save) { 47254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSavePassword = save; 47354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 47454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 47554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 47654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Return whether the WebView is saving password. 47754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 47854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public boolean getSavePassword() { 47954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mSavePassword; 48054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 48154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 48254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 48354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the text size of the page. 48454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param t A TextSize value for increasing or decreasing the text. 48554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @see WebSettings.TextSize 48654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 48754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setTextSize(TextSize t) { 4889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project if (WebView.mLogEvent && mTextSize != t ) { 4899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Checkin.updateStats(mContext.getContentResolver(), 4909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project Checkin.Stats.Tag.BROWSER_TEXT_SIZE_CHANGE, 1, 0.0); 4919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project } 49254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mTextSize = t; 49354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 49454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 49554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 49654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 49754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Get the text size of the page. 49854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return A TextSize enum value describing the text size. 49954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @see WebSettings.TextSize 50054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 50154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized TextSize getTextSize() { 50254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mTextSize; 50354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 50454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 50554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 5060d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * Set the default zoom density of the page. This should be called from UI 5070d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * thread. 5080d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @param zoom A ZoomDensity value 5090d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @see WebSettings.ZoomDensity 5100d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @hide Pending API council approval 5110d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba */ 5120d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba public void setDefaultZoom(ZoomDensity zoom) { 5130d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba if (mDefaultZoom != zoom) { 5140d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba mDefaultZoom = zoom; 5150d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba mWebView.updateDefaultZoomDensity(zoom.value); 5160d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba } 5170d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba } 5180d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba 5190d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba /** 5200d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * Get the default zoom density of the page. This should be called from UI 5210d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * thread. 5220d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @return A ZoomDensity value 5230d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @see WebSettings.ZoomDensity 5240d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba * @hide Pending API council approval 5250d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba */ 5260d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba public ZoomDensity getDefaultZoom() { 5270d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba return mDefaultZoom; 5280d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba } 5290d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba 5300d8b77c2453d0e597f94e39212e4bfeed8affffaGrace Kloba /** 53154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Enables using light touches to make a selection and activate mouseovers. 53254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 53354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setLightTouchEnabled(boolean enabled) { 53454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mLightTouchEnabled = enabled; 53554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 53654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 53754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 53854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Returns true if light touches are enabled. 53954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 54054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public boolean getLightTouchEnabled() { 54154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mLightTouchEnabled; 54254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 54354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 54454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 545adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * @deprecated This setting controlled a rendering optimization 546adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * that is no longer present. Setting it now has no effect. 54754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 548adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn @Deprecated 54954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setUseDoubleTree(boolean use) { 550adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn return; 55154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 55254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 55354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 554adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * @deprecated This setting controlled a rendering optimization 555adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * that is no longer present. Setting it now has no effect. 55654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 557adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn @Deprecated 55854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getUseDoubleTree() { 559adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn return false; 56054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 56154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 56254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 56354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView about user-agent string. 56454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param ua 0 if the WebView should use an Android user-agent string, 56554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * 1 if the WebView should use a desktop user-agent string. 566f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * 567f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @deprecated Please use setUserAgentString instead. 56854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 569f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project @Deprecated 57054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setUserAgent(int ua) { 571f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project String uaString = null; 572f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (ua == 1) { 573f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (DESKTOP_USERAGENT.equals(mUserAgent)) { 574f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return; // do nothing 575f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else { 576f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project uaString = DESKTOP_USERAGENT; 577f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 578f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else if (ua == 2) { 579f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (IPHONE_USERAGENT.equals(mUserAgent)) { 580f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return; // do nothing 581f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else { 582f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project uaString = IPHONE_USERAGENT; 583f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 584f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else if (ua != 0) { 585f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return; // do nothing 58654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 587f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project setUserAgentString(uaString); 58854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 58954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 59054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 59154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Return user-agent as int 59254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return int 0 if the WebView is using an Android user-agent string. 59354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * 1 if the WebView is using a desktop user-agent string. 594f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * -1 if the WebView is using user defined user-agent string. 595f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * 596f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @deprecated Please use getUserAgentString instead. 59754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 598f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project @Deprecated 59954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized int getUserAgent() { 60054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (DESKTOP_USERAGENT.equals(mUserAgent)) { 60154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return 1; 60254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } else if (IPHONE_USERAGENT.equals(mUserAgent)) { 60354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return 2; 604f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else if (mUseDefaultUserAgent) { 605f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return 0; 60654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 607f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return -1; 60854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 60954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 61054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 61154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView to use the wide viewport 61254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 61354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setUseWideViewPort(boolean use) { 61454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mUseWideViewport != use) { 61554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mUseWideViewport = use; 61654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 61754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 61854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 61954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 62054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 62154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if the WebView is using a wide viewport 62254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 62354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getUseWideViewPort() { 62454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mUseWideViewport; 62554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 62654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 62754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 62854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView whether it supports multiple windows. TRUE means 62954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * that {@link WebChromeClient#onCreateWindow(WebView, boolean, 63054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * boolean, Message)} is implemented by the host application. 63154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 63254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setSupportMultipleWindows(boolean support) { 63354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mSupportMultipleWindows != support) { 63454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSupportMultipleWindows = support; 63554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 63654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 63754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 63854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 63954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 64054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if the WebView is supporting multiple windows. This means 64154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * that {@link WebChromeClient#onCreateWindow(WebView, boolean, 64254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * boolean, Message)} is implemented by the host application. 64354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 64454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean supportMultipleWindows() { 64554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mSupportMultipleWindows; 64654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 64754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 64854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 64954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the underlying layout algorithm. This will cause a relayout of the 65054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * WebView. 65154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param l A LayoutAlgorithm enum specifying the algorithm to use. 65254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @see WebSettings.LayoutAlgorithm 65354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 65454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setLayoutAlgorithm(LayoutAlgorithm l) { 65554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // XXX: This will only be affective if libwebcore was built with 65654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // ANDROID_LAYOUT defined. 65754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mLayoutAlgorithm != l) { 65854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mLayoutAlgorithm = l; 65954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 66054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 66154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 66254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 66354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 664adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Return the current layout algorithm. The default is NARROW_COLUMNS. 66554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return LayoutAlgorithm enum value describing the layout algorithm 66654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * being used. 66754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @see WebSettings.LayoutAlgorithm 66854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 66954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized LayoutAlgorithm getLayoutAlgorithm() { 67054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mLayoutAlgorithm; 67154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 67254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 67354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 67454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the standard font family name. 67554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param font A font family name. 67654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 67754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setStandardFontFamily(String font) { 67854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (font != null && !font.equals(mStandardFontFamily)) { 67954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mStandardFontFamily = font; 68054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 68154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 68254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 68354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 68454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 685adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the standard font family name. The default is "sans-serif". 68654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The standard font family name as a string. 68754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 68854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getStandardFontFamily() { 68954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mStandardFontFamily; 69054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 69154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 69254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 69354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the fixed font family name. 69454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param font A font family name. 69554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 69654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setFixedFontFamily(String font) { 69754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (font != null && !font.equals(mFixedFontFamily)) { 69854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mFixedFontFamily = font; 69954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 70054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 70154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 70254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 70354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 704adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the fixed font family name. The default is "monospace". 70554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The fixed font family name as a string. 70654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 70754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getFixedFontFamily() { 70854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mFixedFontFamily; 70954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 71054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 71154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 71254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the sans-serif font family name. 71354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param font A font family name. 71454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 71554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setSansSerifFontFamily(String font) { 71654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (font != null && !font.equals(mSansSerifFontFamily)) { 71754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSansSerifFontFamily = font; 71854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 71954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 72054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 72154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 72254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 72354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Get the sans-serif font family name. 72454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The sans-serif font family name as a string. 72554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 72654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getSansSerifFontFamily() { 72754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mSansSerifFontFamily; 72854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 72954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 73054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 731adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Set the serif font family name. The default is "sans-serif". 73254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param font A font family name. 73354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 73454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setSerifFontFamily(String font) { 73554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (font != null && !font.equals(mSerifFontFamily)) { 73654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSerifFontFamily = font; 73754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 73854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 73954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 74054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 74154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 742adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the serif font family name. The default is "serif". 74354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The serif font family name as a string. 74454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 74554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getSerifFontFamily() { 74654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mSerifFontFamily; 74754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 74854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 74954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 75054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the cursive font family name. 75154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param font A font family name. 75254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 75354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setCursiveFontFamily(String font) { 75454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (font != null && !font.equals(mCursiveFontFamily)) { 75554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mCursiveFontFamily = font; 75654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 75754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 75854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 75954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 76054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 761adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the cursive font family name. The default is "cursive". 76254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The cursive font family name as a string. 76354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 76454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getCursiveFontFamily() { 76554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mCursiveFontFamily; 76654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 76754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 76854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 76954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the fantasy font family name. 77054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param font A font family name. 77154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 77254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setFantasyFontFamily(String font) { 77354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (font != null && !font.equals(mFantasyFontFamily)) { 77454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mFantasyFontFamily = font; 77554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 77654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 77754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 77854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 77954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 780adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the fantasy font family name. The default is "fantasy". 78154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The fantasy font family name as a string. 78254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 78354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getFantasyFontFamily() { 78454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mFantasyFontFamily; 78554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 78654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 78754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 78854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the minimum font size. 78954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param size A non-negative integer between 1 and 72. 79054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Any number outside the specified range will be pinned. 79154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 79254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setMinimumFontSize(int size) { 79354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project size = pin(size); 79454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mMinimumFontSize != size) { 79554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mMinimumFontSize = size; 79654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 79754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 79854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 79954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 80054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 801adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the minimum font size. The default is 8. 80254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return A non-negative integer between 1 and 72. 80354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 80454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized int getMinimumFontSize() { 80554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mMinimumFontSize; 80654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 80754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 80854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 80954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the minimum logical font size. 81054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param size A non-negative integer between 1 and 72. 81154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Any number outside the specified range will be pinned. 81254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 81354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setMinimumLogicalFontSize(int size) { 81454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project size = pin(size); 81554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mMinimumLogicalFontSize != size) { 81654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mMinimumLogicalFontSize = size; 81754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 81854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 81954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 82054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 82154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 822adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the minimum logical font size. The default is 8. 82354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return A non-negative integer between 1 and 72. 82454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 82554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized int getMinimumLogicalFontSize() { 82654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mMinimumLogicalFontSize; 82754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 82854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 82954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 83054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the default font size. 83154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param size A non-negative integer between 1 and 72. 83254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Any number outside the specified range will be pinned. 83354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 83454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setDefaultFontSize(int size) { 83554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project size = pin(size); 83654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mDefaultFontSize != size) { 83754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mDefaultFontSize = size; 83854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 83954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 84054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 84154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 84254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 843adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the default font size. The default is 16. 84454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return A non-negative integer between 1 and 72. 84554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 84654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized int getDefaultFontSize() { 84754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mDefaultFontSize; 84854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 84954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 85054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 85154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the default fixed font size. 85254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param size A non-negative integer between 1 and 72. 85354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Any number outside the specified range will be pinned. 85454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 85554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setDefaultFixedFontSize(int size) { 85654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project size = pin(size); 85754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mDefaultFixedFontSize != size) { 85854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mDefaultFixedFontSize = size; 85954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 86054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 86154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 86254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 86354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 864adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the default fixed font size. The default is 16. 86554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return A non-negative integer between 1 and 72. 86654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 86754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized int getDefaultFixedFontSize() { 86854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mDefaultFixedFontSize; 86954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 87054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 87154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 87254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView to load image resources automatically. 87354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param flag True if the WebView should load images automatically. 87454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 87554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setLoadsImagesAutomatically(boolean flag) { 87654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mLoadsImagesAutomatically != flag) { 87754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mLoadsImagesAutomatically = flag; 87854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 87954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 88054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 88154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 88254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 88354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Return true if the WebView will load image resources automatically. 884adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * The default is true. 88554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if the WebView loads images automatically. 88654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 88754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getLoadsImagesAutomatically() { 88854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mLoadsImagesAutomatically; 88954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 89054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 89154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 89254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView to block network image. This is only checked when 89354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * getLoadsImagesAutomatically() is true. 89454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param flag True if the WebView should block network image 89554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 89654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setBlockNetworkImage(boolean flag) { 89754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mBlockNetworkImage != flag) { 89854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mBlockNetworkImage = flag; 89954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 90054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 90154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 90254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 90354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 904adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Return true if the WebView will block network image. The default is false. 90554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if the WebView blocks network image. 90654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 90754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getBlockNetworkImage() { 90854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mBlockNetworkImage; 90954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 910adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn 911f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 912f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @hide 913adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Tell the WebView to block all network load requests. 914f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @param flag True if the WebView should block all network loads 915f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 916f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public synchronized void setBlockNetworkLoads(boolean flag) { 917f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (mBlockNetworkLoads != flag) { 918f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mBlockNetworkLoads = flag; 919f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project verifyNetworkAccess(); 920f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 921f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 922f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 923f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 924f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @hide 925f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Return true if the WebView will block all network loads. 926adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * The default is false. 927f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @return True if the WebView blocks all network loads. 928f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 929f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public synchronized boolean getBlockNetworkLoads() { 930f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return mBlockNetworkLoads; 931f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 932adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn 933adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn 934f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project private void verifyNetworkAccess() { 935f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (!mBlockNetworkLoads) { 936f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (mContext.checkPermission("android.permission.INTERNET", 937c39a6e0c51e182338deb8b63d07933b585134929The Android Open Source Project android.os.Process.myPid(), android.os.Process.myUid()) != 938f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project PackageManager.PERMISSION_GRANTED) { 939f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project throw new SecurityException 940f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project ("Permission denied - " + 941f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project "application missing INTERNET permission"); 942f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 943f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 944f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 94554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 94654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 94754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView to enable javascript execution. 94854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param flag True if the WebView should execute javascript. 94954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 95054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setJavaScriptEnabled(boolean flag) { 95154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mJavaScriptEnabled != flag) { 95254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mJavaScriptEnabled = flag; 95354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 95454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 95554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 95654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 95754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 95854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView to enable plugins. 95954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param flag True if the WebView should load plugins. 96054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 96154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setPluginsEnabled(boolean flag) { 96254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mPluginsEnabled != flag) { 96354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mPluginsEnabled = flag; 96454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 96554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 96654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 96754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 96854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 969658ab7d787f64987d7c45aae08e5a12a073afe78Grace Kloba * TODO: need to add @Deprecated 97054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 97154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setPluginsPath(String pluginsPath) { 97254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 97354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 97454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 9757df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * Set the path to where database storage API databases should be saved. 9767df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * This will update WebCore when the Sync runs in the C++ side. 9777df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * @param databasePath String path to the directory where databases should 9787df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * be saved. May be the empty string but should never be null. 9797df1985e86635af006be3dfa65987d60e290b5deBen Murdoch */ 9807df1985e86635af006be3dfa65987d60e290b5deBen Murdoch public synchronized void setDatabasePath(String databasePath) { 9817df1985e86635af006be3dfa65987d60e290b5deBen Murdoch if (databasePath != null && !databasePath.equals(mDatabasePath)) { 9827df1985e86635af006be3dfa65987d60e290b5deBen Murdoch mDatabasePath = databasePath; 9837df1985e86635af006be3dfa65987d60e290b5deBen Murdoch postSync(); 9847df1985e86635af006be3dfa65987d60e290b5deBen Murdoch } 9857df1985e86635af006be3dfa65987d60e290b5deBen Murdoch } 9867df1985e86635af006be3dfa65987d60e290b5deBen Murdoch 9877df1985e86635af006be3dfa65987d60e290b5deBen Murdoch /** 9889d3273f62288fa54536a3928383588398ca2d029Steve Block * Set the path where the Geolocation permissions database should be saved. 9899d3273f62288fa54536a3928383588398ca2d029Steve Block * This will update WebCore when the Sync runs in the C++ side. 9909d3273f62288fa54536a3928383588398ca2d029Steve Block * @param databasePath String path to the directory where the Geolocation 9919d3273f62288fa54536a3928383588398ca2d029Steve Block * permissions database should be saved. May be the empty string but 9929d3273f62288fa54536a3928383588398ca2d029Steve Block * should never be null. 9939d3273f62288fa54536a3928383588398ca2d029Steve Block * @hide pending api council approval 9949d3273f62288fa54536a3928383588398ca2d029Steve Block */ 9959d3273f62288fa54536a3928383588398ca2d029Steve Block public synchronized void setGeolocationDatabasePath(String databasePath) { 9969d3273f62288fa54536a3928383588398ca2d029Steve Block if (databasePath != null && !databasePath.equals(mDatabasePath)) { 9979d3273f62288fa54536a3928383588398ca2d029Steve Block mGeolocationDatabasePath = databasePath; 9989d3273f62288fa54536a3928383588398ca2d029Steve Block postSync(); 9999d3273f62288fa54536a3928383588398ca2d029Steve Block } 10009d3273f62288fa54536a3928383588398ca2d029Steve Block } 10019d3273f62288fa54536a3928383588398ca2d029Steve Block 10029d3273f62288fa54536a3928383588398ca2d029Steve Block /** 100360a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * Tell the WebView to enable Application Caches API. 100460a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * @param flag True if the WebView should enable Application Caches. 100560a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * @hide pending api council approval 100660a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu */ 100760a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu public synchronized void setAppCacheEnabled(boolean flag) { 100860a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu if (mAppCacheEnabled != flag) { 100960a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu mAppCacheEnabled = flag; 101060a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu postSync(); 101160a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu } 101260a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu } 101360a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu 101460a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu /** 101560a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * Set a custom path to the Application Caches files. The client 101660a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * must ensure it exists before this call. 101760a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * @param appCachePath String path to the directory containing Application 101860a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * Caches files. The appCache path can be the empty string but should not 101960a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * be null. Passing null for this parameter will result in a no-op. 102060a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu * @hide pending api council approval 102160a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu */ 102260a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu public synchronized void setAppCachePath(String appCachePath) { 102360a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu if (appCachePath != null && !appCachePath.equals(mAppCachePath)) { 102460a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu mAppCachePath = appCachePath; 102560a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu postSync(); 102660a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu } 102760a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu } 102860a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu 102960a9a7d05577a65c8904fcb5f32b6a7a10886a13Andrei Popescu /** 10301c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu * Set the maximum size for the Application Caches content. 10311c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu * @param appCacheMaxSize the maximum size in bytes. 10321c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu * 10331c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu * @hide pending api council approval 10341c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu */ 10351c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu public synchronized void setAppCacheMaxSize(long appCacheMaxSize) { 10361c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu if (appCacheMaxSize != mAppCacheMaxSize) { 10371c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu mAppCacheMaxSize = appCacheMaxSize; 10381c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu postSync(); 10391c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu } 10401c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu } 10411c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu 10421c829208eadf175ad4600e70a14013b50a20adfeAndrei Popescu /** 10437df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * Set whether the database storage API is enabled. 10447df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * @param flag boolean True if the WebView should use the database storage 10457df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * API. 10467df1985e86635af006be3dfa65987d60e290b5deBen Murdoch */ 10477df1985e86635af006be3dfa65987d60e290b5deBen Murdoch public synchronized void setDatabaseEnabled(boolean flag) { 10487df1985e86635af006be3dfa65987d60e290b5deBen Murdoch if (mDatabaseEnabled != flag) { 10497df1985e86635af006be3dfa65987d60e290b5deBen Murdoch mDatabaseEnabled = flag; 10507df1985e86635af006be3dfa65987d60e290b5deBen Murdoch postSync(); 10517df1985e86635af006be3dfa65987d60e290b5deBen Murdoch } 10527df1985e86635af006be3dfa65987d60e290b5deBen Murdoch } 10537df1985e86635af006be3dfa65987d60e290b5deBen Murdoch 10547df1985e86635af006be3dfa65987d60e290b5deBen Murdoch /** 1055274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * Set whether the DOM storage API is enabled. 1056274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * @param flag boolean True if the WebView should use the DOM storage 1057274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * API. 1058274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * @hide pending API council. 1059274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch */ 1060274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch public synchronized void setDomStorageEnabled(boolean flag) { 1061274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch if (mDomStorageEnabled != flag) { 1062274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch mDomStorageEnabled = flag; 1063274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch postSync(); 1064274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch } 1065274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch } 1066274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch 1067274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch /** 1068274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * Returns true if the DOM Storage API's are enabled. 1069274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * @return True if the DOM Storage API's are enabled. 1070274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch * @hide pending API council. 1071274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch */ 1072274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch public synchronized boolean getDomStorageEnabled() { 1073274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch return mDomStorageEnabled; 1074274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch } 1075274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch 1076274680d9b8fce08f31c23dda796ecec937c942deBen Murdoch /** 10777df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * Return the path to where database storage API databases are saved for 10787df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * the current WebView. 10797df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * @return the String path to the database storage API databases. 10807df1985e86635af006be3dfa65987d60e290b5deBen Murdoch */ 10817df1985e86635af006be3dfa65987d60e290b5deBen Murdoch public synchronized String getDatabasePath() { 10827df1985e86635af006be3dfa65987d60e290b5deBen Murdoch return mDatabasePath; 10837df1985e86635af006be3dfa65987d60e290b5deBen Murdoch } 10847df1985e86635af006be3dfa65987d60e290b5deBen Murdoch 10857df1985e86635af006be3dfa65987d60e290b5deBen Murdoch /** 10867df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * Returns true if database storage API is enabled. 10877df1985e86635af006be3dfa65987d60e290b5deBen Murdoch * @return True if the database storage API is enabled. 10887df1985e86635af006be3dfa65987d60e290b5deBen Murdoch */ 10897df1985e86635af006be3dfa65987d60e290b5deBen Murdoch public synchronized boolean getDatabaseEnabled() { 10907df1985e86635af006be3dfa65987d60e290b5deBen Murdoch return mDatabaseEnabled; 10917df1985e86635af006be3dfa65987d60e290b5deBen Murdoch } 10927df1985e86635af006be3dfa65987d60e290b5deBen Murdoch 10937df1985e86635af006be3dfa65987d60e290b5deBen Murdoch /** 1094c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu * Tell the WebView to enable WebWorkers API. 1095c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu * @param flag True if the WebView should enable WebWorkers. 1096c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu * Note that this flag only affects V8. JSC does not have 1097c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu * an equivalent setting. 1098c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu * @hide pending api council approval 1099c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu */ 1100c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu public synchronized void setWorkersEnabled(boolean flag) { 1101c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu if (mWorkersEnabled != flag) { 1102c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu mWorkersEnabled = flag; 1103c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu postSync(); 1104c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu } 1105c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu } 1106c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu 1107c27a9acb3b7ec4d1845b623cc167e0b62b1d0585Andrei Popescu /** 110806cd751b052e65c359b16cce0570b6fab305eb89Steve Block * Sets whether Geolocation is enabled. 110906cd751b052e65c359b16cce0570b6fab305eb89Steve Block * @param flag Whether Geolocation should be enabled. 111006cd751b052e65c359b16cce0570b6fab305eb89Steve Block * @hide pending api council approval 111106cd751b052e65c359b16cce0570b6fab305eb89Steve Block */ 111206cd751b052e65c359b16cce0570b6fab305eb89Steve Block public synchronized void setGeolocationEnabled(boolean flag) { 111306cd751b052e65c359b16cce0570b6fab305eb89Steve Block if (mGeolocationEnabled != flag) { 111406cd751b052e65c359b16cce0570b6fab305eb89Steve Block mGeolocationEnabled = flag; 111506cd751b052e65c359b16cce0570b6fab305eb89Steve Block postSync(); 111606cd751b052e65c359b16cce0570b6fab305eb89Steve Block } 111706cd751b052e65c359b16cce0570b6fab305eb89Steve Block } 111806cd751b052e65c359b16cce0570b6fab305eb89Steve Block 111906cd751b052e65c359b16cce0570b6fab305eb89Steve Block /** 1120adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Return true if javascript is enabled. <b>Note: The default is false.</b> 112154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if javascript is enabled. 112254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 112354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getJavaScriptEnabled() { 112454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mJavaScriptEnabled; 112554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 112654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 112754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 112854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Return true if plugins are enabled. 112954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if plugins are enabled. 113054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 113154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getPluginsEnabled() { 113254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mPluginsEnabled; 113354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 113454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 113554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 1136658ab7d787f64987d7c45aae08e5a12a073afe78Grace Kloba * TODO: need to add @Deprecated 113754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 113854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getPluginsPath() { 1139658ab7d787f64987d7c45aae08e5a12a073afe78Grace Kloba return ""; 114054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 114154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 114254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 114354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell javascript to open windows automatically. This applies to the 114454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * javascript function window.open(). 114554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param flag True if javascript can open windows automatically. 114654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 114754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setJavaScriptCanOpenWindowsAutomatically( 114854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project boolean flag) { 114954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mJavaScriptCanOpenWindowsAutomatically != flag) { 115054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mJavaScriptCanOpenWindowsAutomatically = flag; 115154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 115254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 115354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 115454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 115554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 1156adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Return true if javascript can open windows automatically. The default 1157adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * is false. 115854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return True if javascript can open windows automatically during 115954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * window.open(). 116054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 116154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized boolean getJavaScriptCanOpenWindowsAutomatically() { 116254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mJavaScriptCanOpenWindowsAutomatically; 116354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 116454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 116554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 116654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the default text encoding name to use when decoding html pages. 116754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param encoding The text encoding name. 116854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 116954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setDefaultTextEncodingName(String encoding) { 117054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (encoding != null && !encoding.equals(mDefaultTextEncoding)) { 117154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mDefaultTextEncoding = encoding; 117254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project postSync(); 117354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 117454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 117554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 117654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 1177adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * Get the default text encoding name. The default is "Latin-1". 117854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @return The default text encoding name as a string. 117954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 118054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized String getDefaultTextEncodingName() { 118154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mDefaultTextEncoding; 118254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 118354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 1184f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 1185f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Set the WebView's user-agent string. If the string "ua" is null or empty, 1186f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * it will use the system default user-agent string. 1187f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 1188f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public synchronized void setUserAgentString(String ua) { 1189f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (ua == null || ua.length() == 0) { 1190f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project synchronized(sLockForLocaleSettings) { 1191f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project Locale currentLocale = Locale.getDefault(); 1192f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (!sLocale.equals(currentLocale)) { 1193f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project sLocale = currentLocale; 1194f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mAcceptLanguage = getCurrentAcceptLanguage(); 1195f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1196f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1197f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project ua = getCurrentUserAgent(); 1198f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mUseDefaultUserAgent = true; 1199f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } else { 1200f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mUseDefaultUserAgent = false; 1201f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1202f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 1203f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (!ua.equals(mUserAgent)) { 1204f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mUserAgent = ua; 1205f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project postSync(); 1206f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1207f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1208f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 1209f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 1210f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * Return the WebView's user-agent string. 1211f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 1212f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public synchronized String getUserAgentString() { 1213f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (DESKTOP_USERAGENT.equals(mUserAgent) || 1214f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project IPHONE_USERAGENT.equals(mUserAgent) || 1215f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project !mUseDefaultUserAgent) { 1216f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return mUserAgent; 1217f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1218f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 1219f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project boolean doPostSync = false; 1220f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project synchronized(sLockForLocaleSettings) { 1221f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project Locale currentLocale = Locale.getDefault(); 1222f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (!sLocale.equals(currentLocale)) { 1223f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project sLocale = currentLocale; 1224f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mUserAgent = getCurrentUserAgent(); 1225f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mAcceptLanguage = getCurrentAcceptLanguage(); 1226f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project doPostSync = true; 1227f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1228f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1229f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (doPostSync) { 1230f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project postSync(); 1231f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 123254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mUserAgent; 123354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 123454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 1235f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /* package api to grab the Accept Language string. */ 1236f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /*package*/ synchronized String getAcceptLanguage() { 1237f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project synchronized(sLockForLocaleSettings) { 1238f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project Locale currentLocale = Locale.getDefault(); 1239f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (!sLocale.equals(currentLocale)) { 1240f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project sLocale = currentLocale; 1241f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mAcceptLanguage = getCurrentAcceptLanguage(); 1242f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1243f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1244f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project return mAcceptLanguage; 1245f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1246f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 124754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 124854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Tell the WebView whether it needs to set a node to have focus when 124954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * {@link WebView#requestFocus(int, android.graphics.Rect)} is called. 125054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * 125154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param flag 125254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 125354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setNeedInitialFocus(boolean flag) { 125454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mNeedInitialFocus != flag) { 125554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mNeedInitialFocus = flag; 125654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 125754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 125854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 125954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /* Package api to get the choice whether it needs to set initial focus. */ 126054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /* package */ boolean getNeedInitialFocus() { 126154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mNeedInitialFocus; 126254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 126354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 126454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 126554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Set the priority of the Render thread. Unlike the other settings, this 1266adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * one only needs to be called once per process. The default is NORMAL. 1267adcd2ed8d24deddee528e96260d0ed673eeb261cMike Hearn * 126854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param priority RenderPriority, can be normal, high or low. 126954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 127054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public synchronized void setRenderPriority(RenderPriority priority) { 127154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mRenderPriority != priority) { 127254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mRenderPriority = priority; 127354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mEventHandler.sendMessage(Message.obtain(null, 127454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project EventHandler.PRIORITY)); 127554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 127654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 127754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 127854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 127954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Override the way the cache is used. The way the cache is used is based 128054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * on the navigation option. For a normal page load, the cache is checked 128154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * and content is re-validated as needed. When navigating back, content is 128254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * not revalidated, instead the content is just pulled from the cache. 128354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * This function allows the client to override this behavior. 128454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * @param mode One of the LOAD_ values. 128554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 128654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public void setCacheMode(int mode) { 128754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (mode != mOverrideCacheMode) { 128854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mOverrideCacheMode = mode; 128954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 129054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 129154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 129254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 129354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Return the current setting for overriding the cache mode. For a full 129454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * description, see the {@link #setCacheMode(int)} function. 129554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 129654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project public int getCacheMode() { 129754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return mOverrideCacheMode; 129854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 1299f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project 1300f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project /** 1301f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * If set, webkit alternately shrinks and expands images viewed outside 1302f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * of an HTML page to fit the screen. This conflicts with attempts by 1303f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * the UI to zoom in and out of an image, so it is set false by default. 1304f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * @param shrink Set true to let webkit shrink the standalone image to fit. 1305f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project * {@hide} 1306f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project */ 1307f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project public void setShrinksStandaloneImagesToFit(boolean shrink) { 1308f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project if (mShrinksStandaloneImagesToFit != shrink) { 1309f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project mShrinksStandaloneImagesToFit = shrink; 1310f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project postSync(); 1311f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 1312f013e1afd1e68af5e3b868c26a653bbfb39538f8The Android Open Source Project } 131354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 131454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /** 131554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Transfer messages from the queue to the new WebCoreThread. Called from 131654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * WebCore thread. 131754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */ 131854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /*package*/ 131954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project synchronized void syncSettingsAndCreateHandler(BrowserFrame frame) { 132054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mBrowserFrame = frame; 13212e5c150e746647a1ce5c10e1708debbf06c45ea7Derek Sollenberger if (DebugFlags.WEB_SETTINGS) { 132254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project junit.framework.Assert.assertTrue(frame.mNativeFrame != 0); 132354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 1324d875ce6dac3c2e9a671c121c80b40d2536cbb2afSteve Block sGoogleLocationSettingManager = new GoogleLocationSettingManager(mContext); 1325d875ce6dac3c2e9a671c121c80b40d2536cbb2afSteve Block sGoogleLocationSettingManager.start(); 132654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project nativeSync(frame.mNativeFrame); 132754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSyncPending = false; 132854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mEventHandler.createHandler(); 132954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 133054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 133154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private int pin(int size) { 133254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // FIXME: 72 is just an arbitrary max text size value. 133354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (size < 1) { 133454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return 1; 133554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } else if (size > 72) { 133654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return 72; 133754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 133854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project return size; 133954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 134054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 134154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project /* Post a SYNC message to handle syncing the native settings. */ 134254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private synchronized void postSync() { 134354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Only post if a sync is not pending 134454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project if (!mSyncPending) { 134554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project mSyncPending = mEventHandler.sendMessage( 134654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project Message.obtain(null, EventHandler.SYNC)); 134754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 134854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project } 134954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project 135054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project // Synchronize the native and java settings. 135154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project private native void nativeSync(int nativeFrame); 135254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project} 1353