- fixed all issues with rendering, performance has increased
dramatically on not-fullscreen and has increased a little in fullscreen
- battery life improved as a result
- added hebrew language
- changed the way history works (now uses SQLite database, it's way
better than the android.provider.Browser way)
- fixed a couple crashes related to bookmarks and downloads
- formatted the code a little better (thanks to Aeefire for the tips,
just know I'm taking your advice LOL)
This commit is contained in:
Anthony Restaino 2013-04-01 22:24:56 -04:00
parent d73986d1c5
commit c68e856741
9 changed files with 507 additions and 182 deletions

View File

@ -1,8 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="acr.browser.barebones"
android:versionCode="30"
android:versionName="2.3.7" >
android:versionCode="32"
android:versionName="2.3.9" >
<uses-sdk
android:minSdkVersion="8"
@ -26,6 +26,7 @@
android:launchMode="singleTask"
android:allowTaskReparenting="true"
android:multiprocess="false"
android:hardwareAccelerated="true"
>
<intent-filter>
<action android:name="android.intent.action.MAIN" />

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.5 KiB

View File

@ -0,0 +1,24 @@
<?xml version="1.0" encoding="utf-8"?>
<!--
/*
**
** Copyright 2009, The Android Open Source Project
**
** Licensed under the Apache License, Version 2.0 (the "License");
** you may not use this file except in compliance with the License.
** You may obtain a copy of the License at
**
** http://www.apache.org/licenses/LICENSE-2.0
**
** Unless required by applicable law or agreed to in writing, software
** distributed under the License is distributed on an "AS IS" BASIS,
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
** See the License for the specific language governing permissions and
** limitations under the License.
*/
-->
<animated-rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:drawable="@drawable/spinner"
android:pivotX="50%"
android:pivotY="50%"
/>

View File

@ -0,0 +1,26 @@
<?xml version="1.0" encoding="utf-8"?>
<!--
Copyright 2010, The Android Open Source Project
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<rotate
android:drawable="@drawable/spinner"
android:fromDegrees="720"
android:pivotX="50%"
android:pivotY="50%"
android:toDegrees="0" />
</item>
</layer-list>

View File

@ -109,6 +109,16 @@
android:paddingRight="10dp"
android:paddingTop="10dp"
android:src="@drawable/refresh" />
<ProgressBar
android:id="@+id/progressBar1"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:indeterminate="true"
/>
</RelativeLayout>
<MultiAutoCompleteTextView

View File

@ -0,0 +1,77 @@
package acr.browser.barebones;
import android.content.Context;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.Animation;
import android.webkit.WebView;
public final class AnthonyWebView extends WebView {
boolean move;
int API = Barebones.API;
long timeBetweenDownPress = 0;
int hitTest;
boolean showFullScreen = Barebones.showFullScreen;
View uBar = Barebones.uBar;
boolean uBarShows = Barebones.uBarShows;
Animation slideUp = Barebones.slideUp;
Animation slideDown = Barebones.slideDown;
public AnthonyWebView(Context context) {
super(context);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN: {
move = false;
if (API <= 10 && !Barebones.main[Barebones.pageId].hasFocus()) {
Barebones.main[Barebones.pageId].requestFocus();
}
timeBetweenDownPress = System.currentTimeMillis();
break;
}
case MotionEvent.ACTION_MOVE: {
move = true;
}
case MotionEvent.ACTION_UP: {
try {
hitTest = getHitTestResult().getType();
} catch (NullPointerException e) {
}
if (showFullScreen && hitTest != 9) {
if (System.currentTimeMillis() - timeBetweenDownPress < 500
&& !move) {
if (!uBarShows) {
uBar.startAnimation(slideDown);
uBarShows = true;
} else if (uBarShows) {
uBar.startAnimation(slideUp);
uBarShows = false;
}
break;
} else if (Barebones.main[Barebones.pageId].getScrollY() > 5 && uBarShows) {
uBar.startAnimation(slideUp);
uBarShows = false;
break;
} else if (Barebones.main[Barebones.pageId].getScrollY() < 5 && !uBarShows) {
uBar.startAnimation(slideDown);
uBarShows = true;
break;
}
}
}
default:
break;
}
return super.onTouchEvent(event);
}
}

