summaryrefslogtreecommitdiff
path: root/app/src/main/java/de/danoeh/antennapod
diff options
context:
space:
mode:
authorTom Hennen <TomHennen@users.noreply.github.com>2015-09-05 11:35:32 -0400
committerTom Hennen <TomHennen@users.noreply.github.com>2015-09-05 11:35:32 -0400
commit0fea81a82366ca23e53263ddcf5986a7f0367fd4 (patch)
tree1f69ef377aa1c762b44ebc4e495c79b9d02f9b2b /app/src/main/java/de/danoeh/antennapod
parentd5e31f5350acfd341bca23430ce9be43699851c6 (diff)
parent0514a486f6802cc7026bd4bfe2bd5e7af1768738 (diff)
downloadAntennaPod-0fea81a82366ca23e53263ddcf5986a7f0367fd4.zip
Merge pull request #1157 from mfietz/issue/1154-about-dark
Dark About view
Diffstat (limited to 'app/src/main/java/de/danoeh/antennapod')
-rw-r--r--app/src/main/java/de/danoeh/antennapod/activity/AboutActivity.java60
1 files changed, 59 insertions, 1 deletions
diff --git a/app/src/main/java/de/danoeh/antennapod/activity/AboutActivity.java b/app/src/main/java/de/danoeh/antennapod/activity/AboutActivity.java
index 035ab2f22..6ba84c249 100644
--- a/app/src/main/java/de/danoeh/antennapod/activity/AboutActivity.java
+++ b/app/src/main/java/de/danoeh/antennapod/activity/AboutActivity.java
@@ -1,22 +1,42 @@
package de.danoeh.antennapod.activity;
+import android.content.res.TypedArray;
+import android.graphics.Color;
+import android.os.Build;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
+import android.util.Log;
+import android.view.View;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.LinearLayout;
+import org.apache.commons.io.IOUtils;
+
+import java.io.IOException;
+import java.io.InputStream;
+import java.nio.charset.Charset;
+
import de.danoeh.antennapod.R;
import de.danoeh.antennapod.core.preferences.UserPreferences;
+import rx.Observable;
+import rx.Subscriber;
+import rx.Subscription;
+import rx.android.schedulers.AndroidSchedulers;
+import rx.schedulers.Schedulers;
/**
* Displays the 'about' screen
*/
public class AboutActivity extends ActionBarActivity {
+ private static final String TAG = AboutActivity.class.getSimpleName();
+
private WebView webview;
private LinearLayout webviewContainer;
+ private Subscription subscription;
+
@Override
protected void onCreate(Bundle savedInstanceState) {
setTheme(UserPreferences.getTheme());
@@ -25,6 +45,13 @@ public class AboutActivity extends ActionBarActivity {
setContentView(R.layout.about);
webviewContainer = (LinearLayout) findViewById(R.id.webvContainer);
webview = (WebView) findViewById(R.id.webvAbout);
+ if (UserPreferences.getTheme() == R.style.Theme_AntennaPod_Dark) {
+ if (Build.VERSION.SDK_INT >= 11
+ && Build.VERSION.SDK_INT <= Build.VERSION_CODES.ICE_CREAM_SANDWICH_MR1) {
+ webview.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
+ }
+ webview.setBackgroundColor(Color.TRANSPARENT);
+ }
webview.setWebViewClient(new WebViewClient() {
@Override
@@ -34,12 +61,43 @@ public class AboutActivity extends ActionBarActivity {
}
});
- webview.loadUrl("file:///android_asset/about.html");
+ subscription = Observable.create(new Observable.OnSubscribe<String>() {
+ @Override
+ public void call(Subscriber<? super String> subscriber) {
+ InputStream input = null;
+ try {
+ TypedArray res = AboutActivity.this.getTheme().obtainStyledAttributes(
+ new int[] { android.R.attr.textColorPrimary });
+ int colorResource = res.getColor(0, 0);
+ String colorString = String.format("#%06X", 0xFFFFFF & colorResource);
+ res.recycle();
+ input = getAssets().open("about.html");
+ String webViewData = IOUtils.toString(input, Charset.defaultCharset());
+ webViewData = String.format(webViewData, colorString);
+ subscriber.onNext(webViewData);
+ } catch (IOException e) {
+ subscriber.onError(e);
+ } finally {
+ IOUtils.closeQuietly(input);
+ }
+ subscriber.onCompleted();
+ }
+ })
+ .subscribeOn(Schedulers.newThread())
+ .observeOn(AndroidSchedulers.mainThread())
+ .subscribe(webviewData -> {
+ webview.loadDataWithBaseURL(null, webviewData, "text/html", "utf-8", "about:blank");
+ }, error -> {
+ Log.e(TAG, Log.getStackTraceString(error));
+ });
}
@Override
protected void onDestroy() {
super.onDestroy();
+ if(subscription != null) {
+ subscription.unsubscribe();
+ }
if (webviewContainer != null && webview != null) {
webviewContainer.removeAllViews();
webview.destroy();