first version of custom fullscreen preference (fix for #594)

This commit is contained in:
Philipp Schaefer 2013-10-28 20:14:25 +01:00
parent 7230e2f44a
commit 8d1eb6e0b7
5 changed files with 153 additions and 63 deletions

View File

@ -79,14 +79,16 @@
<string name="pref_user_loc_sum">Show users position on map</string> <string name="pref_user_loc_sum">Show users position on map</string>
<string name="pref_user_zoom">Show zoom control</string> <string name="pref_user_zoom">Show zoom control</string>
<string name="pref_user_zoom_sum">Shows +/- buttons even on multitouch capable devices.</string> <string name="pref_user_zoom_sum">Shows +/- buttons even on multitouch capable devices.</string>
<string name="pref_fullscreen_actionbar">Hide Action Bar in fullscreen mode</string> <string name="pref_fullscreen">Hide in fullscreen mode</string>
<string name="pref_fullscreen_actionbar_sum">Nice for screenshots. Note: IITCm can still be controlled via the Navigation Drawers</string> <string name="pref_fullscreen_sum">Which elements should be hidden in fullscreen mode.
Note: IITCm can still be controlled via the Navigation Drawers</string>
<string name="pref_force_desktop">Force desktop mode</string> <string name="pref_force_desktop">Force desktop mode</string>
<string name="pref_force_desktop_sum">Nice for tablets, looks awful on smartphones</string> <string name="pref_force_desktop_sum">Nice for tablets, looks awful on smartphones</string>
<string name="pref_force_https">Force https</string> <string name="pref_force_https">Force https</string>
<string name="pref_force_https_sum">Disabling may improve performance</string> <string name="pref_force_https_sum">Disabling may improve performance</string>
<string name="pref_external_storage">Move cache to external storage</string> <string name="pref_external_storage">Move cache to external storage</string>
<string name="pref_external_storage_sum">Restart required! Write cache to sdCard. Saves internal storage. External storage has to be mounted.</string> <string name="pref_external_storage_sum">Restart required! Write cache to sdCard. Saves internal storage.
External storage has to be mounted.</string>
<string name="pref_press_twice_to_exit">Press back button twice to exit</string> <string name="pref_press_twice_to_exit">Press back button twice to exit</string>
<string name="pref_press_twice_to_exit_sum">Avoids accidental exits</string> <string name="pref_press_twice_to_exit_sum">Avoids accidental exits</string>
<string name="pref_advanced_options">Advanced settings</string> <string name="pref_advanced_options">Advanced settings</string>
@ -106,6 +108,20 @@
<string name="pref_caching">Aggressive Caching</string> <string name="pref_caching">Aggressive Caching</string>
<string name="pref_caching_sum">Prefer cached values even if they are expired…saves traffic but <string name="pref_caching_sum">Prefer cached values even if they are expired…saves traffic but
may result in login issues</string> may result in login issues</string>
<string-array name="pref_hide_fullscreen">
<item>System Bar</item>
<item>Action Bar</item>
<item>IITC Status Bar</item>
<item>Navigation Bar</item>
</string-array>
<string-array name="pref_hide_fullscreen_vals">
<item>2</item>
<item>4</item>
<item>8</item>
<item>16</item>
</string-array>
<string-array name="pref_caching_array"> <string-array name="pref_caching_array">
<item>Always</item> <item>Always</item>
<item>Mobile data only (default)</item> <item>Mobile data only (default)</item>

View File

@ -24,11 +24,12 @@
android:key="pref_user_zoom" android:key="pref_user_zoom"
android:summary="@string/pref_user_zoom_sum" android:summary="@string/pref_user_zoom_sum"
android:title="@string/pref_user_zoom"/> android:title="@string/pref_user_zoom"/>
<CheckBoxPreference <MultiSelectListPreference
android:defaultValue="true" android:key="pref_fullscreen"
android:key="pref_fullscreen_actionbar" android:summary="@string/pref_fullscreen_sum"
android:summary="@string/pref_fullscreen_actionbar_sum" android:title="@string/pref_fullscreen"
android:title="@string/pref_fullscreen_actionbar"/> android:entries="@array/pref_hide_fullscreen"
android:entryValues="@array/pref_hide_fullscreen_vals"/>
<CheckBoxPreference <CheckBoxPreference
android:defaultValue="false" android:defaultValue="false"
android:key="pref_force_desktop" android:key="pref_force_desktop"

View File

@ -22,7 +22,6 @@ import android.view.Menu;
import android.view.MenuItem; import android.view.MenuItem;
import android.view.View; import android.view.View;
import android.view.Window; import android.view.Window;
import android.view.WindowManager;
import android.webkit.CookieManager; import android.webkit.CookieManager;
import android.webkit.WebView; import android.webkit.WebView;
import android.widget.SearchView; import android.widget.SearchView;
@ -45,7 +44,6 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
private boolean mIsLocEnabled = false; private boolean mIsLocEnabled = false;
private Location mLastLocation = null; private Location mLastLocation = null;
private LocationManager mLocMngr = null; private LocationManager mLocMngr = null;
private boolean mFullscreenMode = false;
private IITC_DeviceAccountLogin mLogin; private IITC_DeviceAccountLogin mLogin;
private MenuItem mSearchMenuItem; private MenuItem mSearchMenuItem;
private boolean mDesktopMode = false; private boolean mDesktopMode = false;
@ -72,11 +70,6 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
setContentView(R.layout.activity_main); setContentView(R.layout.activity_main);
mIitcWebView = (IITC_WebView) findViewById(R.id.iitc_webview); mIitcWebView = (IITC_WebView) findViewById(R.id.iitc_webview);
// pass ActionBar to helper because we deprecated getActionBar
mNavigationHelper = new IITC_NavigationHelper(this, super.getActionBar());
mMapSettings = new IITC_MapSettings(this);
// do something if user changed something in the settings // do something if user changed something in the settings
mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this); mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(this);
mSharedPrefs.registerOnSharedPreferenceChangeListener(this); mSharedPrefs.registerOnSharedPreferenceChangeListener(this);
@ -87,6 +80,9 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
// enable/disable advance menu // enable/disable advance menu
mAdvancedMenu = mSharedPrefs.getBoolean("pref_advanced_menu", false); mAdvancedMenu = mSharedPrefs.getBoolean("pref_advanced_menu", false);
// get fullscreen status from settings
mIitcWebView.updateFullscreenStatus();
// Acquire a reference to the system Location Manager // Acquire a reference to the system Location Manager
mLocMngr = (LocationManager) this mLocMngr = (LocationManager) this
.getSystemService(Context.LOCATION_SERVICE); .getSystemService(Context.LOCATION_SERVICE);
@ -101,6 +97,12 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
this); this);
} }
// pass ActionBar to helper because we deprecated getActionBar
mNavigationHelper = new IITC_NavigationHelper(this, super.getActionBar());
mMapSettings = new IITC_MapSettings(this);
// Clear the back stack // Clear the back stack
mBackStack.clear(); mBackStack.clear();
@ -114,9 +116,9 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
mDesktopMode = sharedPreferences.getBoolean("pref_force_desktop", false); mDesktopMode = sharedPreferences.getBoolean("pref_force_desktop", false);
mNavigationHelper.onPrefChanged(); mNavigationHelper.onPrefChanged();
} else if (key.equals("pref_user_loc")) { } else if (key.equals("pref_user_loc")) {
mIsLocEnabled = sharedPreferences.getBoolean("pref_user_loc", mIsLocEnabled = sharedPreferences.getBoolean("pref_user_loc", false);
false); } else if (key.equals("pref_fullscreen")) {
} else if (key.equals("pref_fullscreen_actionbar")) { mIitcWebView.updateFullscreenStatus();
mNavigationHelper.onPrefChanged(); mNavigationHelper.onPrefChanged();
return; return;
} else if (key.equals("pref_advanced_menu")) { } else if (key.equals("pref_advanced_menu")) {
@ -330,8 +332,8 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
@Override @Override
public void onBackPressed() { public void onBackPressed() {
// exit fullscreen mode if it is enabled and action bar is disabled or the back stack is empty // exit fullscreen mode if it is enabled and action bar is disabled or the back stack is empty
if (mFullscreenMode && (mBackStack.isEmpty() || mNavigationHelper.hideInFullscreen())) { if (mIitcWebView.isInFullscreen() && mBackStack.isEmpty()) {
toggleFullscreen(); mIitcWebView.toggleFullscreen();
return; return;
} }
@ -456,7 +458,7 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
reloadIITC(); reloadIITC();
return true; return true;
case R.id.toggle_fullscreen: case R.id.toggle_fullscreen:
toggleFullscreen(); mIitcWebView.toggleFullscreen();
return true; return true;
case R.id.layer_chooser: case R.id.layer_chooser:
mNavigationHelper.openRightDrawer(); mNavigationHelper.openRightDrawer();
@ -549,16 +551,6 @@ public class IITC_Mobile extends Activity implements OnSharedPreferenceChangeLis
} }
} }
public void toggleFullscreen() {
mFullscreenMode = !mFullscreenMode;
mNavigationHelper.setFullscreen(mFullscreenMode);
// toggle notification bar
WindowManager.LayoutParams attrs = getWindow().getAttributes();
attrs.flags ^= WindowManager.LayoutParams.FLAG_FULLSCREEN;
this.getWindow().setAttributes(attrs);
}
public IITC_WebView getWebView() { public IITC_WebView getWebView() {
return this.mIitcWebView; return this.mIitcWebView;
} }