View File

@ -15,15 +15,17 @@ import java.util.Map;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.DownloadManager;
import android.content.ActivityNotFoundException;
import android.content.ClipData;
import android.content.ClipboardManager;
import android.content.ComponentName;
import android.content.ContentResolver;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.SharedPreferences;
import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo;
import android.content.res.Configuration;
import android.database.Cursor;
import android.database.DatabaseUtils;
@ -40,16 +42,13 @@ import android.net.http.SslError;
import android.os.Bundle;
import android.os.Environment;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.provider.Browser;
import android.provider.Browser.BookmarkColumns;
import android.text.SpannableString;
import android.text.Spanned;
import android.text.TextUtils;
import android.util.DisplayMetrics;
import android.util.Log;
import android.view.Display;
import android.view.Gravity;
import android.view.KeyEvent;
import android.view.LayoutInflater;
@ -73,6 +72,7 @@ import android.webkit.DownloadListener;
import android.webkit.GeolocationPermissions;
import android.webkit.HttpAuthHandler;
import android.webkit.SslErrorHandler;
import android.webkit.URLUtil;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
@ -94,7 +94,6 @@ import android.widget.LinearLayout;
import android.widget.MultiAutoCompleteTextView.Tokenizer;
import android.widget.PopupMenu;
import android.widget.PopupMenu.OnMenuItemClickListener;
import android.widget.PopupWindow;
import android.widget.ProgressBar;
import android.widget.RelativeLayout;
import android.widget.ScrollView;
@ -168,7 +167,6 @@ public class Barebones extends Activity implements OnLongClickListener,
static HorizontalScrollView tabScroll;
static Animation slideUp;
static Animation slideDown;
static Animation anim;
static Animation fadeOut, fadeIn;
static long clock = 0;
static long timeBetweenDownPress = System.currentTimeMillis();
@ -178,6 +176,7 @@ public class Barebones extends Activity implements OnLongClickListener,
static List<Map<String, String>> list;
static Map<String, String> map;
static Handler handler;
static DatabaseHandler historyHandler;
@Override
protected void onCreate(Bundle savedInstanceState) {
@ -230,7 +229,17 @@ public class Barebones extends Activity implements OnLongClickListener,
public void init() {
DisplayMetrics metrics = new DisplayMetrics();
getWindowManager().getDefaultDisplay().getMetrics(metrics);
historyHandler = new DatabaseHandler(this);
API = Integer.valueOf(android.os.Build.VERSION.SDK_INT); // gets the sdk
// level
progressBar = (ProgressBar) findViewById(R.id.progressBar1);
if (API >= 11) {
progressBar.setIndeterminateDrawable(getResources().getDrawable(
R.drawable.ics_animation));
} else {
progressBar.setIndeterminateDrawable(getResources().getDrawable(
R.drawable.ginger_animation));
}
showFullScreen = settings.getBoolean("fullscreen", false);
uBar = (RelativeLayout) findViewById(R.id.urlBar);
bg = (RelativeLayout) findViewById(R.id.background);
@ -282,7 +291,6 @@ public class Barebones extends Activity implements OnLongClickListener,
barLayout = (RelativeLayout) findViewById(R.id.relativeLayout1);
refreshLayout = (RelativeLayout) findViewById(R.id.refreshLayout);
refreshLayout.setBackgroundResource(R.drawable.button);
anim = AnimationUtils.loadAnimation(Barebones.this, R.anim.rotate);
// get settings
WebView test = new WebView(Barebones.this); // getting default webview
// user agent
@ -299,8 +307,7 @@ public class Barebones extends Activity implements OnLongClickListener,
// stored
// homepage
// variable
API = Integer.valueOf(android.os.Build.VERSION.SDK_INT); // gets the sdk
// level
test.destroy();
userAgent = settings.getString("agent", mobile); // initializing
// useragent string
@ -407,7 +414,6 @@ public class Barebones extends Activity implements OnLongClickListener,
});
enterUrl();
updateUI();
if (showFullScreen) {
bg.removeView(uBar);
background.addView(uBar);
@ -415,30 +421,6 @@ public class Barebones extends Activity implements OnLongClickListener,
}
public static void updateUI() {
clock = System.currentTimeMillis();
Thread uiUpdate = new Thread(new Runnable() {
@Override
public void run() {
long clock = System.currentTimeMillis();
while (true) {
while (!(System.currentTimeMillis() - clock > 20 && pageIdIsVisible))
;
main[pageId].postInvalidate();
clock = System.currentTimeMillis();
}
}
});
if (API == 17 && !showFullScreen) {
pageIdIsVisible = true;
uiUpdate.setDaemon(true);
uiUpdate.setPriority(Thread.MIN_PRIORITY);
// uiUpdate.start();
}
}
public class SpaceTokenizer implements Tokenizer {
public int findTokenStart(CharSequence text, int cursor) {
@ -525,23 +507,21 @@ public class Barebones extends Activity implements OnLongClickListener,
@Override
public void run() {
bookmarks = Browser.BOOKMARKS_URI;
// bookmarks = Browser.BOOKMARKS_URI;
columns = new String[] { Browser.BookmarkColumns.URL,
Browser.BookmarkColumns.TITLE };
columns = new String[] { "url", "title" };
try {
managedCursor = null;
managedCursor = getContentResolver().query(bookmarks, // URI
// of
SQLiteDatabase s = historyHandler.getReadableDatabase();
managedCursor = s.query("history", // URI
// of
columns, // Which columns to return
null, // Which rows to return (all rows)
null, // Selection arguments (none)
null);
Log.i("Barebones: ", "SQLite success!!!");
null, null, null);
handler.sendEmptyMessage(1);
Log.i("Barebones: ", "SQLite success!!!");
} catch (SQLiteException e) {
handler.sendEmptyMessage(2);
@ -557,10 +537,8 @@ public class Barebones extends Activity implements OnLongClickListener,
// Variable for holding the retrieved URL
urlColumn = managedCursor
.getColumnIndex(Browser.BookmarkColumns.URL);
titleColumn = managedCursor
.getColumnIndex(Browser.BookmarkColumns.TITLE);
urlColumn = managedCursor.getColumnIndex("url");
titleColumn = managedCursor.getColumnIndex("title");
// Reference to the the column containing the URL
do {
urlA = managedCursor.getString(urlColumn);
@ -587,25 +565,25 @@ public class Barebones extends Activity implements OnLongClickListener,
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
long arg3) {
try{
txt = (TextView) arg1.findViewById(R.id.url);
str = txt.getText().toString();
if (!pageIdIsVisible && isBookmarkShowing) {
scrollBookmarks.startAnimation(fadeOut);
background.removeView(scrollBookmarks);
background.addView(main[pageId]);
pageIdIsVisible = true;
isBookmarkShowing = false;
}
main[pageId].loadUrl(str);
getUrl.setText(str);
getUrl.setPadding(tenPad, 0, tenPad, 0);
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(getUrl.getWindowToken(), 0);
}
catch(NullPointerException e){
Log.e("Barebones Error: ","NullPointerException on item click");
try {
txt = (TextView) arg1.findViewById(R.id.url);
str = txt.getText().toString();
if (!pageIdIsVisible && isBookmarkShowing) {
scrollBookmarks.startAnimation(fadeOut);
background.removeView(scrollBookmarks);
background.addView(main[pageId]);
pageIdIsVisible = true;
isBookmarkShowing = false;
}
main[pageId].loadUrl(str);
getUrl.setText(str);
getUrl.setPadding(tenPad, 0, tenPad, 0);
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(getUrl.getWindowToken(), 0);
} catch (NullPointerException e) {
Log.e("Barebones Error: ",
"NullPointerException on item click");
}
}
@ -790,9 +768,10 @@ public class Barebones extends Activity implements OnLongClickListener,
@Override
public void onConfigurationChanged(Configuration newConfig) {
main[pageId].invalidate();
main[pageId].getSettings().setLayoutAlgorithm(LayoutAlgorithm.NORMAL);
super.onConfigurationChanged(newConfig);
main[pageId].getSettings().setLayoutAlgorithm(
LayoutAlgorithm.NARROW_COLUMNS);
main[pageId].invalidate();
}
public void makeTab(final int pageToView, String Url) {
@ -807,7 +786,7 @@ public class Barebones extends Activity implements OnLongClickListener,
main[pageToView].setDownloadListener(new AnthonyDownload());
}
main[pageToView].requestFocus();
main[pageToView].setFocusable(true);
// main[pageToView].setFocusable(true);
main[pageToView].setOnLongClickListener(new OnLongClickListener() {
@Override
@ -976,75 +955,6 @@ public class Barebones extends Activity implements OnLongClickListener,
}
public static final class AnthonyWebView extends WebView {
public AnthonyWebView(Context context) {
super(context);
}
@Override
protected void onDraw(Canvas canvas) {
if (!showFullScreen) {
main[pageId].invalidate();
}
super.onDraw(canvas);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
// final HitTestResult poop;
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN: {
move = false;
if (API <= 10 && !main[pageId].hasFocus()) {
main[pageId].requestFocus();
}
timeBetweenDownPress = System.currentTimeMillis();
break;
}
case MotionEvent.ACTION_MOVE: {
move = true;
}
case MotionEvent.ACTION_UP: {
try {
hitTest = getHitTestResult().getType();
} catch (NullPointerException e) {
}
if (showFullScreen && hitTest != 9) {
if (System.currentTimeMillis() - timeBetweenDownPress < 500
&& !move) {
if (!uBarShows) {
uBar.startAnimation(slideDown);
uBarShows = true;
} else if (uBarShows) {
uBar.startAnimation(slideUp);
uBarShows = false;
}
break;
} else if (main[pageId].getScrollY() > 5 && uBarShows) {
uBar.startAnimation(slideUp);
uBarShows = false;
break;
} else if (main[pageId].getScrollY() < 5 && !uBarShows) {
uBar.startAnimation(slideDown);
uBarShows = true;
break;
}
}
}
default:
break;
}
return super.onTouchEvent(event);
}
}
private class AnthonyWebViewClient extends WebViewClient {
@Override
@ -1098,8 +1008,9 @@ public class Barebones extends Activity implements OnLongClickListener,
int num = view.getId();
pageIsLoading = true;
refresh.startAnimation(anim);
getUrl.setText(url);
refresh.setVisibility(View.INVISIBLE);
progressBar.setVisibility(View.VISIBLE);
getUrl.setPadding(tenPad, 0, tenPad, 0);
urlToLoad[num][0] = url;
urlTitle[num].setCompoundDrawables(webpageOther, null, exitTab,
@ -1113,21 +1024,20 @@ public class Barebones extends Activity implements OnLongClickListener,
@Override
public void onPageFinished(WebView view, final String url) {
progressBar.setVisibility(View.GONE);
refresh.setVisibility(View.VISIBLE);
if (!noStockBrowser) {
Thread history = new Thread(new Runnable() {
@Override
public void run() {
Browser.updateVisitedHistory(getContentResolver(), url,
true);
// Log.i("Barebones",view.getTitle()+" "+url);
}
});
history.start();
}
pageIsLoading = false;
anim.cancel();
anim.reset();
}
}
@ -1137,15 +1047,61 @@ public class Barebones extends Activity implements OnLongClickListener,
@Override
public void onDownloadStart(String url, String userAgent,
String contentDisposition, String mimetype, long contentLength) {
DownloadManager download = (DownloadManager) getSystemService(DOWNLOAD_SERVICE);
Uri nice = Uri.parse(url);
DownloadManager.Request it = new DownloadManager.Request(nice);
String fileName = url.substring(url.lastIndexOf('/') + 1,
url.length());
it.setDestinationInExternalPublicDir(
Environment.DIRECTORY_DOWNLOADS, fileName);
Log.i("Barebones", "Downloading" + fileName);
download.enqueue(it);
if (contentDisposition == null
|| !contentDisposition.regionMatches(
true, 0, "attachment", 0, 10)) {
// query the package manager to see if there's a registered handler
// that matches.
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(Uri.parse(url), mimetype);
ResolveInfo info = getPackageManager().resolveActivity(intent,
PackageManager.MATCH_DEFAULT_ONLY);
if (info != null) {
ComponentName myName = getComponentName();
// If we resolved to ourselves, we don't want to attempt to
// load the url only to try and download it again.
if (!myName.getPackageName().equals(
info.activityInfo.packageName)
|| !myName.getClassName().equals(
info.activityInfo.name)) {
// someone (other than us) knows how to handle this mime
// type with this scheme, don't download.
try {
startActivity(intent);
return;
} catch (ActivityNotFoundException ex) {
Log.d("Barebones", "activity not found for " + mimetype
+ " over " + Uri.parse(url).getScheme(),
ex);
// Best behavior is to fall back to a download in this
// case
try {
DownloadManager download = (DownloadManager) getSystemService(DOWNLOAD_SERVICE);
Uri nice = Uri.parse(url);
DownloadManager.Request it = new DownloadManager.Request(nice);
String fileName = URLUtil.guessFileName(url,
contentDisposition, mimetype);
it.setDestinationInExternalPublicDir(
Environment.DIRECTORY_DOWNLOADS, fileName);
Log.i("Barebones", "Downloading" + fileName);
download.enqueue(it);
} catch (NullPointerException e) {
Log.e("Barebones", "Problem downloading");
Toast.makeText(Barebones.this, "Error Downloading File",
Toast.LENGTH_SHORT).show();
}
catch (IllegalArgumentException e){
Log.e("Barebones", "Problem downloading");
Toast.makeText(Barebones.this, "Error Downloading File",
Toast.LENGTH_SHORT).show();
}
}
}
}
}
}
}
@ -1257,11 +1213,36 @@ public class Barebones extends Activity implements OnLongClickListener,
}
@Override
public void onReceivedTitle(WebView view, String title) {
public void onReceivedTitle(final WebView view, final String title) {
int num = view.getId();
urlTitle[num].setText(title);
urlToLoad[num][1] = title;
Thread up = new Thread(new Runnable() {
@Override
public void run() {
try {
StringBuilder sb = new StringBuilder("url" + " = ");
DatabaseUtils.appendEscapedSQLString(sb, view.getUrl());
SQLiteDatabase s = historyHandler.getReadableDatabase();
Cursor c = s.query("history", new String[] { "id",
"url", "title" }, sb.toString(), null, null,
null, null);
if (c.moveToFirst()) {
} else {
historyHandler.addHistoryItem(new HistoryItem(view
.getUrl(), title));
}
} catch (IllegalStateException e) {
Log.e("Barebones", "ERRRRROOORRRR 1");
} catch (NullPointerException e) {
Log.e("Barebones", "ERRRRROOORRRR 2");
}
}
});
up.run();
super.onReceivedTitle(view, title);
}
@ -1340,8 +1321,10 @@ public class Barebones extends Activity implements OnLongClickListener,
// view.setDrawingCacheEnabled(true);
view.setDrawingCacheBackgroundColor(getResources().getColor(
android.R.color.background_light));
view.setDrawingCacheQuality(View.DRAWING_CACHE_QUALITY_HIGH);
view.setAlwaysDrawnWithCacheEnabled(true);
// view.setDrawingCacheQuality(View.DRAWING_CACHE_QUALITY_HIGH);
// view.setAlwaysDrawnWithCacheEnabled(true);
view.setWillNotCacheDrawing(true);
// view.setPersistentDrawingCache(ViewGroup.PERSISTENT_ALL_CACHES);
view.setFocusable(true);
view.setFocusableInTouchMode(true);
view.setSaveEnabled(true);
@ -1392,6 +1375,7 @@ public class Barebones extends Activity implements OnLongClickListener,
webViewSettings.setLayoutAlgorithm(LayoutAlgorithm.NARROW_COLUMNS);
webViewSettings.setLoadsImagesAutomatically(true);
// webViewSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
return view;
}
@ -1477,9 +1461,7 @@ public class Barebones extends Activity implements OnLongClickListener,
new FileWriter(book));
BufferedWriter urlWriter = new BufferedWriter(
new FileWriter(bookUrl));
Log.i("barebones", "makes to here");
while (bUrl[n] != null && n < (MAX_BOOKMARKS - 1)) {
Log.i("barebones", "makes to here " + n);
if (delete != n) {
bookWriter.write(bTitle[n]);
urlWriter.write(bUrl[n]);
@ -1487,7 +1469,6 @@ public class Barebones extends Activity implements OnLongClickListener,
urlWriter.newLine();
}
n++;
Log.i("barebones", "makes to here " + n);
}
bookWriter.close();
urlWriter.close();
@ -1577,7 +1558,6 @@ public class Barebones extends Activity implements OnLongClickListener,
}
}
public void addBookmark() {
File book = new File(getBaseContext().getFilesDir(), "bookmarks");
File bookUrl = new File(getBaseContext().getFilesDir(), "bookurl");
@ -1598,7 +1578,7 @@ public class Barebones extends Activity implements OnLongClickListener,
} catch (IOException e) {
e.printStackTrace();
} catch (NullPointerException e){
} catch (NullPointerException e) {
e.printStackTrace();
}
}
@ -1657,6 +1637,9 @@ public class Barebones extends Activity implements OnLongClickListener,
int leftId = id;
pageIdIsVisible = false;
main[id].stopLoading();
if (API >= 11) {
main[id].onPause();
}
main[id].clearView();
boolean right = false, left = false;
// background.clearDisappearingChildren();
@ -1886,20 +1869,25 @@ public class Barebones extends Activity implements OnLongClickListener,
menu.show();
} else if (API < 11) {
/*
LayoutInflater inflater=(LayoutInflater)Barebones.this.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
Display display=getWindowManager().getDefaultDisplay();
* LayoutInflater
* inflater=(LayoutInflater)Barebones.this.getSystemService
* (Context.LAYOUT_INFLATER_SERVICE); Display
* display=getWindowManager().getDefaultDisplay();
*
* int width=display.getWidth()/2; int
* height=display.getHeight()/2;
*
* View pop = inflater.inflate(R.layout.menu,null,false);
* pop
* .measure(View.MeasureSpec.UNSPECIFIED,View.MeasureSpec.
* UNSPECIFIED); height=pop.getMeasuredHeight();
* width=pop.getMeasuredWidth(); PopupWindow pu = new
* PopupWindow(pop,width,height,true);
* pu.showAtLocation(findViewById
* (v.getId()),Gravity.NO_GRAVITY
* ,v.getRight(),v.getBottom()+80);
*/
int width=display.getWidth()/2;
int height=display.getHeight()/2;
View pop = inflater.inflate(R.layout.menu,null,false);
pop.measure(View.MeasureSpec.UNSPECIFIED,View.MeasureSpec.UNSPECIFIED);
height=pop.getMeasuredHeight();
width=pop.getMeasuredWidth();
PopupWindow pu = new PopupWindow(pop,width,height,true);
pu.showAtLocation(findViewById(v.getId()),Gravity.NO_GRAVITY,v.getRight(),v.getBottom()+80);
*/
openOptionsMenu();
}
}
@ -1963,7 +1951,6 @@ public class Barebones extends Activity implements OnLongClickListener,
String fixedQuery = query.trim();
boolean period = fixedQuery.contains(".");
if (isBookmarkShowing) {
Log.i("Barebones", " is executing");
scrollBookmarks.startAnimation(fadeOut);
background.removeView(scrollBookmarks);
isBookmarkShowing = false;
@ -2098,16 +2085,11 @@ public class Barebones extends Activity implements OnLongClickListener,
@Override
public void finish() {
pageIdIsVisible = false;
this.onPause();
super.finish();
}
@Override
protected void onDestroy() {
try {
deleteHistory = settings.getBoolean("history", false);
if (deleteHistory == true) {
this.deleteDatabase("historyManager");
if (!noStockBrowser) {
Browser.clearHistory(getContentResolver());
}
@ -2117,6 +2099,13 @@ public class Barebones extends Activity implements OnLongClickListener,
e.printStackTrace();
}
this.onPause();
super.finish();
}
@Override
protected void onDestroy() {
super.onDestroy();
}

View File

@ -0,0 +1,141 @@
package acr.browser.barebones;
import java.util.ArrayList;
import java.util.List;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
public class DatabaseHandler extends SQLiteOpenHelper {
// All Static variables
// Database Version
private static final int DATABASE_VERSION = 1;
// Database Name
private static final String DATABASE_NAME = "historyManager";
// HistoryItems table name
private static final String TABLE_HISTORY = "history";
// HistoryItems Table Columns names
private static final String KEY_ID = "id";
private static final String KEY_URL = "url";
private static final String KEY_TITLE = "title";
public DatabaseHandler(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
// Creating Tables
@Override
public void onCreate(SQLiteDatabase db) {
String CREATE_CONTACTS_TABLE = "CREATE TABLE " + TABLE_HISTORY + "("
+ KEY_ID + " INTEGER PRIMARY KEY," + KEY_URL + " TEXT,"
+ KEY_TITLE + " TEXT" +")";
db.execSQL(CREATE_CONTACTS_TABLE);
}
// Upgrading database
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// Drop older table if existed
db.execSQL("DROP TABLE IF EXISTS " + TABLE_HISTORY);
// Create tables again
onCreate(db);
}
/**
* All CRUD(Create, Read, Update, Delete) Operations
*/
// Adding new item
void addHistoryItem(HistoryItem item) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(KEY_URL, item.getUrl()); // HistoryItem Name
values.put(KEY_TITLE, item.getTitle()); // HistoryItem Phone
// Inserting Row
db.insert(TABLE_HISTORY, null, values);
db.close(); // Closing database connection
}
// Getting single item
HistoryItem getHistoryItem(int id) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.query(TABLE_HISTORY, new String[] { KEY_ID,
KEY_URL, KEY_TITLE}, KEY_ID + "=?",
new String[] { String.valueOf(id) }, null, null, null, null);
if (cursor != null)
cursor.moveToFirst();
HistoryItem item = new HistoryItem(Integer.parseInt(cursor.getString(0)),
cursor.getString(1), cursor.getString(2));
// return item
return item;
}
// Getting All HistoryItems
public List<HistoryItem> getAllHistoryItems() {
List<HistoryItem> itemList = new ArrayList<HistoryItem>();
// Select All Query
String selectQuery = "SELECT * FROM " + TABLE_HISTORY;
SQLiteDatabase db = this.getWritableDatabase();
Cursor cursor = db.rawQuery(selectQuery, null);
// looping through all rows and adding to list
if (cursor.moveToFirst()) {
do {
HistoryItem item = new HistoryItem();
item.setID(Integer.parseInt(cursor.getString(0)));
item.setUrl(cursor.getString(1));
item.setTitle(cursor.getString(2));
// Adding item to list
itemList.add(item);
} while (cursor.moveToNext());
}
// return item list
return itemList;
}
// Updating single item
public int updateHistoryItem(HistoryItem item) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put(KEY_URL, item.getUrl());
values.put(KEY_TITLE, item.getTitle());
// updating row
return db.update(TABLE_HISTORY, values, KEY_ID + " = ?",
new String[] { String.valueOf(item.getID()) });
}
// Deleting single item
public void deleteHistoryItem(HistoryItem item) {
SQLiteDatabase db = this.getWritableDatabase();
db.delete(TABLE_HISTORY, KEY_ID + " = ?",
new String[] { String.valueOf(item.getID()) });
db.close();
}
// Getting items Count
public int getHistoryItemsCount() {
String countQuery = "SELECT * FROM " + TABLE_HISTORY;
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(countQuery, null);
cursor.close();
// return count
return cursor.getCount();
}
}

View File

@ -0,0 +1,57 @@
package acr.browser.barebones;
public class HistoryItem {
//private variables
int _id;
String _url;
String _title;
// Empty constructor
public HistoryItem(){
}
// constructor
public HistoryItem(int id, String url, String title){
this._id = id;
this._url = url;
this._title = title;
}
// constructor
public HistoryItem(String url, String title){
this._url = url;
this._title = title;
}
// getting ID
public int getID(){
return this._id;
}
// setting id
public void setID(int id){
this._id = id;
}
// getting name
public String getUrl(){
return this._url;
}
// setting name
public void setUrl(String url){
this._url = url;
}
// getting phone number
public String getTitle(){
return this._title;
}
// setting phone number
public void setTitle(String title){
this._title = title;
}
}