View File

@ -20,7 +20,6 @@ import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter; import android.widget.ArrayAdapter;
import android.widget.ListView; import android.widget.ListView;
import android.widget.TextView; import android.widget.TextView;
import android.widget.Toast;
public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnItemClickListener { public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnItemClickListener {
// Show/hide the up arrow on the very left // Show/hide the up arrow on the very left
@ -111,9 +110,7 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
private final View mDrawerRight; private final View mDrawerRight;
private boolean mDesktopMode = false; private boolean mDesktopMode = false;
private boolean mFullscreen = false;
private boolean mIsLoading; private boolean mIsLoading;
private boolean mHideInFullscreen = false;
private Pane mPane = Pane.MAP; private Pane mPane = Pane.MAP;
private String mHighlighter = null; private String mHighlighter = null;
@ -232,12 +229,6 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
} else { } else {
mActionBar.setSubtitle(mHighlighter); mActionBar.setSubtitle(mHighlighter);
} }
if (mFullscreen && mHideInFullscreen) {
mActionBar.hide();
} else {
mActionBar.show();
}
} }
public void closeDrawers() { public void closeDrawers() {
@ -263,10 +254,6 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
} }
} }
public boolean hideInFullscreen() {
return mHideInFullscreen;
}
public boolean isDrawerOpened() { public boolean isDrawerOpened() {
return mDrawerLayout.isDrawerOpen(mDrawerLeft) || mDrawerLayout.isDrawerOpen(mDrawerRight); return mDrawerLayout.isDrawerOpen(mDrawerLeft) || mDrawerLayout.isDrawerOpen(mDrawerRight);
} }
@ -275,6 +262,7 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
public void onDrawerClosed(View drawerView) { public void onDrawerClosed(View drawerView) {
super.onDrawerClosed(drawerView); super.onDrawerClosed(drawerView);
mIitc.getWebView().onWindowFocusChanged(true);
// delay invalidating to prevent flickering in case another drawer is opened // delay invalidating to prevent flickering in case another drawer is opened
(new Handler()).postDelayed(new Runnable() { (new Handler()).postDelayed(new Runnable() {
@Override @Override
@ -288,6 +276,7 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
@Override @Override
public void onDrawerOpened(View drawerView) { public void onDrawerOpened(View drawerView) {
super.onDrawerOpened(drawerView); super.onDrawerOpened(drawerView);
mIitc.getWebView().onWindowFocusChanged(false);
mIitc.invalidateOptionsMenu(); mIitc.invalidateOptionsMenu();
updateActionBar(); updateActionBar();
mDrawerLayout.closeDrawer(drawerView.equals(mDrawerLeft) ? mDrawerRight : mDrawerLeft); mDrawerLayout.closeDrawer(drawerView.equals(mDrawerLeft) ? mDrawerRight : mDrawerLeft);
@ -321,7 +310,6 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
public void onPrefChanged() { public void onPrefChanged() {
mDesktopMode = mPrefs.getBoolean("pref_force_desktop", false); mDesktopMode = mPrefs.getBoolean("pref_force_desktop", false);
mHideInFullscreen = mPrefs.getBoolean("pref_fullscreen_actionbar", true);
updateActionBar(); updateActionBar();
} }
@ -343,16 +331,6 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
} }
} }
public void setFullscreen(boolean fullscreen) {
mFullscreen = fullscreen;
if (mFullscreen && mHideInFullscreen) {
// show a toast with instructions to exit the fullscreen mode again
Toast.makeText(mIitc, "Press back button to exit fullscreen", Toast.LENGTH_SHORT).show();
}
updateActionBar();
}
public void setHighlighter(String name) { public void setHighlighter(String name) {
mHighlighter = name; mHighlighter = name;
updateActionBar(); updateActionBar();
@ -368,4 +346,12 @@ public class IITC_NavigationHelper extends ActionBarDrawerToggle implements OnIt
updateActionBar(); updateActionBar();
} }
public void showActionBar() {
mActionBar.show();
}
public void hideActionBar() {
mActionBar.hide();
}
} }

View File

@ -11,32 +11,47 @@ import android.os.Build;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.util.Log; import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
import android.webkit.ConsoleMessage; import android.webkit.ConsoleMessage;
import android.webkit.GeolocationPermissions; import android.webkit.GeolocationPermissions;
import android.webkit.WebChromeClient; import android.webkit.WebChromeClient;
import android.webkit.WebSettings; import android.webkit.WebSettings;
import android.webkit.WebView; import android.webkit.WebView;
import android.widget.Toast;
import com.cradle.iitc_mobile.async.CheckHttpResponse; import com.cradle.iitc_mobile.async.CheckHttpResponse;
import java.util.HashSet;
import java.util.Set;
@SuppressLint("SetJavaScriptEnabled") @SuppressLint("SetJavaScriptEnabled")
public class IITC_WebView extends WebView { public class IITC_WebView extends WebView {
// fullscreen modes
public static final int FS_ENABLED = (1 << 0);
public static final int FS_SYSBAR = (1 << 1);
public static final int FS_ACTIONBAR = (1 << 2);
public static final int FS_STATUSBAR = (1 << 3);
public static final int FS_NAVBAR = (1 << 4);
private WebSettings mSettings; private WebSettings mSettings;
private IITC_WebViewClient mIitcWebViewClient; private IITC_WebViewClient mIitcWebViewClient;
private IITC_JSInterface mJsInterface; private IITC_JSInterface mJsInterface;
private Context mContext; private IITC_Mobile mIitc;
private SharedPreferences mSharedPrefs; private SharedPreferences mSharedPrefs;
private int mFullscreenStatus = 0;
private Runnable mNavHider;
private boolean mDisableJs = false; private boolean mDisableJs = false;
private String mDefaultUserAgent; private String mDefaultUserAgent;
private final String mDesktopUserAgent = "Mozilla/5.0 (X11; Linux x86_64; rv:17.0)" + private final String mDesktopUserAgent = "Mozilla/5.0 (X11; Linux x86_64; rv:17.0)" +
" Gecko/20130810 Firefox/17.0 Iceweasel/17.0.8"; " Gecko/20130810 Firefox/17.0 Iceweasel/17.0.8";
// init web view // init web view
private void iitc_init(Context c) { private void iitc_init(Context c) {
if (isInEditMode()) return; if (isInEditMode()) return;
mContext = c; mIitc = (IITC_Mobile) c;
mSettings = getSettings(); mSettings = getSettings();
mSettings.setJavaScriptEnabled(true); mSettings.setJavaScriptEnabled(true);
mSettings.setDomStorageEnabled(true); mSettings.setDomStorageEnabled(true);
@ -45,12 +60,21 @@ public class IITC_WebView extends WebView {
mSettings.setAppCacheEnabled(true); mSettings.setAppCacheEnabled(true);
mSettings.setDatabasePath(getContext().getApplicationInfo().dataDir + "/databases/"); mSettings.setDatabasePath(getContext().getApplicationInfo().dataDir + "/databases/");
mSettings.setAppCachePath(getContext().getCacheDir().getAbsolutePath()); mSettings.setAppCachePath(getContext().getCacheDir().getAbsolutePath());
mJsInterface = new IITC_JSInterface((IITC_Mobile) mContext); mJsInterface = new IITC_JSInterface(mIitc);
addJavascriptInterface(mJsInterface, "android"); addJavascriptInterface(mJsInterface, "android");
mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(mContext); mSharedPrefs = PreferenceManager.getDefaultSharedPreferences(mIitc);
mDefaultUserAgent = mSettings.getUserAgentString(); mDefaultUserAgent = mSettings.getUserAgentString();
setUserAgent(); setUserAgent();
mNavHider = new Runnable() {
@Override
public void run() {
if (isInFullscreen() && (getFullscreenStatus() & (FS_NAVBAR)) != 0) {
setSystemUiVisibility(SYSTEM_UI_FLAG_HIDE_NAVIGATION);
}
}
};
setWebChromeClient(new WebChromeClient() { setWebChromeClient(new WebChromeClient() {
/** /**
* our webchromeclient should share geolocation with the iitc script * our webchromeclient should share geolocation with the iitc script
@ -81,7 +105,7 @@ public class IITC_WebView extends WebView {
@Override @Override
public boolean onConsoleMessage(ConsoleMessage consoleMessage) { public boolean onConsoleMessage(ConsoleMessage consoleMessage) {
if (consoleMessage.messageLevel() == ConsoleMessage.MessageLevel.ERROR) { if (consoleMessage.messageLevel() == ConsoleMessage.MessageLevel.ERROR) {
((IITC_Mobile) getContext()).setLoadingState(false); mIitc.setLoadingState(false);
} }
return super.onConsoleMessage(consoleMessage); return super.onConsoleMessage(consoleMessage);
} }
@ -142,12 +166,84 @@ public class IITC_WebView extends WebView {
} }
// disable splash screen if a http error code is responded // disable splash screen if a http error code is responded
new CheckHttpResponse(mJsInterface, mContext).execute(url); new CheckHttpResponse(mJsInterface, mIitc).execute(url);
Log.d("iitcm", "loading url: " + url); Log.d("iitcm", "loading url: " + url);
} }
super.loadUrl(url); super.loadUrl(url);
} }
@Override
public boolean onTouchEvent(MotionEvent event) {
getHandler().removeCallbacks(mNavHider);
getHandler().postDelayed(mNavHider, 2000);
return super.onTouchEvent(event);
}
@Override
public void setSystemUiVisibility(int visibility) {
getHandler().postDelayed(mNavHider, 2000);
super.setSystemUiVisibility(visibility);
}
@Override
public void onWindowFocusChanged(boolean hasWindowFocus) {
if (hasWindowFocus) {
getHandler().postDelayed(mNavHider, 2000);
} else {
getHandler().removeCallbacks(mNavHider);
}
super.onWindowFocusChanged(hasWindowFocus);
}
public void toggleFullscreen() {
mFullscreenStatus ^= FS_ENABLED;
WindowManager.LayoutParams attrs = mIitc.getWindow().getAttributes();
// toggle notification bar
if (isInFullscreen()) {
// show a toast with instructions to exit the fullscreen mode again
Toast.makeText(mIitc, "Press back button to exit fullscreen", Toast.LENGTH_SHORT).show();
if ((mFullscreenStatus & FS_ACTIONBAR) != 0) {
mIitc.getNavigationHelper().hideActionBar();
}
if ((mFullscreenStatus & FS_SYSBAR) != 0) {
attrs.flags |= WindowManager.LayoutParams.FLAG_FULLSCREEN;
}
if ((mFullscreenStatus & FS_NAVBAR) != 0) {
setSystemUiVisibility(View.SYSTEM_UI_FLAG_HIDE_NAVIGATION);
}
if ((mFullscreenStatus & FS_STATUSBAR) != 0) {
loadUrl("javascript: $('#updatestatus').hide();");
}
} else {
attrs.flags &= ~WindowManager.LayoutParams.FLAG_FULLSCREEN;
mIitc.getNavigationHelper().showActionBar();
loadUrl("javascript: $('#updatestatus').show();");
}
mIitc.getWindow().setAttributes(attrs);
}
void updateFullscreenStatus() {
Set<String> entries = mSharedPrefs.getStringSet("pref_fullscreen", new HashSet<String>());
mFullscreenStatus &= FS_ENABLED;
// default values...android has no nice way to add default values to multiSelectListPreferences
if (entries.isEmpty()) {
mFullscreenStatus += FS_ACTIONBAR | FS_SYSBAR;
}
for (String entry : entries) {
mFullscreenStatus += Integer.parseInt(entry);
}
}
int getFullscreenStatus() {
return mFullscreenStatus;
}
public boolean isInFullscreen() {
return (mFullscreenStatus & FS_ENABLED) != 0;
}
public IITC_WebViewClient getWebViewClient() { public IITC_WebViewClient getWebViewClient() {
return mIitcWebViewClient; return mIitcWebViewClient;
} }
@ -210,5 +306,4 @@ public class IITC_WebView extends WebView {
Log.d("iitcm", "setting user agent to: " + ua); Log.d("iitcm", "setting user agent to: " + ua);
mSettings.setUserAgentString(ua); mSettings.setUserAgentString(ua);
} }
} }