diff options
42 files changed, 5530 insertions, 1604 deletions
@@ -5,4 +5,4 @@ vdrmanager/local.properties vdrmanager/vdrmanager.iml vdr-vdrmanager/CMakeLists.txt vdrmanager/gradle/ - +R.java diff --git a/vdrmanager/build.gradle b/vdrmanager/build.gradle index 9ed22aa..2f6c7ea 100644 --- a/vdrmanager/build.gradle +++ b/vdrmanager/build.gradle @@ -5,7 +5,7 @@ buildscript { google() } dependencies { - classpath 'com.android.tools.build:gradle:3.0.0' + classpath 'com.android.tools.build:gradle:3.5.1' } } diff --git a/vdrmanager/de.bjusystems.vdrmanager/build.gradle b/vdrmanager/de.bjusystems.vdrmanager/build.gradle index f759850..5b08d75 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/build.gradle +++ b/vdrmanager/de.bjusystems.vdrmanager/build.gradle @@ -14,14 +14,11 @@ android { } } - compileSdkVersion 23 - buildToolsVersion '26.0.2' + compileSdkVersion 26 defaultConfig { applicationId "de.bjusystems.vdrmanager" - minSdkVersion 8 - targetSdkVersion 23 - //vectorDrawables.useSupportLibrary = true - + minSdkVersion 15 + targetSdkVersion 26 } @@ -40,11 +37,12 @@ android { } dependencies { - compile 'com.android.support:support-v4:23.4.0' - compile 'com.android.support:appcompat-v7:23.4.0' + compile 'com.android.support:support-v4:26.1.0' + compile 'com.android.support:appcompat-v7:26.1.0' compile 'com.j256.ormlite:ormlite-android:4.48' compile 'com.j256.ormlite:ormlite-core:4.48' compile 'org.slf4j:slf4j-android:1.7.19' - compile 'org.hampelratte:svdrp4j:1.1.0-SNAPSHOT' - compile 'com.android.support:recyclerview-v7:23.4.0' + compile 'org.hampelratte:svdrp4j:1.1.1' + compile 'com.android.support:recyclerview-v7:26.1.0' + compile 'com.toptoche.searchablespinner:searchablespinnerlibrary:1.3.1' } diff --git a/vdrmanager/de.bjusystems.vdrmanager/build/generated/source/buildConfig/debug/de/bjusystems/vdrmanager/BuildConfig.java b/vdrmanager/de.bjusystems.vdrmanager/build/generated/source/buildConfig/debug/de/bjusystems/vdrmanager/BuildConfig.java new file mode 100644 index 0000000..30004b4 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/build/generated/source/buildConfig/debug/de/bjusystems/vdrmanager/BuildConfig.java @@ -0,0 +1,13 @@ +/** + * Automatically generated file. DO NOT MODIFY + */ +package de.bjusystems.vdrmanager; + +public final class BuildConfig { + public static final boolean DEBUG = Boolean.parseBoolean("true"); + public static final String APPLICATION_ID = "de.bjusystems.vdrmanager"; + public static final String BUILD_TYPE = "debug"; + public static final String FLAVOR = ""; + public static final int VERSION_CODE = 12800; + public static final String VERSION_NAME = "12.80"; +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release.apk b/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release.apk Binary files differindex 68f48f9..3183e5a 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release.apk +++ b/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release.apk diff --git a/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release_12760.apk b/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release_12760.apk Binary files differnew file mode 100644 index 0000000..f1c2786 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/release/de.bjusystems.vdrmanager-release_12760.apk diff --git a/vdrmanager/de.bjusystems.vdrmanager/release/output.json b/vdrmanager/de.bjusystems.vdrmanager/release/output.json index 98f40ef..1048b4b 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/release/output.json +++ b/vdrmanager/de.bjusystems.vdrmanager/release/output.json @@ -1 +1 @@ -[{"outputType":{"type":"APK"},"apkInfo":{"type":"MAIN","splits":[],"versionCode":12710},"path":"de.bjusystems.vdrmanager-release.apk","properties":{"packageId":"de.bjusystems.vdrmanager","split":"","minSdkVersion":"8"}}]
\ No newline at end of file +[{"outputType":{"type":"APK"},"apkData":{"type":"MAIN","splits":[],"versionCode":12800,"versionName":"12.80","enabled":true,"outputFile":"de.bjusystems.vdrmanager-release.apk","fullName":"release","baseName":"release"},"path":"de.bjusystems.vdrmanager-release.apk","properties":{}}]
\ No newline at end of file diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/AndroidManifest.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/AndroidManifest.xml index ad02637..e02fcdb 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/AndroidManifest.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/AndroidManifest.xml @@ -1,8 +1,8 @@ <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="de.bjusystems.vdrmanager" - android:versionCode="12710" - android:versionName="12.71"> + android:versionCode="12800" + android:versionName="12.80"> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> @@ -10,9 +10,6 @@ <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> - <uses-sdk - android:minSdkVersion="8" - android:targetSdkVersion="23" /> <application android:name=".app.VdrManagerApp" @@ -156,7 +153,7 @@ <activity android:name=".remote.RemoteActivity" android:theme="@style/AppTheme" - android:configChanges="orientation|locale|screenSize"> + android:configChanges="locale|screenSize"> <intent-filter> <action android:name="android.intent.action.SEND" /> <category android:name="android.intent.category.DEFAULT" /> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/assets/fonts/fontawesome-webfont.ttf b/vdrmanager/de.bjusystems.vdrmanager/src/main/assets/fonts/fontawesome-webfont.ttf Binary files differindex ed9372f..35acda2 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/assets/fonts/fontawesome-webfont.ttf +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/assets/fonts/fontawesome-webfont.ttf diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeButton.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeButton.java index 22c4de1..f35971c 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeButton.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeButton.java @@ -2,12 +2,11 @@ package de.androvdr.widget; import android.content.Context; import android.util.AttributeSet; -import android.widget.Button; /** * Created by lado on 04.05.15. */ -public class FontAwesomeButton extends Button { +public class FontAwesomeButton extends android.support.v7.widget.AppCompatButton { public FontAwesomeButton(Context context, AttributeSet attrs, int defStyle) { diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeTextView.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeTextView.java new file mode 100644 index 0000000..a6b5b42 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/androvdr/widget/FontAwesomeTextView.java @@ -0,0 +1,36 @@ +package de.androvdr.widget; + +import android.content.Context; +import android.graphics.Typeface; +import android.support.annotation.Nullable; +import android.util.AttributeSet; +import android.widget.TextView; + +/** + * Created by lado on 17.11.17. + */ + +public class FontAwesomeTextView extends TextView { + public FontAwesomeTextView(Context context) { + super(context); + initFontAwesome(); + } + + public FontAwesomeTextView(Context context, @Nullable AttributeSet attrs) { + super(context, attrs); + initFontAwesome(); + } + + public FontAwesomeTextView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { + super(context, attrs, defStyleAttr); + initFontAwesome(); + } + + private void initFontAwesome() { + if (isInEditMode() == false) { + setTypeface(FontAwesome.getFontAwesome(getContext().getApplicationContext().getApplicationContext())); + } + } + + +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/ButtonMapping.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/ButtonMapping.java new file mode 100644 index 0000000..cacef1a --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/ButtonMapping.java @@ -0,0 +1,49 @@ +package de.bjusystems.vdrmanager; + +import org.json.JSONException; +import org.json.JSONObject; + +/** + * Created by lado on 05.11.17. + */ +public class ButtonMapping { + + public static final String KEY = "key"; + public static final String LABEL = "label"; + public static final String COLOR = "color"; + + public static final String PREFIX_SEPARATOR = "_"; + + public static final String KEY_PREFIX = KEY + PREFIX_SEPARATOR; + public static final String LABEL_PREFIX = LABEL + PREFIX_SEPARATOR; + public static final String COLOR_PREFIX = COLOR + PREFIX_SEPARATOR; + + public static final Integer NO_COLOR = -1; + + /** + * The Key. + */ + public String key; + /** + * The Label. + */ + public String label; + /** + * The Color. + */ + public Integer color; + + public ButtonMapping() { + + } + + public ButtonMapping(String key, String label, Integer color) { + this.key = key; + this.label = label; + this.color = color; + } + + public JSONObject toJson() throws JSONException { + return new JSONObject().put("key", key).put("label", label).put("color", color); + } +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/BaseActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/BaseActivity.java index 26fe8e4..a3f752a 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/BaseActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/BaseActivity.java @@ -8,7 +8,7 @@ import android.os.Bundle; import android.support.v4.app.ActionBarDrawerToggle; import android.support.v4.view.GravityCompat; import android.support.v4.widget.DrawerLayout; -import android.support.v7.app.ActionBarActivity; +import android.support.v7.app.AppCompatActivity; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; @@ -27,6 +27,7 @@ import de.bjusystems.vdrmanager.app.VdrManagerApp; import de.bjusystems.vdrmanager.data.Channel; import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.remote.RemoteActivity; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpAsyncTask; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpClient; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpEvent; @@ -36,619 +37,621 @@ import de.bjusystems.vdrmanager.utils.svdrp.SvdrpFinishedListener; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpListener; public abstract class BaseActivity<Result, T extends ListView> extends - ActionBarActivity implements OnClickListener, SvdrpListener, - SvdrpExceptionListener, SvdrpFinishedListener<Result> { + AppCompatActivity implements OnClickListener, SvdrpListener, + SvdrpExceptionListener, SvdrpFinishedListener<Result> { - public static final String TAG = BaseActivity.class.getName(); + public static final String TAG = BaseActivity.class.getName(); - public static final int MENU_GROUP_REFRESH = 99; + public static final int MENU_GROUP_REFRESH = 99; - public static final int MENU_REFRESH = 99; - - protected T listView; - - protected ViewFlipper flipper; - - private Button retry; - - private ProgressDialog progress; - - protected Preferences getPrefs(){ - return Preferences.get(); - } - - // protected SvdrpProgressDialog progress; - - private CharSequence mDrawerTitle; - private DrawerLayout mDrawerLayout; - private ListView mDrawerList; - private ActionBarDrawerToggle mDrawerToggle; - private String[] mTitles; - - abstract protected String getWindowTitle(); - - abstract protected int getMainLayout(); - - protected void noInternetConnection() { - alert(R.string.no_internet_connection); - } - - abstract protected boolean displayingResults(); - - /** - * When using the ActionBarDrawerToggle, you must call it during - * onPostCreate() and onConfigurationChanged()... - */ - - @Override - protected void onPostCreate(Bundle savedInstanceState) { - super.onPostCreate(savedInstanceState); - // Sync the toggle state after onRestoreInstanceState has occurred. - mDrawerToggle.syncState(); - } - - protected boolean isForceRefresh() { - if (forceRefresh == false) { - return false; - } - forceRefresh = false; - return true; - } - - protected boolean forceRefresh = false; - - protected void switchNoConnection() { - if (flipper == null) { - say(R.string.no_connection); - return; - } - - if (displayingResults()) { - say(R.string.no_connection); - } else { - flipper.setDisplayedChild(1); - } - } - - protected CertificateProblemDialog getCertificateProblemDialog() { - return new CertificateProblemDialog(this); - } - - @Override - public void onConfigurationChanged(final Configuration newConfig) { - Preferences.setLocale(this); - super.onConfigurationChanged(newConfig); - mDrawerToggle.onConfigurationChanged(newConfig); - } - - @Override - protected void onResume() { - Preferences.init(this); - super.onResume(); - } - - protected void initFlipper() { - this.flipper = (ViewFlipper) findViewById(R.id.flipper); - retry = (Button) findViewById(R.id.retry_button); - retry.setOnClickListener(this); - } - - @Override - public void onClick(final View v) { - if (v.getId() == R.id.retry_button) { - retry(); - } - } - - // - // protected void updateWindowTitle(int topic, int subtopic) { - // String title; - // title = getString(topic); - // if (subtopic != -1) { - // title += " > " + getString(subtopic); - // } - // setTitle(title); - // } - // - // protected void updateWindowTitle(String topic, String subtopic) { - // String title = topic; - // if (subtopic != null) { - // title += " > " + subtopic; - // } - // setTitle(title); - // } - - abstract protected int getListNavigationIndex(); - - public static final int LIST_NAVIGATION_CHANNELS = 0; - public static final int LIST_NAVIGATION_EPG_BY_TIME = 1; - public static final int LIST_NAVIGATION_EPG_BY_CHANNEL = 2; - public static final int LIST_NAVIGATION_RECORDINGS = 3; - public static final int LIST_NAVIGATION_TIMERS = 4; - public static final int LIST_NAVIGATION_REMOTE = 5; - - protected boolean hasListNavigation() { - return true; - } - - protected void initListNavigation() { - - if (hasListNavigation() == false) { - return; - } - - // getSupportActionBar().setDisplayShowTitleEnabled(false); - // - // getSupportActionBar().setNavigationMode( - // getSupportActionBar().NAVIGATION_MODE_LIST); - // - // final ArrayAdapter<CharSequence> mSpinnerAdapter = ArrayAdapter - // .createFromResource(this, R.array.navigation_array, - // android.R.layout.simple_spinner_dropdown_item); - // - // getSupportActionBar().setListNavigationCallbacks(mSpinnerAdapter, - // new OnNavigationListener() { - // - // private boolean firstHit = true; - // - // @Override - // public boolean onNavigationItemSelected( - // final int itemPosition, final long itemId) { - // - // if (firstHit == true) { - // firstHit = false; - // return false; - // } - // switch (itemPosition) { - // - // case LIST_NAVIGATION_CHANNELS: { - // startActivity(ChannelListActivity.class); - // return true; - // } - // case LIST_NAVIGATION_EPG_BY_TIME: { - // startActivity(TimeEpgListActivity.class); - // return true; - // } - // - // case LIST_NAVIGATION_EPG_BY_CHANNEL: { - // startActivity(EventEpgListActivity.class); - // return true; - // } - // - // case LIST_NAVIGATION_RECORDINGS: { - // startActivity(RecordingListActivity.class); - // return true; - // } - // - // case LIST_NAVIGATION_TIMERS: { - // startActivity(TimerListActivity.class); - // return true; - // } - // - // } - // return false; - // } - // }); - // getSupportActionBar().setSelectedNavigationItem( - // getListNavigationIndex()); - - } - - @Override - protected void onCreate(final Bundle savedInstanceState) { - super.onCreate(savedInstanceState); - Preferences.setLocale(this); - setContentView(getMainLayout()); - progress = new ProgressDialog(this); - progress.setCancelable(false); - progress.setCanceledOnTouchOutside(false); - // progress.setOnCancelListener(new OnCancelListener() { - // @Override - // public void onCancel(DialogInterface dialog) { - // - // } - // }); - - initActionBar(); - - initListNavigation(); - - initLeftDrawer(savedInstanceState); - - // new OnNavigationListener() { - // @Override - // public boolean onNavigationItemSelected(int itemPosition, long - // itemId) { - // System.err.println("itemPosition: "+ itemPosition +", itemId:" + - // itemId); - // rturn false; - // } - // }); - - // your logic for click listner - // setListenerForActionBarCustomView(actionBarView); - - // private void setListenerForActionBarCustomView(View actionBarView) { - // ActionBarCustomViewOnClickListener actionBarCustomViewOnClickListener - // = new ActionBarCustomViewOnClickListener(); - // actionBarView.findViewById(R.id.text_view_title).setOnClickListener(actionBarCustomViewOnClickListener); - // } - - } - - protected void initLeftDrawer(final Bundle savedInstanceState) { - - mDrawerTitle = getTitle(); - - mTitles = getResources().getStringArray(R.array.navigation_array); - - mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout); - mDrawerList = (ListView) findViewById(R.id.left_drawer); - - // set a custom shadow that overlays the main content when the drawer - // opens - mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, - GravityCompat.START); - // set up the drawer's list view with items and click listener - mDrawerList.setAdapter(new ArrayAdapter<String>(this, - R.layout.drawer_list_item, mTitles)); - mDrawerList.setOnItemClickListener(new DrawerItemClickListener()); - - // enable ActionBar app icon to behave as action to toggle nav drawer - getSupportActionBar().setDisplayHomeAsUpEnabled(true); - - // ActionBarDrawerToggle ties together the the proper interactions - // between the sliding drawer and the action bar app icon - mDrawerToggle = new ActionBarDrawerToggle(this, /* host Activity */ - mDrawerLayout, /* DrawerLayout object */ - R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */ - R.string.drawer_open, /* "open drawer" description for accessibility */ - R.string.drawer_close /* "close drawer" description for accessibility */ - ) { - public void onDrawerClosed(View view) { - // getSupportActionBar().setTitle(mTitle); - //invalidateOptionsMenu(); // creates call to - // onPrepareOptionsMenu() - } - - public void onDrawerOpened(View drawerView) { - // getSupportActionBar().setTitle(mDrawerTitle); - //invalidateOptionsMenu(); // creates call to - // onPrepareOptionsMenu() - } - }; - mDrawerLayout.setDrawerListener(mDrawerToggle); + public static final int MENU_REFRESH = 99; + + protected T listView; + + protected ViewFlipper flipper; + + private Button retry; + + private ProgressDialog progress; + + protected Preferences getPrefs() { + return Preferences.get(); + } + + // protected SvdrpProgressDialog progress; + + private CharSequence mDrawerTitle; + private DrawerLayout mDrawerLayout; + private ListView mDrawerList; + private ActionBarDrawerToggle mDrawerToggle; + private String[] mTitles; + + abstract protected String getWindowTitle(); + + abstract protected int getMainLayout(); + + protected void noInternetConnection() { + alert(R.string.no_internet_connection); + } + + abstract protected boolean displayingResults(); + + /** + * When using the ActionBarDrawerToggle, you must call it during + * onPostCreate() and onConfigurationChanged()... + */ + + @Override + protected void onPostCreate(Bundle savedInstanceState) { + super.onPostCreate(savedInstanceState); + // Sync the toggle state after onRestoreInstanceState has occurred. + mDrawerToggle.syncState(); + } + + protected boolean isForceRefresh() { + if (forceRefresh == false) { + return false; + } + forceRefresh = false; + return true; + } + + protected boolean forceRefresh = false; + + protected void switchNoConnection() { + if (flipper == null) { + say(R.string.no_connection); + return; + } + + if (displayingResults()) { + say(R.string.no_connection); + } else { + flipper.setDisplayedChild(1); + } + } + + protected CertificateProblemDialog getCertificateProblemDialog() { + return new CertificateProblemDialog(this); + } + + @Override + public void onConfigurationChanged(final Configuration newConfig) { + Preferences.setLocale(this); + super.onConfigurationChanged(newConfig); + mDrawerToggle.onConfigurationChanged(newConfig); + } + + @Override + protected void onResume() { + Preferences.init(this); + super.onResume(); + } + + protected void initFlipper() { + this.flipper = (ViewFlipper) findViewById(R.id.flipper); + retry = (Button) findViewById(R.id.retry_button); + retry.setOnClickListener(this); + } + + @Override + public void onClick(final View v) { + if (v.getId() == R.id.retry_button) { + retry(); + } + } + + // + // protected void updateWindowTitle(int topic, int subtopic) { + // String title; + // title = getString(topic); + // if (subtopic != -1) { + // title += " > " + getString(subtopic); + // } + // setTitle(title); + // } + // + // protected void updateWindowTitle(String topic, String subtopic) { + // String title = topic; + // if (subtopic != null) { + // title += " > " + subtopic; + // } + // setTitle(title); + // } + + abstract protected int getListNavigationIndex(); + + public static final int LIST_NAVIGATION_CHANNELS = 0; + public static final int LIST_NAVIGATION_EPG_BY_TIME = 1; + public static final int LIST_NAVIGATION_EPG_BY_CHANNEL = 2; + public static final int LIST_NAVIGATION_RECORDINGS = 3; + public static final int LIST_NAVIGATION_TIMERS = 4; + public static final int LIST_NAVIGATION_REMOTE = 5; + + protected boolean hasListNavigation() { + return true; + } + + protected void initListNavigation() { + + if (hasListNavigation() == false) { + return; + } + + // getSupportActionBar().setDisplayShowTitleEnabled(false); + // + // getSupportActionBar().setNavigationMode( + // getSupportActionBar().NAVIGATION_MODE_LIST); + // + // final ArrayAdapter<CharSequence> mSpinnerAdapter = ArrayAdapter + // .createFromResource(this, R.array.navigation_array, + // android.R.layout.simple_spinner_dropdown_item); + // + // getSupportActionBar().setListNavigationCallbacks(mSpinnerAdapter, + // new OnNavigationListener() { + // + // private boolean firstHit = true; + // + // @Override + // public boolean onNavigationItemSelected( + // final int itemPosition, final long itemId) { + // + // if (firstHit == true) { + // firstHit = false; + // return false; + // } + // switch (itemPosition) { + // + // case LIST_NAVIGATION_CHANNELS: { + // startActivity(ChannelListActivity.class); + // return true; + // } + // case LIST_NAVIGATION_EPG_BY_TIME: { + // startActivity(TimeEpgListActivity.class); + // return true; + // } + // + // case LIST_NAVIGATION_EPG_BY_CHANNEL: { + // startActivity(EventEpgListActivity.class); + // return true; + // } + // + // case LIST_NAVIGATION_RECORDINGS: { + // startActivity(RecordingListActivity.class); + // return true; + // } + // + // case LIST_NAVIGATION_TIMERS: { + // startActivity(TimerListActivity.class); + // return true; + // } + // + // } + // return false; + // } + // }); + // getSupportActionBar().setSelectedNavigationItem( + // getListNavigationIndex()); + + } + + @Override + protected void onCreate(final Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); + Preferences.setLocale(this); + setContentView(getMainLayout()); + progress = new ProgressDialog(this); + progress.setCancelable(false); + progress.setCanceledOnTouchOutside(false); + // progress.setOnCancelListener(new OnCancelListener() { + // @Override + // public void onCancel(DialogInterface dialog) { + // + // } + // }); + + initActionBar(); + + initListNavigation(); + + initLeftDrawer(savedInstanceState); + + // new OnNavigationListener() { + // @Override + // public boolean onNavigationItemSelected(int itemPosition, long + // itemId) { + // System.err.println("itemPosition: "+ itemPosition +", itemId:" + + // itemId); + // rturn false; + // } + // }); + + // your logic for click listner + // setListenerForActionBarCustomView(actionBarView); + + // private void setListenerForActionBarCustomView(View actionBarView) { + // ActionBarCustomViewOnClickListener actionBarCustomViewOnClickListener + // = new ActionBarCustomViewOnClickListener(); + // actionBarView.findViewById(R.id.text_view_title).setOnClickListener(actionBarCustomViewOnClickListener); + // } + + } + + protected void initLeftDrawer(final Bundle savedInstanceState) { + + mDrawerTitle = getTitle(); + + mTitles = getResources().getStringArray(R.array.navigation_array); + + mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout); + mDrawerList = (ListView) findViewById(R.id.left_drawer); + + // set a custom shadow that overlays the main content when the drawer + // opens + mDrawerLayout.setDrawerShadow(R.drawable.drawer_shadow, + GravityCompat.START); + // set up the drawer's list view with items and click listener + mDrawerList.setAdapter(new ArrayAdapter<String>(this, + R.layout.drawer_list_item, mTitles)); + mDrawerList.setOnItemClickListener(new DrawerItemClickListener()); + + // enable ActionBar app icon to behave as action to toggle nav drawer + getSupportActionBar().setDisplayHomeAsUpEnabled(true); + + // ActionBarDrawerToggle ties together the the proper interactions + // between the sliding drawer and the action bar app icon + mDrawerToggle = new ActionBarDrawerToggle(this, /* host Activity */ + mDrawerLayout, /* DrawerLayout object */ + R.drawable.ic_drawer, /* nav drawer image to replace 'Up' caret */ + R.string.drawer_open, /* "open drawer" description for accessibility */ + R.string.drawer_close /* "close drawer" description for accessibility */ + ) { + public void onDrawerClosed(View view) { + // getSupportActionBar().setTitle(mTitle); + //invalidateOptionsMenu(); // creates call to + // onPrepareOptionsMenu() + } + + public void onDrawerOpened(View drawerView) { + // getSupportActionBar().setTitle(mDrawerTitle); + //invalidateOptionsMenu(); // creates call to + // onPrepareOptionsMenu() + } + }; + mDrawerLayout.setDrawerListener(mDrawerToggle); // if (savedInstanceState == null) { // selectItem(0); // } - } - - /* The click listner for ListView in the navigation drawer */ - private class DrawerItemClickListener implements - ListView.OnItemClickListener { - @Override - public void onItemClick(AdapterView<?> parent, View view, int position, - long id) { - selectItem(position); - } - } - - private void selectItem(int position) { - - // update selected item and title, then close the drawer - mDrawerList.setItemChecked(position, true); - // setTitle(mPlanetTitles[position]); - - switch (position) { - - case LIST_NAVIGATION_CHANNELS: { - startActivity(ChannelListActivity.class); - break; - } - case LIST_NAVIGATION_EPG_BY_TIME: { - startActivity(TimeEpgListActivity.class); - break; - } - - case LIST_NAVIGATION_EPG_BY_CHANNEL: { - startActivity(EventEpgListActivity.class); - break; - } - - case LIST_NAVIGATION_RECORDINGS: { - startActivity(RecordingListActivity.class); - break; - } - - case LIST_NAVIGATION_TIMERS: { - startActivity(TimerListActivity.class); - break; - } - case LIST_NAVIGATION_REMOTE: { - startActivity(RemoteActivity.class); - break; - } - } - - mDrawerLayout.closeDrawer(mDrawerList); - } - - protected void initActionBar() { - getSupportActionBar().setHomeButtonEnabled(true); - } - - public void startActivity(final Class<?> clazz) { - final Intent intent = new Intent(Intent.ACTION_VIEW); - intent.setClass(this, clazz); - startActivity(intent); - finish(); - } - - protected int getBaseMenu() { - return R.menu.refresh_filter_menu; - } - - @Override - public boolean onCreateOptionsMenu(final Menu menu) { - - // MenuItem item; - // item = menu.add(MENU_GROUP_REFRESH, MENU_REFRESH, 0, - // R.string.refresh); - // item.setIcon(R.drawable.ic_menu_refresh); - // item.setAlphabeticShortcut('r'); - final MenuInflater inf = getMenuInflater(); - inf.inflate(getBaseMenu(), menu); - - // SearchView searchView = (SearchView) - // menu.findItem(R.id.menu_search).getActionView(); - // searchView.setSearchableInfo(searchManager.getSearchableInfo(getComponentName())); - - return true; - } - - abstract protected void refresh(); - - abstract protected void retry(); - - // abstract protected SvdrpClient<Result> getClient(); - - @Override - public boolean onOptionsItemSelected(final MenuItem item) { - - if (mDrawerToggle != null && mDrawerToggle.onOptionsItemSelected(item)) { - return true; - } - - switch (item.getItemId()) { - case R.id.list_refresh: - backupViewSelection(); - refresh(); - return true; - case R.id.list_filter: { - onSearchRequested(); - return true; - } - case android.R.id.home: - final Intent intent = new Intent(this, VdrManagerActivity.class); - intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); - startActivity(intent); - return true; - default: - return false; - } - } - - protected void setCurrent(final Channel channel) { - getApp().setCurrentChannel(channel); - } - - protected VdrManagerApp getApp() { - final VdrManagerApp app = (VdrManagerApp) getApplication(); - return app; - } - - // protected Channel getCurrentChannel(){ - // final Channel channel = ((VdrManagerApp) getApplication()) - // .getCurrentChannel(); - // return channel; - // } - - protected void say(final int res) { - say(this.getString(res)); - } - - protected void say(final String msg) { - Utils.say(this, msg); - } - - protected boolean noConnection(final SvdrpEvent event) { - switch (event) { - case CONNECTION_TIMEOUT: - say(R.string.progress_connect_timeout); - switchNoConnection(); - case CONNECT_ERROR: - say(R.string.progress_connect_error); - switchNoConnection(); - break; - case FINISHED_ABNORMALY: - alert(R.string.progress_connect_finished_abnormal); - switchNoConnection(); - break; - case LOGIN_ERROR: - say(R.string.progress_login_error); - switchNoConnection(); - break; - default: - return false; - } - return true; - } - - protected void alert(final String msg) { - if (isFinishing()) { - return; - } - new AlertDialog.Builder(this)// - .setMessage(msg)// - .setPositiveButton(android.R.string.ok, null)// - .create()// - .show();// - } - - protected void alert(final int resId) { - alert(getString(resId)); - } - - protected void restoreViewSelection() { - listView.setSelectionFromTop(index, top); - } - - protected void backupViewSelection() { - index = listView.getFirstVisiblePosition(); - final View v = listView.getChildAt(0); - top = (v == null) ? 0 : v.getTop(); - } - - int index; - int top; - - protected boolean checkInternetConnection() { - if (Utils.checkInternetConnection(this)) { - return true; - } - noInternetConnection(); - return false; - } - - // public void svdrpEvent(Result result) { - // resultReceived(result); - // } - - @Override - public void svdrpEvent(final SvdrpEvent event, final Throwable t) { - progress.dismiss(); - Utils.say(this, t.getMessage()); - } - - protected void addListener( - final SvdrpAsyncTask<Result, SvdrpClient<Result>> task) { - task.addSvdrpExceptionListener(this); - task.addSvdrpListener(this); - task.addSvdrpFinishedListener(this); - } - - @Override - public void svdrpEvent(final SvdrpEvent event) { - - switch (event) { - case LOGIN: - break; - case COMMAND_SENDING: - break; - case CONNECTING: - progress.setProgressStyle(ProgressDialog.STYLE_SPINNER); - setMessage(R.string.progress_connect); - if (!isFinishing()) { - progress.show(); - } - break; - case LOGGED_IN: - setMessage(R.string.progress_login); - break; - case COMMAND_SENT: - setMessage(getProgressTextId()); - break; - case DISCONNECTING: - setMessage(R.string.progress_disconnect); - break; - case DISCONNECTED: - break; - case ABORTED: - progress.dismiss(); - say(R.string.aborted); - break; - case ERROR: - progress.dismiss(); - alert(R.string.epg_client_errors); - break; - case CONNECTED: - connected(); - break; - case CONNECTION_TIMEOUT: - case CONNECT_ERROR: - case FINISHED_ABNORMALY: - case LOGIN_ERROR: - progress.dismiss(); - noConnection(event); - break; - case CACHE_HIT: - progress.dismiss(); - cacheHit(); - return; - case FINISHED_SUCCESS: - progress.dismiss(); - break; - } - // case RESULT_RECEIVED: - // resultReceived(result); - // break; - // } - } - - protected int getProgressTextId() { - return R.string.progress_loading; - } - - private void setMessage(final int progressConnect) { - progress.setMessage(getString(progressConnect)); - } - - protected boolean finishedSuccess = false; - - protected void cacheHit() { - - } - - /** - * @return false, if no results found - */ - protected abstract boolean finishedSuccess(List<Result> results); - - // /** - // * @param result - // */ - // protected abstract void resultReceived(Result result); - - protected void connected() { - if (flipper != null) { - flipper.setDisplayedChild(0); - } - } - - public void svdrpException(final SvdrpException exception) { - // svdrpException(exception); - // Log.w(TAG, exception); - alert(getString(R.string.vdr_error_text, exception.getMessage())); - } - - @Override - protected void onDestroy() { - if (progress.isShowing()) { - progress.dismiss(); - } - super.onDestroy(); - } - - @Override - public void finished(final List<Result> results) { - if (finishedSuccess(results)) { - finishedSuccess = true; - restoreViewSelection(); - } else { - say(R.string.epg_no_items); - } - } + } + + /* The click listner for ListView in the navigation drawer */ + private class DrawerItemClickListener implements + ListView.OnItemClickListener { + @Override + public void onItemClick(AdapterView<?> parent, View view, int position, + long id) { + selectItem(position); + } + } + + private void selectItem(int position) { + + // update selected item and title, then close the drawer + mDrawerList.setItemChecked(position, true); + // setTitle(mPlanetTitles[position]); + + switch (position) { + + case LIST_NAVIGATION_CHANNELS: { + startActivity(ChannelListActivity.class); + break; + } + case LIST_NAVIGATION_EPG_BY_TIME: { + startActivity(TimeEpgListActivity.class); + break; + } + + case LIST_NAVIGATION_EPG_BY_CHANNEL: { + startActivity(EventEpgListActivity.class); + break; + } + + case LIST_NAVIGATION_RECORDINGS: { + startActivity(RecordingListActivity.class); + break; + } + + case LIST_NAVIGATION_TIMERS: { + startActivity(TimerListActivity.class); + break; + } + case LIST_NAVIGATION_REMOTE: { + startActivity(RemoteActivity.class); + break; + } + } + + mDrawerLayout.closeDrawer(mDrawerList); + } + + protected void initActionBar() { + getSupportActionBar().setHomeButtonEnabled(true); + } + + public void startActivity(final Class<?> clazz) { + final Intent intent = new Intent(Intent.ACTION_VIEW); + intent.setClass(this, clazz); + startActivity(intent); + finish(); + } + + protected int getBaseMenu() { + return R.menu.refresh_filter_menu; + } + + @Override + public boolean onCreateOptionsMenu(final Menu menu) { + + // MenuItem item; + // item = menu.add(MENU_GROUP_REFRESH, MENU_REFRESH, 0, + // R.string.refresh); + // item.setIcon(R.drawable.ic_menu_refresh); + // item.setAlphabeticShortcut('r'); + final MenuInflater inf = getMenuInflater(); + inf.inflate(getBaseMenu(), menu); + + // SearchView searchView = (SearchView) + // menu.findItem(R.id.menu_search).getActionView(); + // searchView.setSearchableInfo(searchManager.getSearchableInfo(getComponentName())); + + return true; + } + + abstract protected void refresh(); + + abstract protected void retry(); + + // abstract protected SvdrpClient<Result> getClient(); + + @Override + public boolean onOptionsItemSelected(final MenuItem item) { + + if (mDrawerToggle != null && mDrawerToggle.onOptionsItemSelected(item)) { + return true; + } + + switch (item.getItemId()) { + case R.id.list_refresh: + backupViewSelection(); + refresh(); + return true; + case R.id.list_filter: { + onSearchRequested(); + return true; + } + case android.R.id.home: + final Intent intent = new Intent(this, VdrManagerActivity.class); + intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); + startActivity(intent); + return true; + default: + return false; + } + } + + protected void setCurrent(final Channel channel) { + getApp().setCurrentChannel(channel); + } + + protected VdrManagerApp getApp() { + final VdrManagerApp app = (VdrManagerApp) getApplication(); + return app; + } + + // protected Channel getCurrentChannel(){ + // final Channel channel = ((VdrManagerApp) getApplication()) + // .getCurrentChannel(); + // return channel; + // } + + protected void say(final int res) { + say(this.getString(res)); + } + + protected void say(final String msg) { + Utils.say(this, msg); + } + + protected boolean noConnection(final SvdrpEvent event) { + switch (event) { + case CONNECTION_TIMEOUT: + say(R.string.progress_connect_timeout); + switchNoConnection(); + case CONNECT_ERROR: + say(R.string.progress_connect_error); + switchNoConnection(); + break; + case FINISHED_ABNORMALY: + alert(R.string.progress_connect_finished_abnormal); + switchNoConnection(); + break; + case LOGIN_ERROR: + say(R.string.progress_login_error); + switchNoConnection(); + break; + default: + return false; + } + return true; + } + + protected void alert(final String msg) { + if (isFinishing()) { + return; + } + new AlertDialog.Builder(this)// + .setMessage(msg)// + .setPositiveButton(android.R.string.ok, null)// + .create()// + .show();// + } + + protected void alert(final int resId) { + alert(getString(resId)); + } + + protected void restoreViewSelection() { + listView.setSelectionFromTop(index, top); + } + + protected void backupViewSelection() { + index = listView.getFirstVisiblePosition(); + final View v = listView.getChildAt(0); + top = (v == null) ? 0 : v.getTop(); + } + + int index; + int top; + + protected boolean checkInternetConnection() { + if (Utils.checkInternetConnection(this)) { + return true; + } + noInternetConnection(); + return false; + } + + // public void svdrpEvent(Result result) { + // resultReceived(result); + // } + + @Override + public void svdrpEvent(final SvdrpEvent event, final Throwable t) { + progress.dismiss(); + Utils.say(this, t.getMessage()); + } + + protected void addListener( + final SvdrpAsyncTask<Result, SvdrpClient<Result>> task) { + task.addSvdrpExceptionListener(this); + task.addSvdrpListener(this); + task.addSvdrpFinishedListener(this); + } + + @Override + public void svdrpEvent(final SvdrpEvent event) { + + switch (event) { + case LOGIN: + break; + case COMMAND_SENDING: + break; + case CONNECTING: + progress.setProgressStyle(ProgressDialog.STYLE_SPINNER); + setMessage(R.string.progress_connect); + if (!isFinishing()) { + progress.show(); + } + break; + case LOGGED_IN: + setMessage(R.string.progress_login); + break; + case COMMAND_SENT: + setMessage(getProgressTextId()); + break; + case DISCONNECTING: + setMessage(R.string.progress_disconnect); + break; + case DISCONNECTED: + break; + case ABORTED: + progress.dismiss(); + say(R.string.aborted); + break; + case ERROR: + progress.dismiss(); + alert(R.string.epg_client_errors); + break; + case CONNECTED: + connected(); + break; + case CONNECTION_TIMEOUT: + case CONNECT_ERROR: + case FINISHED_ABNORMALY: + case LOGIN_ERROR: + progress.dismiss(); + noConnection(event); + break; + case CACHE_HIT: + progress.dismiss(); + cacheHit(); + return; + case FINISHED_SUCCESS: + progress.dismiss(); + break; + } + // case RESULT_RECEIVED: + // resultReceived(result); + // break; + // } + } + + protected int getProgressTextId() { + return R.string.progress_loading; + } + + private void setMessage(final int progressConnect) { + progress.setMessage(getString(progressConnect)); + } + + protected boolean finishedSuccess = false; + + protected void cacheHit() { + + } + + /** + * @return false, if no results found + */ + protected abstract boolean finishedSuccess(List<Result> results); + + // /** + // * @param result + // */ + // protected abstract void resultReceived(Result result); + + protected void connected() { + if (flipper != null) { + flipper.setDisplayedChild(0); + } + } + + public void svdrpException(final SvdrpException exception) { + // svdrpException(exception); + // Log.w(TAG, exception); + alert(getString(R.string.vdr_error_text, exception.getMessage())); + } + + @Override + protected void onDestroy() { + if (progress.isShowing()) { + progress.dismiss(); + } + super.onDestroy(); + } + + @Override + public void finished(final List<Result> results) { + if (finishedSuccess(results)) { + finishedSuccess = true; + restoreViewSelection(); + } else { + say(R.string.epg_no_items); + } + } } diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ChannelListActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ChannelListActivity.java index d5b0b3f..5b78c05 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ChannelListActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ChannelListActivity.java @@ -29,6 +29,7 @@ import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.data.RecenteChannel; import de.bjusystems.vdrmanager.data.db.DBAccess; import de.bjusystems.vdrmanager.tasks.VoidAsyncTask; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; import de.bjusystems.vdrmanager.utils.svdrp.ChannelClient; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpAsyncTask; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpClient; @@ -50,26 +51,53 @@ public class ChannelListActivity extends private static final String TAG = ChannelListActivity.class.getName(); + /** + * The Adapter. + */ ChannelAdapter adapter; + /** + * The Prefs. + */ Preferences prefs; // private static final LinkedList<Channel> RECENT = new // LinkedList<Channel>(); + /** + * The constant MENU_GROUP. + */ public static final int MENU_GROUP = 0; + /** + * The constant MENU_PROVIDER. + */ public static final int MENU_PROVIDER = 1; + /** + * The constant MENU_SOURCE. + */ public static final int MENU_SOURCE = 2; + /** + * The constant MENU_NAME. + */ public static final int MENU_NAME = 3; + /** + * The constant GROUP_NATURAL. + */ public static final boolean GROUP_NATURAL = false; + /** + * The constant GROUP_REVERSE. + */ public static final boolean GROUP_REVERSE = true; private int groupBy; private boolean groupByReverse; + /** + * The constant ALL_CHANNELS_GROUP. + */ final static ArrayList<String> ALL_CHANNELS_GROUP = new ArrayList<String>(1); @Override @@ -82,6 +110,8 @@ public class ChannelListActivity extends @Override protected void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); // Attach view @@ -147,12 +177,26 @@ public class ChannelListActivity extends task.run(); } + /** + * The Recent adapter. + */ static RecentChannelsAdapter RECENT_ADAPTER = null; + /** + * The type Recent channels adapter. + */ static class RecentChannelsAdapter extends ArrayAdapter<Channel> { private final Activity context; + /** + * The Res id. + */ int resId; + /** + * Instantiates a new Recent channels adapter. + * + * @param context the context + */ public RecentChannelsAdapter(final Activity context) { super(context, android.R.layout.simple_list_item_1); this.context = context; @@ -165,6 +209,9 @@ public class ChannelListActivity extends } } + /** + * The Show channel numbers. + */ public boolean showChannelNumbers; @Override @@ -285,6 +332,9 @@ public class ChannelListActivity extends return R.array.channels_group_by; } + /** + * The Group by dialog. + */ AlertDialog groupByDialog = null; @Override diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ColoredButton.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ColoredButton.java index f10860c..8f09496 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ColoredButton.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/ColoredButton.java @@ -1,7 +1,6 @@ package de.bjusystems.vdrmanager.gui; import android.content.Context; -import android.content.res.Resources; import android.content.res.TypedArray; import android.graphics.Color; import android.graphics.CornerPathEffect; @@ -15,14 +14,13 @@ import android.graphics.drawable.StateListDrawable; import android.graphics.drawable.shapes.RectShape; import android.os.Build; import android.util.AttributeSet; -import android.widget.Button; import de.bjusystems.vdrmanager.R; /** * Created by lado on 03.05.15. */ -public class ColoredButton extends Button { +public class ColoredButton extends android.support.v7.widget.AppCompatButton { private final float defaultRadius = 0.0f; @@ -89,4 +87,4 @@ private int defaultPrimaryColor; } //typedArray.recycle(); } -}
\ No newline at end of file +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java index b063854..031f413 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/EpgDetailsActivity.java @@ -11,7 +11,7 @@ import android.os.Parcelable; import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; -import android.support.v7.app.ActionBarActivity; +import android.support.v7.app.AppCompatActivity; import android.util.Log; import android.view.Menu; import android.view.MenuInflater; @@ -23,7 +23,9 @@ import android.widget.ImageView; import android.widget.ProgressBar; import android.widget.TextView; import android.widget.Toast; + import com.viewpagerindicator.TitleProvider; + import de.bjusystems.vdrmanager.R; import de.bjusystems.vdrmanager.app.Intents; import de.bjusystems.vdrmanager.app.VdrManagerApp; @@ -41,6 +43,7 @@ import de.bjusystems.vdrmanager.tasks.CreateTimerTask; import de.bjusystems.vdrmanager.tasks.DeleteTimerTask; import de.bjusystems.vdrmanager.tasks.ToggleTimerTask; import de.bjusystems.vdrmanager.tasks.VoidAsyncTask; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpEvent; import java.net.URLEncoder; @@ -53,7 +56,7 @@ import java.util.List; * * @author bju22 */ -public class EpgDetailsActivity extends ActionBarActivity implements +public class EpgDetailsActivity extends AppCompatActivity implements OnClickListener, OnPageChangeListener, View.OnLongClickListener { public static final String TAG = "EpgDetailsActivity"; @@ -95,7 +98,7 @@ public class EpgDetailsActivity extends ActionBarActivity implements return true; } - final Timer timer = new Timer(cEvent); + final Timer timer = new Timer(cEvent); Date start = new Date(timer.getStart().getTime() - Preferences.get().getTimerPreMargin() * 60000); @@ -105,29 +108,30 @@ public class EpgDetailsActivity extends ActionBarActivity implements + Preferences.get().getTimerPostMargin() * 60000); timer.setStop(end); - final CreateTimerTask task = new CreateTimerTask( - EpgDetailsActivity.this, timer) { - boolean error = false; - @Override - public void svdrpEvent(final SvdrpEvent event, Throwable th) { - if(event == SvdrpEvent.ERROR){ - error = true; - } - super.svdrpEvent(event, th); + final CreateTimerTask task = new CreateTimerTask( + EpgDetailsActivity.this, timer) { + boolean error = false; + + @Override + public void svdrpEvent(final SvdrpEvent event, Throwable th) { + if (event == SvdrpEvent.ERROR) { + error = true; } + super.svdrpEvent(event, th); + } - @Override - public void finished(SvdrpEvent event) { - modifed = true; - EpgCache.CACHE.remove(timer - .getChannelId()); - if(error == false && event == SvdrpEvent.FINISHED_SUCCESS) { - say(R.string.timer_created); - } + @Override + public void finished(SvdrpEvent event) { + modifed = true; + EpgCache.CACHE.remove(timer + .getChannelId()); + if (error == false && event == SvdrpEvent.FINISHED_SUCCESS) { + say(R.string.timer_created); } - }; - task.start(); - return true; + } + }; + task.start(); + return true; } @@ -184,6 +188,8 @@ public class EpgDetailsActivity extends ActionBarActivity implements @Override protected void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); getSupportActionBar().setHomeButtonEnabled(true); // requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS); @@ -544,7 +550,7 @@ public class EpgDetailsActivity extends ActionBarActivity implements final Event cEvent = epgs.get(pager.getCurrentItem()); - if(v.getId() == R.id.epg_event_livetv) { + if (v.getId() == R.id.epg_event_livetv) { if (cEvent instanceof Recording) { Utils.streamRecording(this, (Recording) cEvent); } else { @@ -790,7 +796,7 @@ public class EpgDetailsActivity extends ActionBarActivity implements public void onPageSelected(int position) { Event cEvent = epgs.get(position); - if(cEvent == null){ + if (cEvent == null) { return; } String cn = cEvent.getChannelName(); diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/PreferencesActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/PreferencesActivity.java index 4dce431..5688bc7 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/PreferencesActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/PreferencesActivity.java @@ -12,7 +12,11 @@ import android.preference.PreferenceManager; import de.bjusystems.vdrmanager.R; import de.bjusystems.vdrmanager.backup.BackupSettingsActivity; import de.bjusystems.vdrmanager.data.Preferences; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; +/** + * The type Preferences activity. + */ public class PreferencesActivity extends BasePreferencesActivity implements OnSharedPreferenceChangeListener, OnPreferenceChangeListener, OnPreferenceClickListener { @@ -29,6 +33,8 @@ public class PreferencesActivity extends BasePreferencesActivity implements @Override protected void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); this.getPreferenceManager().setSharedPreferencesName( Preferences.getPreferenceFile(this)); @@ -49,7 +55,13 @@ public class PreferencesActivity extends BasePreferencesActivity implements updateChildPreferences(); } - // /** Return a properly configured SharedPreferences instance */ + /** + * Gets shared preferences. + * + * @param context the context + * @return the shared preferences + */ +// /** Return a properly configured SharedPreferences instance */ public static SharedPreferences getSharedPreferences(Context context) { return PreferenceManager.getDefaultSharedPreferences(context); } diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/TimerDetailsActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/TimerDetailsActivity.java index 1b30890..1ea3046 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/TimerDetailsActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/TimerDetailsActivity.java @@ -34,17 +34,30 @@ import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.data.Timer; import de.bjusystems.vdrmanager.tasks.CreateTimerTask; import de.bjusystems.vdrmanager.tasks.ModifyTimerTask; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; import de.bjusystems.vdrmanager.utils.date.DateFormatter; import de.bjusystems.vdrmanager.utils.svdrp.SetTimerClient.TimerOperation; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpEvent; +/** + * The type Timer details activity. + */ public class TimerDetailsActivity extends Activity implements OnClickListener, OnDateSetListener, OnTimeSetListener { + /** + * The constant REQUEST_CODE_TIMER_MODIFIED. + */ public static final int REQUEST_CODE_TIMER_MODIFIED = 34; + /** + * The constant REQUEST_CODE_TIMER_EDIT. + */ public static final int REQUEST_CODE_TIMER_EDIT = 35; + /** + * The constant REQUEST_CODE_TIMER_ADD. + */ public static final int REQUEST_CODE_TIMER_ADD = 36; private CharSequence prevStart; @@ -56,6 +69,8 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); View view = getLayoutInflater().inflate(R.layout.timer_detail, null); tView = new EditTimerViewHolder(); tView.view = view; @@ -170,29 +185,80 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, tView.dateField.setEnabled(true); } + /** + * The type Edit timer view holder. + */ public class EditTimerViewHolder { + /** + * The View. + */ View view; + /** + * The Title. + */ TextView title; + /** + * The Channel. + */ TextView channel; + /** + * The Date field. + */ Button dateField; + /** + * The Start field. + */ Button startField; + /** + * The End field. + */ Button endField; + /** + * The Save button. + */ Button saveButton; + /** + * The Modify button. + */ Button modifyButton; + /** + * The Vps. + */ CheckBox vps; + /** + * The Repeat. + */ Button repeat; + /** + * The Priority. + */ EditText priority; + /** + * The Lifecycle. + */ EditText lifecycle; } + /** + * The T view. + */ EditTimerViewHolder tView = null; + /** + * The Edit start. + */ boolean editStart; // SetTimerClient setTimerClient; + /** + * The Timer. + */ Timer timer; + /** + * The Original. + */ Timer original; private void updateDates(Date start, Date stop) { @@ -261,15 +327,26 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, } + /** + * Gets app. + * + * @return the app + */ protected VdrManagerApp getApp() { final VdrManagerApp app = (VdrManagerApp) getApplication(); return app; } + /** + * Add. + */ public void add() { updateDisplay(TimerOperation.CREATE); } + /** + * Modify. + */ public void modify() { updateDisplay(TimerOperation.MODIFY); } @@ -384,6 +461,11 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, } } + /** + * Gets selected items. + * + * @return the selected items + */ DaysOfWeek getSelectedItems() { String str = timer.getWeekdays(); @@ -410,6 +492,11 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, return Integer.valueOf(text.getText().toString()); } + /** + * Say. + * + * @param res the res + */ protected void say(int res) { Toast.makeText(this, res, Toast.LENGTH_SHORT).show(); } @@ -475,6 +562,9 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, task.start(); } + /** + * Done. + */ public void done() { setResult(RESULT_OK); finish(); @@ -490,6 +580,9 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, task.start(); } + /** + * The type Days of week. + */ /* * Days of week code as a single int. 0x00: no day 0x01: Monday 0x02: * Tuesday 0x04: Wednesday 0x08: Thursday 0x10: Friday 0x20: Saturday 0x40: @@ -504,10 +597,22 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, // Bitmask of all repeating days private int mDays; + /** + * Instantiates a new Days of week. + * + * @param days the days + */ DaysOfWeek(int days) { mDays = days; } + /** + * To string string. + * + * @param context the context + * @param showNever the show never + * @return the string + */ public String toString(Context context, boolean showNever) { StringBuilder ret = new StringBuilder(); @@ -551,6 +656,12 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, return ((mDays & (1 << day)) > 0); } + /** + * Set. + * + * @param day the day + * @param set the set + */ public void set(int day, boolean set) { if (set) { mDays |= (1 << day); @@ -559,15 +670,30 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, } } + /** + * Set. + * + * @param dow the dow + */ public void set(DaysOfWeek dow) { mDays = dow.mDays; } + /** + * Gets coded. + * + * @return the coded + */ public int getCoded() { return mDays; } - // Returns days of week encoded in an array of booleans. + /** + * Get boolean array boolean [ ]. + * + * @return the boolean [ ] + */ +// Returns days of week encoded in an array of booleans. public boolean[] getBooleanArray() { boolean[] ret = new boolean[7]; for (int i = 0; i < 7; i++) { @@ -576,6 +702,11 @@ public class TimerDetailsActivity extends Activity implements OnClickListener, return ret; } + /** + * Is repeat set boolean. + * + * @return the boolean + */ public boolean isRepeatSet() { return mDays != 0; } diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/Utils.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/Utils.java index a880fcf..6c57ecc 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/Utils.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/Utils.java @@ -45,16 +45,38 @@ import de.bjusystems.vdrmanager.utils.svdrp.SvdrpException; import de.bjusystems.vdrmanager.utils.svdrp.SvdrpListener; import de.bjusystems.vdrmanager.utils.svdrp.SwitchChannelClient; +/** + * The type Utils. + */ public class Utils { + /** + * The constant TAG. + */ public static final String TAG = Utils.class.getName(); + /** + * The constant EMPTY_LIST. + */ public static final List EMPTY_LIST = new ArrayList(0); + /** + * The constant EMPTY. + */ public static final String[] EMPTY = new String[]{}; + /** + * The constant HIGHLIGHT_TEXT. + */ public static final ForegroundColorSpan HIGHLIGHT_TEXT = new ForegroundColorSpan( Color.RED); + /** + * Highlight char sequence. + * + * @param where the where + * @param what the what + * @return the char sequence + */ public static CharSequence highlight(final String where, String what) { if (TextUtils.isEmpty(what)) { return where; @@ -72,6 +94,13 @@ public class Utils { return ss; } + /** + * Highlight 2 pair. + * + * @param where the where + * @param what the what + * @return the pair + */ public static Pair<Boolean, CharSequence> highlight2(final String where, String what) { if (TextUtils.isEmpty(what)) { @@ -90,11 +119,24 @@ public class Utils { return Pair.create(Boolean.TRUE, (CharSequence) ss); } + /** + * Gets progress. + * + * @param start the start + * @param stop the stop + * @return the progress + */ public static int getProgress(final Date start, final Date stop) { final long now = System.currentTimeMillis(); return getProgress(now, start.getTime(), stop.getTime()); } + /** + * Gets progress. + * + * @param e the e + * @return the progress + */ public static int getProgress(final Event e) { if (e instanceof Recording == false) { return getProgress(e.getStart(), e.getStop()); @@ -109,8 +151,8 @@ public class Utils { /** * @param now - * @param time - * @param time2 + * @param start + * @param stop * @return -1, is not not between start stop, */ private static int getProgress(final long now, final long start, @@ -123,6 +165,12 @@ public class Utils { return -1; } + /** + * Is live boolean. + * + * @param event the event + * @return the boolean + */ public static boolean isLive(final Event event) { final long now = System.currentTimeMillis(); return now >= event.getStart().getTime() @@ -175,14 +223,42 @@ public class Utils { return sb.toString(); } + /** + * Stream. + * + * @param activity the activity + * @param event the event + */ public static void stream(final Activity activity, final Event event) { stream(activity, event.getStreamId()); } + /** + * Stream. + * + * @param activity the activity + * @param channel the channel + */ public static void stream(final Activity activity, final Channel channel) { stream(activity, channel.getId()); } + /** + * Stream. + * + * @param activity the activity + * @param rec the channel + */ + public static void stream(final Activity activity, final Recording rec) { + stream(activity, rec.getDevInode()); + } + + /** + * Stream. + * + * @param activity the activity + * @param idornr the idornr + */ public static void stream(final Activity activity, final String idornr) { if (Preferences.get().isEnableRemux() == false) { @@ -224,10 +300,16 @@ public class Utils { }).create().show(); } + /** + * Start stream. + * + * @param activity the activity + * @param url the url + */ public static void startStream(final Activity activity, final String url) { try { final Intent intent = new Intent(Intent.ACTION_VIEW); - intent.setDataAndType(Uri.parse(url.toString()), "video/*"); + intent.setDataAndType(Uri.parse(url), "video/*"); activity.startActivityForResult(intent, 1); } catch (final ActivityNotFoundException anfe) { Log.w(TAG, anfe); @@ -236,6 +318,12 @@ public class Utils { } } + /** + * Md 5 string. + * + * @param s the s + * @return the string + */ public static final String md5(final String s) { try { // Create MD5 Hash @@ -261,12 +349,24 @@ public class Utils { return ""; } + /** + * Gets duration. + * + * @param event the event + * @return the duration + */ public static int getDuration(final Event event) { final long millis = event.getDuration(); final int minuts = (int) (millis / 1000 / 60); return minuts; } + /** + * Share event. + * + * @param activity the activity + * @param event the event + */ public static void shareEvent(final Activity activity, final Event event) { final Intent share = new Intent(android.content.Intent.ACTION_SEND); share.setType("text/plain"); @@ -290,6 +390,12 @@ public class Utils { activity.getString(R.string.share_chooser))); } + /** + * Add calendar event. + * + * @param activity the activity + * @param event the event + */ public static void addCalendarEvent(final Activity activity, final Event event) { final Intent intent = new Intent(Intent.ACTION_EDIT); @@ -301,6 +407,12 @@ public class Utils { activity.startActivity(intent); } + /** + * Map special chars string. + * + * @param src the src + * @return the string + */ public static String mapSpecialChars(final String src) { if (src == null) { return ""; @@ -308,6 +420,12 @@ public class Utils { return src.replace("|##", C.DATA_SEPARATOR).replace("||#", "\n"); } + /** + * Un map special chars string. + * + * @param src the src + * @return the string + */ public static String unMapSpecialChars(final String src) { if (src == null) { return ""; @@ -315,6 +433,12 @@ public class Utils { return src.replace(C.DATA_SEPARATOR, "|##").replace("\n", "||#"); } + /** + * Gets package info. + * + * @param ctx the ctx + * @return the package info + */ public static PackageInfo getPackageInfo(final Context ctx) { PackageInfo pi = null; try { @@ -326,6 +450,12 @@ public class Utils { return pi; } + /** + * Check internet connection boolean. + * + * @param ctx the ctx + * @return the boolean + */ public static boolean checkInternetConnection(final Context ctx) { final ConnectivityManager cm = (ConnectivityManager) ctx .getSystemService(Context.CONNECTIVITY_SERVICE); @@ -337,7 +467,7 @@ public class Utils { return false; } - private static String getRecordingStream(final Activity ctx, + private static String getRecordingStream(final Context ctx, final Recording rec) { @@ -388,20 +518,71 @@ public class Utils { return url.toString(); } - public static void streamRecording(final Activity ctx, final Recording rec) { + + public static void streamRecording(final Activity activity, final Recording rec) { + + + if (Preferences.get().isEnableRemux() == false) { + streamRecordingDirect(activity, rec); + return; + } + + final String sf = Preferences.get().getStreamFormat(); + final String ext = activity.getString(R.string.remux_title); + new AlertDialog.Builder(activity) + .setTitle(R.string.stream_via_as) + // + .setItems( + new String[]{ + activity.getString(R.string.stream_as, sf), + activity.getString(R.string.stream_via, ext)},// TODO + // add + // here + // what + // will + // be + // used + new DialogInterface.OnClickListener() { + @Override + public void onClick(final DialogInterface dialog, + final int which) { + switch (which) { + case 0: + streamRecordingDirect(activity, rec); + break; + case 1: + startStream(activity, getRemuxStreamUrl(rec.getDevInode())); + break; + } + } + }).create().show(); + + + } + + + private static void streamRecordingDirect(final Activity ctx, final Recording rec) { final String urlstring = getRecordingStream(ctx, rec); Log.d(TAG, "try stream: " + urlstring); Utils.startStream(ctx, urlstring); } + /** + * Switch to. + * + * @param activity the activity + * @param channel the channel + */ public static void switchTo(final Activity activity, final Channel channel) { switchTo(activity, channel.getId(), channel.getName()); } /** - * @param ctx - * @param id - * @param name Optional für die Anzeige + * Switch to. + * + * @param activity the activity + * @param id the id + * @param name Optional für die Anzeige */ public static void switchTo(final Activity activity, final String id, final String name) { @@ -436,20 +617,45 @@ public class Utils { task.run(); } + /** + * Say. + * + * @param ctx the ctx + * @param msg the msg + */ public static void say(final Context ctx, final String msg) { final Toast t = Toast.makeText(ctx, msg, Toast.LENGTH_SHORT); t.setGravity(Gravity.CENTER, 0, 0); t.show(); } + /** + * Encode url path string. + * + * @param path the path + * @return the string + */ public static String encodeUrlPath(String path) { return path.replaceAll("%", "%25"); } + /** + * Say. + * + * @param ctx the ctx + * @param msg the msg + */ public static void say(final Context ctx, final int msg) { say(ctx, msg, Toast.LENGTH_SHORT); } + /** + * Say. + * + * @param ctx the ctx + * @param msg the msg + * @param duration the duration + */ public static void say(final Context ctx, final int msg, final int duration) { final Toast t = Toast.makeText(ctx, msg, duration); t.setGravity(Gravity.CENTER, 0, 0); @@ -461,8 +667,8 @@ public class Utils { * * @param context the context * @param time the time in milliseconds + * @return the string */ - public static String formatDateTime(final Context context, final long time) { return android.text.format.DateFormat.getDateFormat(context).format( time) @@ -471,6 +677,16 @@ public class Utils { DateUtils.FORMAT_SHOW_TIME).toString(); } + /** + * Gets timer state drawable. + * + * @param match the match + * @param full the full + * @param begin the begin + * @param end the end + * @param conflict the conflict + * @return the timer state drawable + */ public static int getTimerStateDrawable(final TimerMatch match, final int full, final int begin, final int end, final int conflict) { @@ -486,6 +702,13 @@ public class Utils { } } + /** + * Format audio string. + * + * @param context the context + * @param tracks the tracks + * @return the string + */ public static String formatAudio(final Context context, final List<AudioTrack> tracks) { @@ -505,6 +728,13 @@ public class Utils { } + /** + * Gets timer match. + * + * @param event the event + * @param timer the timer + * @return the timer match + */ public static TimerMatch getTimerMatch(Event event, Timer timer) { if (timer == null) { return null; @@ -522,6 +752,12 @@ public class Utils { return timerMatch; } + /** + * Content to string int. + * + * @param c the c + * @return the int + */ public static int contentToString(int c) { ; switch (c & 0xF0) { @@ -743,6 +979,13 @@ public class Utils { return R.string.Content_Unknown; } + /** + * Gets conten string. + * + * @param ctx the ctx + * @param contents the contents + * @return the conten string + */ public static String getContenString(Context ctx, int[] contents) { if (contents.length == 0) { @@ -762,6 +1005,12 @@ public class Utils { return sb.toString(); } + /** + * Is serie boolean. + * + * @param contents the contents + * @return the boolean + */ public static boolean isSerie(int[] contents) { if (contents.length == 0) { return false; diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrListActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrListActivity.java index af1b532..05a8368 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrListActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrListActivity.java @@ -19,6 +19,10 @@ import android.widget.AdapterView.OnItemLongClickListener; import android.widget.ArrayAdapter; import android.widget.ListView; import android.widget.TextView; + +import java.util.ArrayList; +import java.util.List; + import de.bjusystems.vdrmanager.R; import de.bjusystems.vdrmanager.app.Intents; import de.bjusystems.vdrmanager.backup.BackupSettingsActivity; @@ -27,276 +31,274 @@ import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.data.Vdr; import de.bjusystems.vdrmanager.data.db.DBAccess; -import java.util.ArrayList; -import java.util.List; - public class VdrListActivity extends AppCompatActivity implements - OnItemClickListener, OnItemLongClickListener, View.OnClickListener { - - private static final String TAG = VdrListActivity.class.getName(); - - List<Vdr> list = new ArrayList<Vdr>(); - - ArrayAdapter<Vdr> adapter = null; - - // Cursor cursor; - - String[] listItems = {}; - - private boolean emptyConfig = false; - - // private void initCursor() { - // - // //if (cursor != null) { - // //if (!cursor.isClosed()) { - // //cursor.close(); - // // } - // //} - // try { - // cursor = getHelper().getVdrCursor(); - // //startManagingCursor(cursor); - // } catch (Exception ex) { - // Log.w(TAG,ex); - // } - // } - - private void populateIntent() { - emptyConfig = getIntent().getBooleanExtra(Intents.EMPTY_CONFIG, - Boolean.FALSE); - } - - - @Override - public void onClick(View v) { - - if(v.getId() == R.id.new_vdr){ - editVdr(null); - return; - } - - } - - static class Holder { - public TextView text1; - public TextView text2; - } - - /** Called when the activity is first created. */ - @Override - public void onCreate(Bundle savedInstanceState) { - super.onCreate(savedInstanceState); - - populateIntent(); - - setContentView(R.layout.vdr_list_add_delete); - - - findViewById(R.id.new_vdr).setOnClickListener(this); - - // initCursor(); - final Vdr cur = Preferences.get().getCurrentVdr(); - adapter = new ArrayAdapter<Vdr>(this, - android.R.layout.simple_list_item_2, list) { - - @Override - public View getView(int position, View convertView, ViewGroup parent) { - // recycle view? - Holder holder = null; - View view = convertView; - if (view == null) { - view = getLayoutInflater().inflate( - android.R.layout.simple_list_item_2, null); - holder = new Holder(); - - holder.text1 = (TextView) view - .findViewById(android.R.id.text1); - holder.text2 = (TextView) view - .findViewById(android.R.id.text2); - view.setTag(holder); - } else { - holder = (Holder) view.getTag(); - } - - Vdr vdr = getItem(position); - String name = (vdr.getName() != null ? vdr.getName() : ""); - String host = vdr.getHost(); - holder.text2.setText(host); - - if (cur != null && cur.getId() == vdr.getId()) { - SpannableString content = new SpannableString(name); - content.setSpan(new UnderlineSpan(), 0, content.length(), 0); - holder.text1.setText(content); - // text1.setText(text1.getText()); - } else { - holder.text1.setTypeface(Typeface.DEFAULT); - holder.text1.setText(name); - } - return view; - } - - }; - - // adapter = new ArrayAdapter<Vdr>( - // "name", "host" }, new int[] { android.R.id.text1, - // android.R.id.text2}) { - // @Override - // public void bindView(View view, Context context, - // Cursor cursor) { - // - // TextView text1 = (TextView)view.findViewById(android.R.id.text1); - // TextView text2 = (TextView)view.findViewById(android.R.id.text2); - // int id = cursor.getInt(cursor.getColumnIndex("_id")); - // String name = cursor.getString(cursor.getColumnIndex("name")); - // String host = cursor.getString(cursor.getColumnIndex("host")); - // text2.setText(host); - // - // if(cur != null && cur.getId() == id) { - // SpannableString content = new SpannableString(name); - // content.setSpan(new UnderlineSpan(), 0, content.length(), 0); - // text1.setText(content); - // //text1.setText(text1.getText()); - // } else { - // text1.setTypeface(Typeface.DEFAULT); - // text1.setText(name); - // } - // - // - // } - // - // }; - ListView listView = (ListView) findViewById(R.id.vdr_list); - listView.setAdapter(adapter); - registerForContextMenu(listView); - listView.setOnItemClickListener(this); - listView.setOnItemLongClickListener(this); - listView.setLongClickable(true); - listView.setEmptyView(findViewById(R.id.empty_view)); - } - - /* - * (non-Javadoc) - * - * @see - * android.widget.AdapterView.OnItemClickListener#onItemClick(android.widget - * .AdapterView, android.view.View, int, long) - */ - public void onItemClick(AdapterView<?> parent, View view, int position, - long id) { - editVdr(adapter.getItem(position).getId()); - } - - /** - * Start {@link VdrPreferencesActivity} to create or edit a vdr - * - * @param id - * may be null. Then a new vdr is created - */ - private void editVdr(Integer id) { - Intent intent = new Intent(this, VdrPreferencesActivity.class); - intent.putExtra(Intents.VDR_ID, id); - startActivityForResult(intent, Intents.EDIT_VDR); - } - - /* - * (non-Javadoc) - * - * @see android.app.Activity#onActivityResult(int, int, - * android.content.Intent) - */ - @Override - protected void onActivityResult(int requestCode, int resultCode, Intent data) { - - if (resultCode != RESULT_OK) { - return; - } - if (requestCode == Intents.EDIT_VDR) { - refresh(); - return; - } - - } - - @Override - protected void onResume() { - refresh(); - super.onResume(); - } - - @Override - public void onBackPressed() { - if (list.isEmpty()) { - finish(); - return; - } - if (emptyConfig) { - Intent intent = new Intent(this, VdrManagerActivity.class); - intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); - startActivity(intent); - finish(); - } else { - super.onBackPressed(); - } - } - - /** - * Refresh the list - */ - private void refresh() { - list.clear(); - list.addAll(DBAccess.get(this).getVdrDAO().queryForAll()); - adapter.notifyDataSetChanged(); - } - - public boolean onItemLongClick(AdapterView<?> parent, View view, - final int position, final long id) { - - new AlertDialog.Builder(this) - .setMessage(R.string.vdr_device_delete_qeustion)// - .setPositiveButton(android.R.string.ok, - new DialogInterface.OnClickListener() { - public void onClick(DialogInterface dialog, - int which) { - if (DBAccess - .get(VdrListActivity.this) - .getVdrDAO() - .deleteById( - adapter.getItem(position) - .getId()) > 0) { - if (Preferences.get().getCurrentVdrContext( - VdrListActivity.this) == id) { - Preferences.setCurrentVdr( - VdrListActivity.this, null); - } - refresh(); - } - - } - })// - .setNegativeButton(android.R.string.cancel, null)// - .create()// - .show(); - return true; - } - - @Override - public final boolean onCreateOptionsMenu(final Menu menu) { - super.onCreateOptionsMenu(menu); - - final MenuInflater inflater = getMenuInflater(); - inflater.inflate(R.menu.vdrlist, menu); - - return true; - } - - @Override - public boolean onOptionsItemSelected(MenuItem item) { - if (item.getItemId() == R.id.main_menu_vdrlist_restore) { - - Intent intent = IntentUtils.newIntent(this, - BackupSettingsActivity.class); - startActivity(intent); - return true; - } - return super.onOptionsItemSelected(item); - } + OnItemClickListener, OnItemLongClickListener, View.OnClickListener { + + private static final String TAG = VdrListActivity.class.getName(); + + List<Vdr> list = new ArrayList<Vdr>(); + + ArrayAdapter<Vdr> adapter = null; + + // Cursor cursor; + + String[] listItems = {}; + + private boolean emptyConfig = false; + + // private void initCursor() { + // + // //if (cursor != null) { + // //if (!cursor.isClosed()) { + // //cursor.close(); + // // } + // //} + // try { + // cursor = getHelper().getVdrCursor(); + // //startManagingCursor(cursor); + // } catch (Exception ex) { + // Log.w(TAG,ex); + // } + // } + + private void populateIntent() { + emptyConfig = getIntent().getBooleanExtra(Intents.EMPTY_CONFIG, + Boolean.FALSE); + } + + + @Override + public void onClick(View v) { + + if (v.getId() == R.id.new_vdr) { + editVdr(null); + return; + } + + } + + static class Holder { + public TextView text1; + public TextView text2; + } + + /** + * Called when the activity is first created. + */ + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + + populateIntent(); + + setContentView(R.layout.vdr_list_add_delete); + + + findViewById(R.id.new_vdr).setOnClickListener(this); + + // initCursor(); + final Vdr cur = Preferences.get().getCurrentVdr(); + adapter = new ArrayAdapter<Vdr>(this, + android.R.layout.simple_list_item_2, list) { + + @Override + public View getView(int position, View convertView, ViewGroup parent) { + // recycle view? + Holder holder = null; + View view = convertView; + if (view == null) { + view = getLayoutInflater().inflate( + android.R.layout.simple_list_item_2, null); + holder = new Holder(); + + holder.text1 = (TextView) view + .findViewById(android.R.id.text1); + holder.text2 = (TextView) view + .findViewById(android.R.id.text2); + view.setTag(holder); + } else { + holder = (Holder) view.getTag(); + } + + Vdr vdr = getItem(position); + String name = (vdr.getName() != null ? vdr.getName() : ""); + String host = vdr.getHost(); + holder.text2.setText(host); + + if (cur != null && cur.getId() == vdr.getId()) { + SpannableString content = new SpannableString(name); + content.setSpan(new UnderlineSpan(), 0, content.length(), 0); + holder.text1.setText(content); + // text1.setText(text1.getText()); + } else { + holder.text1.setTypeface(Typeface.DEFAULT); + holder.text1.setText(name); + } + return view; + } + + }; + + // adapter = new ArrayAdapter<Vdr>( + // "name", "host" }, new int[] { android.R.id.text1, + // android.R.id.text2}) { + // @Override + // public void bindView(View view, Context context, + // Cursor cursor) { + // + // TextView text1 = (TextView)view.findViewById(android.R.id.text1); + // TextView text2 = (TextView)view.findViewById(android.R.id.text2); + // int id = cursor.getInt(cursor.getColumnIndex("_id")); + // String name = cursor.getString(cursor.getColumnIndex("name")); + // String host = cursor.getString(cursor.getColumnIndex("host")); + // text2.setText(host); + // + // if(cur != null && cur.getId() == id) { + // SpannableString content = new SpannableString(name); + // content.setSpan(new UnderlineSpan(), 0, content.length(), 0); + // text1.setText(content); + // //text1.setText(text1.getText()); + // } else { + // text1.setTypeface(Typeface.DEFAULT); + // text1.setText(name); + // } + // + // + // } + // + // }; + ListView listView = (ListView) findViewById(R.id.vdr_list); + listView.setAdapter(adapter); + registerForContextMenu(listView); + listView.setOnItemClickListener(this); + listView.setOnItemLongClickListener(this); + listView.setLongClickable(true); + listView.setEmptyView(findViewById(R.id.empty_view)); + } + + /* + * (non-Javadoc) + * + * @see + * android.widget.AdapterView.OnItemClickListener#onItemClick(android.widget + * .AdapterView, android.view.View, int, long) + */ + public void onItemClick(AdapterView<?> parent, View view, int position, + long id) { + editVdr(adapter.getItem(position).getId()); + } + + /** + * Start {@link VdrPreferencesActivity} to create or edit a vdr + * + * @param id may be null. Then a new vdr is created + */ + private void editVdr(Integer id) { + Intent intent = new Intent(this, VdrPreferencesActivity.class); + intent.putExtra(Intents.VDR_ID, id); + startActivityForResult(intent, Intents.EDIT_VDR); + } + + /* + * (non-Javadoc) + * + * @see android.app.Activity#onActivityResult(int, int, + * android.content.Intent) + */ + @Override + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + + if (resultCode != RESULT_OK) { + return; + } + if (requestCode == Intents.EDIT_VDR) { + refresh(); + return; + } + + } + + @Override + protected void onResume() { + refresh(); + super.onResume(); + } + + @Override + public void onBackPressed() { + if (list.isEmpty()) { + finish(); + return; + } + if (emptyConfig) { + Intent intent = new Intent(this, VdrManagerActivity.class); + intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP); + startActivity(intent); + finish(); + } else { + super.onBackPressed(); + } + } + + /** + * Refresh the list + */ + private void refresh() { + list.clear(); + list.addAll(DBAccess.get(this).getVdrDAO().queryForAll()); + adapter.notifyDataSetChanged(); + } + + public boolean onItemLongClick(AdapterView<?> parent, View view, + final int position, final long id) { + + new AlertDialog.Builder(this) + .setMessage(R.string.vdr_device_delete_qeustion)// + .setPositiveButton(android.R.string.ok, + new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + if (DBAccess + .get(VdrListActivity.this) + .getVdrDAO() + .deleteById( + adapter.getItem(position) + .getId()) > 0) { + if (Preferences.get().getCurrentVdrContext( + VdrListActivity.this) == id) { + Preferences.setCurrentVdr( + VdrListActivity.this, null); + } + refresh(); + } + + } + })// + .setNegativeButton(android.R.string.cancel, null)// + .create()// + .show(); + return true; + } + + @Override + public final boolean onCreateOptionsMenu(final Menu menu) { + super.onCreateOptionsMenu(menu); + + final MenuInflater inflater = getMenuInflater(); + inflater.inflate(R.menu.vdrlist, menu); + + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + if (item.getItemId() == R.id.main_menu_vdrlist_restore) { + + Intent intent = IntentUtils.newIntent(this, + BackupSettingsActivity.class); + startActivity(intent); + return true; + } + return super.onOptionsItemSelected(item); + } } diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrManagerActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrManagerActivity.java index 8f3c68c..6b2ee9f 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrManagerActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrManagerActivity.java @@ -37,6 +37,7 @@ import de.bjusystems.vdrmanager.data.Vdr; import de.bjusystems.vdrmanager.data.db.DBAccess; import de.bjusystems.vdrmanager.data.db.EPGSearchSuggestionsProvider; import de.bjusystems.vdrmanager.remote.RemoteActivity; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; import de.bjusystems.vdrmanager.utils.wakeup.AsyncWakeupTask; public class VdrManagerActivity extends AppCompatActivity implements @@ -92,7 +93,8 @@ public class VdrManagerActivity extends AppCompatActivity implements @Override protected void onCreate(final Bundle savedInstanceState) { super.onCreate(savedInstanceState); - + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); // Preferences.initVDR(this); // if(Preferences.get().getCurrentVdr() == null){ @@ -108,6 +110,7 @@ public class VdrManagerActivity extends AppCompatActivity implements intent.putExtra(Intents.EMPTY_CONFIG, Boolean.TRUE); startActivity(intent); Toast.makeText(this, R.string.no_vdr, Toast.LENGTH_SHORT).show(); + checkAndRequestPermission(); finish(); return; } diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrPreferencesActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrPreferencesActivity.java index 143954c..9743d4e 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrPreferencesActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/VdrPreferencesActivity.java @@ -1,16 +1,5 @@ package de.bjusystems.vdrmanager.gui; -import java.io.BufferedReader; -import java.io.FileReader; -import java.io.IOException; -import java.net.InetAddress; -import java.net.InetSocketAddress; -import java.net.Socket; -import java.util.ArrayList; -import java.util.List; - -import org.fueri.reeldroid.network.DeviceManager; - import android.app.Activity; import android.app.AlertDialog; import android.app.ProgressDialog; @@ -24,6 +13,18 @@ import android.os.Bundle; import android.preference.Preference; import android.preference.Preference.OnPreferenceClickListener; import android.view.View; + +import org.fueri.reeldroid.network.DeviceManager; + +import java.io.BufferedReader; +import java.io.FileReader; +import java.io.IOException; +import java.net.InetAddress; +import java.net.InetSocketAddress; +import java.net.Socket; +import java.util.ArrayList; +import java.util.List; + import de.bjusystems.vdrmanager.R; import de.bjusystems.vdrmanager.VdrSharedPreferencesImpl; import de.bjusystems.vdrmanager.ZonePicker; @@ -33,478 +34,490 @@ import de.bjusystems.vdrmanager.data.Preferences; import de.bjusystems.vdrmanager.data.Vdr; import de.bjusystems.vdrmanager.data.db.DBAccess; import de.bjusystems.vdrmanager.tasks.VoidAsyncTask; +import de.bjusystems.vdrmanager.utils.VdrManagerExceptionHandler; public class VdrPreferencesActivity extends BasePreferencesActivity implements - OnSharedPreferenceChangeListener, OnPreferenceClickListener { - - public static final int REQUEST_CODE_PICK_A_TIME_ZONE = 1; - - Vdr vdr; - - VdrSharedPreferencesImpl pref; - - int id = -1; - - @Override - public SharedPreferences getSharedPreferences(String name, int mode) { - return this.pref; - } - - @Override - public Preference findPreference(CharSequence key) { - return super.findPreference(key); - } - - @Override - protected void updateSummary(Preference ep) { - if (ep.getKey().equals("key_timezone")) { - String text = vdr.getServerTimeZone(); - if (text == null) { - return; - } - setSummary(text, ep); - return; - } - super.updateSummary(ep); - } - - private boolean isNew = false; - - private boolean hasChanged = false; - - private void initVDRInstance() { - id = getIntent().getIntExtra(Intents.VDR_ID, -1); - if (id == -1) {// new vdr - vdr = new Vdr(); - isNew = true; - } else {// edit - Vdr v = DBAccess.get(this).getVdrDAO().queryForId(id); - if (v != null) { - vdr = v; - } else { - vdr = new Vdr(); - id = -1; - isNew = true; - } - } - pref = new VdrSharedPreferencesImpl(vdr, DBAccess.get(this).getVdrDAO()); - } - - public static String ARP_CACHE = "/proc/net/arp"; - - /** - * return mac address as a string. - * - * @param ip - * @return - */ - public static String getMacFromArpCache(String ip) { - - if (ip == null) { - return null; - } - - BufferedReader br = null; - - try { - br = new BufferedReader(new FileReader(ARP_CACHE)); - - String line; - - while ((line = br.readLine()) != null) { - String[] values = line.split("\\s+"); - if (values != null && values.length >= 4 - && ip.equals(values[0])) { - // format check - String mac = values[3]; - if (mac.matches("..:..:..:..:..:..")) { - return mac; - } else { - return null; - } - } - } - } catch (Exception e) { - - } finally { - try { - br.close(); - } catch (IOException e) { - - } - } - return null; - } - - // private String getIp() throws Exception { - // final Preferences prefs = Preferences.get(); - // String host = prefs.getSvdrpHost(); - // return InetAddress.getByName(host).getHostAddress(); - // } - - private void ping(String ip, int port) throws Exception { - Socket socket = new Socket(); - socket.connect(new InetSocketAddress(ip, port), 5 * 1000); - socket.setSoTimeout(5 * 1000); - } - - @Override - protected void onCreate(Bundle savedInstanceState) { - - super.onCreate(savedInstanceState); - - initVDRInstance(); - - this.addPreferencesFromResource(R.xml.vdr_prefs); - - // this.getPreferenceManager().setSharedPreferencesName(Preferences.getPreferenceFile(this)); - - pref.registerOnSharedPreferenceChangeListener(this); - - String recstream = pref.getString("key_recstream_method", "vdr-live"); - - if (recstream.equals("vdr-live") == false) { - Preference p = findPreference("key_live_port"); - p.setEnabled(false); - // PreferenceCategory cat = (PreferenceCategory) - // findPreference("key_streaming_category"); - // cat.removePreference(p); - } - - if (recstream.equals("vdr-smarttvweb") == false) { - Preference p = findPreference("key_smarttvweb_port"); - p.setEnabled(false); - p = findPreference("key_smarttvweb_recstream_method"); - p.setEnabled(false); - - } - - // create background task - - // start task - - final FetchEditTextPreference macedit = (FetchEditTextPreference) findPreference(getString(R.string.wakeup_wol_mac_key)); - String mac = vdr.getMac(); - if (mac == null) { - mac = ""; - } - macedit.setText(mac); - macedit.setCompoundButtonListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - final String host = vdr.getHost(); - if (host == null) { - Utils.say(VdrPreferencesActivity.this, - getString(R.string.vdr_host_not_defined)); - return; - } - - new VoidAsyncTask() { - - ProgressDialog pd; - - private String mac; - - String message; - - protected void onPreExecute() { - pd = new ProgressDialog(VdrPreferencesActivity.this); - pd.setMessage(getString(R.string.processing)); - pd.show(); - }; - - protected void onPostExecute(Void result) { - pd.dismiss(); - if (message != null) { - Utils.say(VdrPreferencesActivity.this, message); - return; - } - macedit.setEditText(mac); - }; - - @Override - protected Void doInBackground(Void... params) { - try { - String ip = InetAddress.getByName(host) - .getHostAddress(); - ping(ip, vdr.getPort()); - mac = getMacFromArpCache(ip); - } catch (Exception ex) { - message = ex.getLocalizedMessage(); - } - - return null; - } - }.execute(); - } - }); - - final FetchEditTextPreference ipEdit = (FetchEditTextPreference) findPreference(getString(R.string.vdr_host_key)); - String ip = vdr.getHost(); - ipEdit.setText(ip); - ipEdit.setCompoundButtonListener(new View.OnClickListener() { - @Override - public void onClick(View v) { - - new AsyncTask<Void, String, List<String>>() { - - ProgressDialog pd; - - String message; - - protected void onPreExecute() { - pd = new ProgressDialog(VdrPreferencesActivity.this); - pd.setMessage(getString(R.string.processing)); - pd.show(); - }; - - protected void onPostExecute(final List<String> ips) { - pd.dismiss(); - if (message != null) { - Utils.say(VdrPreferencesActivity.this, message); - return; - } - - if (ips.isEmpty()) { - Utils.say(VdrPreferencesActivity.this, - R.string.no_results); - return; - } - if (ips.size() == 1) { - ipEdit.setEditText(ips.get(0).toString()); - } else { - new AlertDialog.Builder(VdrPreferencesActivity.this) - .setItems( - ips.toArray(new CharSequence[] {}), - new DialogInterface.OnClickListener() { - @Override - public void onClick( - DialogInterface dialog, - int which) { - String ip = ips.get(which); - ipEdit.setEditText(ip); - } - }).show(); - } - - } - - protected void onProgressUpdate(String... values) { - pd.setMessage(getString(R.string.probing, values[0])); - }; - - @Override - protected List<String> doInBackground(Void... params) { - try { - - final int port = vdr.getPort(); - return DeviceManager.findVDRHosts( - VdrPreferencesActivity.this, port, - new DeviceManager.ProgressListener() { - - @Override - public void publish(String currentIP) { - publishProgress(currentIP); - } - }); - - } catch (Exception ex) { - message = ex.getLocalizedMessage(); - } - return new ArrayList<String>(0); - } - }.execute(); - - } - }); - - updateChildPreferences(); - - findPreference(getString(R.string.timezone_key)) - .setOnPreferenceClickListener(this); - - } - - public void onSharedPreferenceChanged(SharedPreferences arg0, String key) { - hasChanged = true; - updateChildPreferences(); - Preference p = findPreference(key); - updateSummary(p); - - if (key != null && key.equals("key_recstream_method")) { - String recstream = pref.getString("key_recstream_method", - "vdr-live"); - Preference pk = findPreference("key_live_port"); - if (recstream.equals("vdr-live") == false) { - - pk.setEnabled(false); - // PreferenceCategory cat = (PreferenceCategory) - // findPreference("key_streaming_category"); - // cat.removePreference(p); - } else { - pk.setEnabled(true); - } - - if (recstream.equals("vdr-smarttvweb") == false) { - p = findPreference("key_smarttvweb_port"); - p.setEnabled(false); - p = findPreference("key_smarttvweb_recstream_method"); - p.setEnabled(false); - - } else { - p = findPreference("key_smarttvweb_port"); - p.setEnabled(true); - p = findPreference("key_smarttvweb_recstream_method"); - p.setEnabled(true); - - } - - // if(pk) - // cat.addPreference(pk); - // } else { - // cat.removePreference(pk); - // } - } - - Preferences.reloadVDR(this); - } - - @Override - protected void onResume() { - super.onResume(); - pref.registerOnSharedPreferenceChangeListener(this); - } - - @Override - protected void onPause() { - super.onPause(); - // Unregister the listener whenever a key changes - pref.unregisterOnSharedPreferenceChangeListener(this); - } - - private void enableWolPreferences() { - Preference p = findPreference(getString(R.string.wakeup_wol_mac_key)); - if (p != null) - - p.setEnabled(true); - p = findPreference(getString(R.string.wakeup_wol_custom_broadcast_key)); - if (p != null) { - p.setEnabled(true); - } - } - - private void disableWolPreferences() { - Preference p = findPreference(getString(R.string.wakeup_wol_mac_key)); - if (p != null) - p.setEnabled(false); - - p = findPreference(getString(R.string.wakeup_wol_custom_broadcast_key)); - if (p != null) - p.setEnabled(false); - - } - - private void disableWakeupUrlPreferences() { - Preference p = findPreference(getString(R.string.wakeup_url_key)); - if (p != null) { - p.setEnabled(false); - } - p = findPreference(getString(R.string.wakeup_password_key)); - if (p != null) { - p.setEnabled(false); - } - - p = findPreference(getString(R.string.wakeup_user_key)); - if (p != null) { - p.setEnabled(false); - } - } - - private void enableWakeupUrlPrefenreces() { - Preference p = findPreference(getString(R.string.wakeup_url_key)); - if (p != null) { - p.setEnabled(true); - } - - p = findPreference(getString(R.string.wakeup_password_key)); - if (p != null) { - p.setEnabled(true); - } - p = findPreference(getString(R.string.wakeup_user_key)); - if (p != null) { - p.setEnabled(true); - } - } - - private void updateChildPreferences() { - String wakup = pref.getString(getString(R.string.wakeup_method_key), - "wol"); - - if (wakup.equals("url")) { - disableWolPreferences(); - enableWakeupUrlPrefenreces(); - } else {// remote url - disableWakeupUrlPreferences(); - enableWolPreferences(); - } - - for (String key : pref.getAll().keySet()) { - Preference p = findPreference(key); - updateSummary(p); - } - - } - - @Override - public void onBackPressed() { - if (id != -1) {// no new devices - setResult(RESULT_OK); - finish(); - return; - } - if (isNew == true && hasChanged == false) { - // if (pref.commits < 2) {// user has not changed anything - DBAccess.get(this).getVdrDAO().delete(pref.getVdr()); - finish(); - return; - } - super.onBackPressed(); - } - - @Override - public boolean onPreferenceClick(Preference preference) { - - String timezone = vdr.getServerTimeZone(); - - Intent intent = new Intent(this, ZonePicker.class); - intent.putExtra("current_tz", timezone); - startActivityForResult(intent, REQUEST_CODE_PICK_A_TIME_ZONE); - return true; - } - - - - @Override - protected void onActivityResult(int requestCode, int resultCode, Intent data) { - if (resultCode != Activity.RESULT_OK) { - super.onActivityResult(requestCode, resultCode, data); - return; - } - - // never mind, onResume also registers this, but the listenres are held - // in a map (as key) so that no double occurance - pref.registerOnSharedPreferenceChangeListener(this); - - if (requestCode == REQUEST_CODE_PICK_A_TIME_ZONE) { - String ntz = data.getStringExtra("new_tz"); - if (ntz != null) { - vdr.setServerTimeZone(ntz); - Editor editor = findPreference("key_timezone").getEditor(); - editor.putString("key_timezone", ntz); - editor.commit(); - // setSummary(ntz, ); - } - } - } + OnSharedPreferenceChangeListener, OnPreferenceClickListener { + + public static final int REQUEST_CODE_PICK_A_TIME_ZONE = 1; + + Vdr vdr; + + VdrSharedPreferencesImpl pref; + + int id = -1; + + @Override + public SharedPreferences getSharedPreferences(String name, int mode) { + return this.pref; + } + + @Override + public Preference findPreference(CharSequence key) { + return super.findPreference(key); + } + + @Override + protected void updateSummary(Preference ep) { + if (ep.getKey().equals("key_timezone")) { + String text = vdr.getServerTimeZone(); + if (text == null) { + return; + } + setSummary(text, ep); + return; + } + super.updateSummary(ep); + } + + private boolean isNew = false; + + private boolean hasChanged = false; + + private void initVDRInstance() { + id = getIntent().getIntExtra(Intents.VDR_ID, -1); + if (id == -1) {// new vdr + vdr = new Vdr(); + isNew = true; + } else {// edit + Vdr v = DBAccess.get(this).getVdrDAO().queryForId(id); + if (v != null) { + vdr = v; + } else { + vdr = new Vdr(); + id = -1; + isNew = true; + } + } + pref = new VdrSharedPreferencesImpl(vdr, DBAccess.get(this).getVdrDAO()); + } + + public static String ARP_CACHE = "/proc/net/arp"; + + /** + * return mac address as a string. + * + * @param ip + * @return + */ + public static String getMacFromArpCache(String ip) { + + if (ip == null) { + return null; + } + + BufferedReader br = null; + + try { + br = new BufferedReader(new FileReader(ARP_CACHE)); + + String line; + + while ((line = br.readLine()) != null) { + String[] values = line.split("\\s+"); + if (values != null && values.length >= 4 + && ip.equals(values[0])) { + // format check + String mac = values[3]; + if (mac.matches("..:..:..:..:..:..")) { + return mac; + } else { + return null; + } + } + } + } catch (Exception e) { + + } finally { + try { + br.close(); + } catch (IOException e) { + + } + } + return null; + } + + // private String getIp() throws Exception { + // final Preferences prefs = Preferences.get(); + // String host = prefs.getSvdrpHost(); + // return InetAddress.getByName(host).getHostAddress(); + // } + + private void ping(String ip, int port) throws Exception { + Socket socket = new Socket(); + socket.connect(new InetSocketAddress(ip, port), 5 * 1000); + socket.setSoTimeout(5 * 1000); + } + + @Override + protected void onCreate(Bundle savedInstanceState) { + + super.onCreate(savedInstanceState); + Thread.setDefaultUncaughtExceptionHandler(VdrManagerExceptionHandler.get(this, + Thread.getDefaultUncaughtExceptionHandler())); + initVDRInstance(); + + this.addPreferencesFromResource(R.xml.vdr_prefs); + + // this.getPreferenceManager().setSharedPreferencesName(Preferences.getPreferenceFile(this)); + + pref.registerOnSharedPreferenceChangeListener(this); + + String recstream = pref.getString("key_recstream_method", "vdr-live"); + + if (recstream.equals("vdr-live") == false) { + Preference p = findPreference("key_live_port"); + p.setEnabled(false); + // PreferenceCategory cat = (PreferenceCategory) + // findPreference("key_streaming_category"); + // cat.removePreference(p); + } + + if (recstream.equals("vdr-smarttvweb") == false) { + Preference p = findPreference("key_smarttvweb_port"); + p.setEnabled(false); + p = findPreference("key_smarttvweb_recstream_method"); + p.setEnabled(false); + + } + + // create background task + + // start task + + final FetchEditTextPreference macedit = (FetchEditTextPreference) findPreference(getString(R.string.wakeup_wol_mac_key)); + String mac = vdr.getMac(); + if (mac == null) { + mac = ""; + } + macedit.setText(mac); + macedit.setCompoundButtonListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + final String host = vdr.getHost(); + if (host == null) { + Utils.say(VdrPreferencesActivity.this, + getString(R.string.vdr_host_not_defined)); + return; + } + + new VoidAsyncTask() { + + ProgressDialog pd; + + private String mac; + + String message; + + protected void onPreExecute() { + pd = new ProgressDialog(VdrPreferencesActivity.this); + pd.setMessage(getString(R.string.processing)); + pd.show(); + } + + ; + + protected void onPostExecute(Void result) { + pd.dismiss(); + if (message != null) { + Utils.say(VdrPreferencesActivity.this, message); + return; + } + macedit.setEditText(mac); + } + + ; + + @Override + protected Void doInBackground(Void... params) { + try { + String ip = InetAddress.getByName(host) + .getHostAddress(); + ping(ip, vdr.getPort()); + mac = getMacFromArpCache(ip); + } catch (Exception ex) { + message = ex.getLocalizedMessage(); + } + + return null; + } + }.execute(); + } + }); + + final FetchEditTextPreference ipEdit = (FetchEditTextPreference) findPreference(getString(R.string.vdr_host_key)); + String ip = vdr.getHost(); + ipEdit.setText(ip); + ipEdit.setCompoundButtonListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + + new AsyncTask<Void, String, List<String>>() { + + ProgressDialog pd; + + String message; + + protected void onPreExecute() { + pd = new ProgressDialog(VdrPreferencesActivity.this); + pd.setMessage(getString(R.string.processing)); + pd.show(); + } + + ; + + protected void onPostExecute(final List<String> ips) { + pd.dismiss(); + if (message != null) { + Utils.say(VdrPreferencesActivity.this, message); + return; + } + + if (ips.isEmpty()) { + Utils.say(VdrPreferencesActivity.this, + R.string.no_results); + return; + } + if (ips.size() == 1) { + ipEdit.setEditText(ips.get(0).toString()); + } else { + new AlertDialog.Builder(VdrPreferencesActivity.this) + .setItems( + ips.toArray(new CharSequence[]{}), + new DialogInterface.OnClickListener() { + @Override + public void onClick( + DialogInterface dialog, + int which) { + String ip = ips.get(which); + ipEdit.setEditText(ip); + } + }).show(); + } + + } + + protected void onProgressUpdate(String... values) { + pd.setMessage(getString(R.string.probing, values[0])); + } + + ; + + @Override + protected List<String> doInBackground(Void... params) { + try { + + final int port = vdr.getPort(); + return DeviceManager.findVDRHosts( + VdrPreferencesActivity.this, port, + new DeviceManager.ProgressListener() { + + @Override + public void publish(String currentIP) { + publishProgress(currentIP); + } + }); + + } catch (Exception ex) { + message = ex.getLocalizedMessage(); + } + return new ArrayList<String>(0); + } + }.execute(); + + } + }); + + updateChildPreferences(); + + findPreference(getString(R.string.timezone_key)) + .setOnPreferenceClickListener(this); + + } + + public void onSharedPreferenceChanged(SharedPreferences arg0, String key) { + hasChanged = true; + updateChildPreferences(); + Preference p = findPreference(key); + updateSummary(p); + + if (key != null && key.equals("key_recstream_method")) { + String recstream = pref.getString("key_recstream_method", + "vdr-live"); + Preference pk = findPreference("key_live_port"); + if (recstream.equals("vdr-live") == false) { + + pk.setEnabled(false); + // PreferenceCategory cat = (PreferenceCategory) + // findPreference("key_streaming_category"); + // cat.removePreference(p); + } else { + pk.setEnabled(true); + } + + if (recstream.equals("vdr-smarttvweb") == false) { + p = findPreference("key_smarttvweb_port"); + p.setEnabled(false); + p = findPreference("key_smarttvweb_recstream_method"); + p.setEnabled(false); + + } else { + p = findPreference("key_smarttvweb_port"); + p.setEnabled(true); + p = findPreference("key_smarttvweb_recstream_method"); + p.setEnabled(true); + + } + + // if(pk) + // cat.addPreference(pk); + // } else { + // cat.removePreference(pk); + // } + } + + Preferences.reloadVDR(this); + } + + @Override + protected void onResume() { + super.onResume(); + pref.registerOnSharedPreferenceChangeListener(this); + } + + @Override + protected void onPause() { + super.onPause(); + // Unregister the listener whenever a key changes + pref.unregisterOnSharedPreferenceChangeListener(this); + } + + private void enableWolPreferences() { + Preference p = findPreference(getString(R.string.wakeup_wol_mac_key)); + if (p != null) + + p.setEnabled(true); + p = findPreference(getString(R.string.wakeup_wol_custom_broadcast_key)); + if (p != null) { + p.setEnabled(true); + } + } + + private void disableWolPreferences() { + Preference p = findPreference(getString(R.string.wakeup_wol_mac_key)); + if (p != null) + p.setEnabled(false); + + p = findPreference(getString(R.string.wakeup_wol_custom_broadcast_key)); + if (p != null) + p.setEnabled(false); + + } + + private void disableWakeupUrlPreferences() { + Preference p = findPreference(getString(R.string.wakeup_url_key)); + if (p != null) { + p.setEnabled(false); + } + p = findPreference(getString(R.string.wakeup_password_key)); + if (p != null) { + p.setEnabled(false); + } + + p = findPreference(getString(R.string.wakeup_user_key)); + if (p != null) { + p.setEnabled(false); + } + } + + private void enableWakeupUrlPrefenreces() { + Preference p = findPreference(getString(R.string.wakeup_url_key)); + if (p != null) { + p.setEnabled(true); + } + + p = findPreference(getString(R.string.wakeup_password_key)); + if (p != null) { + p.setEnabled(true); + } + p = findPreference(getString(R.string.wakeup_user_key)); + if (p != null) { + p.setEnabled(true); + } + } + + private void updateChildPreferences() { + String wakup = pref.getString(getString(R.string.wakeup_method_key), + "wol"); + + if (wakup.equals("url")) { + disableWolPreferences(); + enableWakeupUrlPrefenreces(); + } else {// remote url + disableWakeupUrlPreferences(); + enableWolPreferences(); + } + + for (String key : pref.getAll().keySet()) { + Preference p = findPreference(key); + if (p == null) { + continue; + } + updateSummary(p); + } + + } + + @Override + public void onBackPressed() { + if (id != -1) {// no new devices + setResult(RESULT_OK); + finish(); + return; + } + if (isNew == true && hasChanged == false) { + // if (pref.commits < 2) {// user has not changed anything + DBAccess.get(this).getVdrDAO().delete(pref.getVdr()); + finish(); + return; + } + super.onBackPressed(); + } + + @Override + public boolean onPreferenceClick(Preference preference) { + + String timezone = vdr.getServerTimeZone(); + + Intent intent = new Intent(this, ZonePicker.class); + intent.putExtra("current_tz", timezone); + startActivityForResult(intent, REQUEST_CODE_PICK_A_TIME_ZONE); + return true; + } + + + @Override + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + if (resultCode != Activity.RESULT_OK) { + super.onActivityResult(requestCode, resultCode, data); + return; + } + + // never mind, onResume also registers this, but the listenres are held + // in a map (as key) so that no double occurance + pref.registerOnSharedPreferenceChangeListener(this); + + if (requestCode == REQUEST_CODE_PICK_A_TIME_ZONE) { + String ntz = data.getStringExtra("new_tz"); + if (ntz != null) { + vdr.setServerTimeZone(ntz); + Editor editor = findPreference("key_timezone").getEditor(); + editor.putString("key_timezone", ntz); + editor.commit(); + // setSummary(ntz, ); + } + } + } } diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerDialog.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerDialog.java new file mode 100644 index 0000000..37fa552 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerDialog.java @@ -0,0 +1,502 @@ +/* + * Copyright (C) 2007 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. + */ + +package de.bjusystems.vdrmanager.gui.colorpicker; + +import android.app.Dialog; +import android.content.Context; +import android.content.res.Resources; +import android.graphics.BlurMaskFilter; +import android.graphics.BlurMaskFilter.Blur; +import android.graphics.Canvas; +import android.graphics.Color; +import android.graphics.ColorFilter; +import android.graphics.Paint; +import android.graphics.Paint.Style; +import android.graphics.PixelFormat; +import android.graphics.Rect; +import android.graphics.RectF; +import android.graphics.Shader; +import android.graphics.SweepGradient; +import android.graphics.Typeface; +import android.graphics.drawable.Drawable; +import android.os.Bundle; +import android.os.SystemClock; +import android.text.Editable; +import android.text.TextWatcher; +import android.util.StateSet; +import android.view.MotionEvent; +import android.view.View; +import android.view.animation.Animation; +import android.view.animation.AnimationUtils; +import android.view.animation.DecelerateInterpolator; +import android.view.animation.Transformation; +import android.widget.EditText; +import android.widget.LinearLayout; +import android.widget.SeekBar; +import android.widget.TextView; + +import de.bjusystems.vdrmanager.R; + +public class ColorPickerDialog extends Dialog { + private static int CENTER_X = 100; + private static int CENTER_Y = 100; + private static int CENTER_RADIUS = 32; + + public interface OnColorChangedListener { + void colorChanged(int color); + } + + private OnColorChangedListener mListener; + + private int mInitialColor; + + public int lastColor = 0; + + public void setOnColorChangedListener(OnColorChangedListener listener){ + mListener = listener; + }; + + + private class ColorPickerView extends View { + private Paint mPaint; + private Paint mCenterPaint; + private final int[] mColors; + private OnColorChangedListener mListener; + + ColorPickerView(Context c, OnColorChangedListener l, int color) { + super(c); + mListener = l; + lastColor = color; + mColors = new int[] { + 0xFFFF0000, 0xFFFF00FF, 0xFF0000FF, 0xFF00FFFF, 0xFF00FF00, + 0xFFFFFF00, 0xFFFFFFFF, 0xFF808080, 0xFF000000, 0xFFFF0000 + }; + Shader s = new SweepGradient(0, 0, mColors, null); + + mPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mPaint.setShader(s); + mPaint.setStyle(Style.STROKE); + mPaint.setStrokeWidth(CENTER_RADIUS); + + mCenterPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mCenterPaint.setColor(color); + mCenterPaint.setStrokeWidth(5); + } + + private boolean mTrackingCenter; + private boolean mHighlightCenter; + + @Override + protected void onDraw(Canvas canvas) { + float r = CENTER_X - mPaint.getStrokeWidth()*0.8f; + + canvas.translate(CENTER_X, CENTER_X); + + canvas.drawOval(new RectF(-r, -r, r, r), mPaint); + canvas.drawCircle(0, 0, CENTER_RADIUS, mCenterPaint); + + if (mTrackingCenter) { + int c = mCenterPaint.getColor(); + mCenterPaint.setStyle(Style.STROKE); + + if (mHighlightCenter) { + mCenterPaint.setAlpha(0xFF); + } else { + mCenterPaint.setAlpha(0x80); + } + canvas.drawCircle(0, 0, + CENTER_RADIUS + mCenterPaint.getStrokeWidth(), + mCenterPaint); + + mCenterPaint.setStyle(Style.FILL); + mCenterPaint.setColor(c); + } + } + + @Override + protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { + setMeasuredDimension(CENTER_X*2, CENTER_Y*2); + } + + public void setCenterColor(int color) { + mCenterPaint.setColor(color); + invalidate(); + } + + public void setTransparency(int alpha) { + int color = mCenterPaint.getColor(); + int newColor = Color.argb(alpha, Color.red(color), Color.green(color), Color.blue(color)); + mCenterPaint.setColor(newColor); + mEditText.setText(convertToARGB(newColor)); + invalidate(); + } + + private int ave(int s, int d, float p) { + return s + Math.round(p * (d - s)); + } + + private int interpColor(int colors[], float unit) { + if (unit <= 0) { + return colors[0]; + } + if (unit >= 1) { + return colors[colors.length - 1]; + } + + float p = unit * (colors.length - 1); + int i = (int)p; + p -= i; + + // now p is just the fractional part [0...1) and i is the index + int c0 = colors[i]; + int c1 = colors[i+1]; + int a = ave(Color.alpha(c0), Color.alpha(c1), p); + int r = ave(Color.red(c0), Color.red(c1), p); + int g = ave(Color.green(c0), Color.green(c1), p); + int b = ave(Color.blue(c0), Color.blue(c1), p); + + return Color.argb(a, r, g, b); + } + + private static final float PI = 3.1415926f; + + @Override + public boolean onTouchEvent(MotionEvent event) { + float x = event.getX() - CENTER_X; + float y = event.getY() - CENTER_Y; + boolean inCenter = Math.sqrt(x*x + y*y) <= CENTER_RADIUS; + + switch (event.getAction()) { + case MotionEvent.ACTION_DOWN: + mTrackingCenter = inCenter; + if (inCenter) { + mHighlightCenter = true; + invalidate(); + break; + } + case MotionEvent.ACTION_MOVE: + if (mTrackingCenter) { + if (mHighlightCenter != inCenter) { + mHighlightCenter = inCenter; + invalidate(); + } + } else { + float angle = (float) Math.atan2(y, x); + // need to turn angle [-PI ... PI] into unit [0....1] + float unit = angle/(2*PI); + if (unit < 0) { + unit += 1; + } + int color = interpColor(mColors, unit); + mCenterPaint.setColor(color); + mEditText.setText(convertToARGB(color)); + invalidate(); + } + break; + case MotionEvent.ACTION_UP: + if (mTrackingCenter) { + if (inCenter) { + mListener.colorChanged(mCenterPaint.getColor()); + lastColor = mCenterPaint.getColor(); + } + mTrackingCenter = false; // so we draw w/o halo + invalidate(); + } + break; + } + return true; + } + } + + private String convertToARGB(int color) { + String alpha = Integer.toHexString(Color.alpha(color)); + String red = Integer.toHexString(Color.red(color)); + String green = Integer.toHexString(Color.green(color)); + String blue = Integer.toHexString(Color.blue(color)); + + if (alpha.length() == 1) { + alpha = "0" + alpha; + } + + if (red.length() == 1) { + red = "0" + red; + } + + if (green.length() == 1) { + green = "0" + green; + } + + if (blue.length() == 1) { + blue = "0" + blue; + } + + return "#" + alpha + red + green + blue; + } + + private int convertToColorInt(String argb) throws NumberFormatException { + + int alpha = -1, red = -1, green = -1, blue = -1; + + if (argb.length() == 8) { + alpha = Integer.parseInt(argb.substring(0, 2), 16); + red = Integer.parseInt(argb.substring(2, 4), 16); + green = Integer.parseInt(argb.substring(4, 6), 16); + blue = Integer.parseInt(argb.substring(6, 8), 16); + } + else if (argb.length() == 6) { + alpha = 255; + red = Integer.parseInt(argb.substring(0, 2), 16); + green = Integer.parseInt(argb.substring(2, 4), 16); + blue = Integer.parseInt(argb.substring(4, 6), 16); + } + + return Color.argb(alpha, red, green, blue); + } + + private Context mContext; + private EditText mEditText; + private ColorPickerView mColorPickerView; + private SeekBar mTransparencyBar; + + public ColorPickerDialog(Context context, OnColorChangedListener listener, int initialColor) { + super(context); + mContext = context; + mListener = listener; + mInitialColor = initialColor; + CENTER_Y=CENTER_X=context.getResources().getDimensionPixelSize(R.dimen.color_picker_center); + CENTER_RADIUS=context.getResources().getDimensionPixelSize(R.dimen.color_picker_radius); + } + + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + + LinearLayout layout = new LinearLayout(mContext); + layout.setOrientation(LinearLayout.VERTICAL); + layout.setGravity(android.view.Gravity.CENTER); + + LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, + LinearLayout.LayoutParams.WRAP_CONTENT); + layoutParams.setMargins(10, 0, 10, 5); + + TextView tv = new TextView(mContext); + tv.setText(mContext.getString(R.string.pref_dialog_message_color_picker)); + layout.addView(tv, layoutParams); + + mColorPickerView = new ColorPickerView(getContext(), onColorChangedListener, mInitialColor); + layout.addView(mColorPickerView, layoutParams); + + mTransparencyBar = new SeekBar(mContext); + mTransparencyBar.setMax(255); + mTransparencyBar.setProgressDrawable(new TextSeekBarDrawable(mContext.getResources(), mContext.getString(R.string.pref_dialog_color_picker_alpha), true)); + mTransparencyBar.setProgress(Color.alpha(mInitialColor)); + mTransparencyBar.setOnSeekBarChangeListener(onTransparencyChangedListener); + layout.addView(mTransparencyBar, layoutParams); + + mEditText = new EditText(mContext); + mEditText.addTextChangedListener(mEditTextListener); + mEditText.setText(convertToARGB(mInitialColor)); + layout.addView(mEditText, layoutParams); + + setContentView(layout); + setTitle(mContext.getString(R.string.pref_dialog_title_color_picker)); + } + + private OnColorChangedListener onColorChangedListener = new OnColorChangedListener() { + public void colorChanged(int color) { + mListener.colorChanged(color); + lastColor = color; + dismiss(); + } + }; + + private SeekBar.OnSeekBarChangeListener onTransparencyChangedListener = new SeekBar.OnSeekBarChangeListener() { + + public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { + mColorPickerView.setTransparency(progress); + } + + public void onStartTrackingTouch(SeekBar seekBar) { + } + + public void onStopTrackingTouch(SeekBar seekBar) { + } + }; + + private TextWatcher mEditTextListener = new TextWatcher() { + + public void afterTextChanged(Editable s) { + } + + public void beforeTextChanged(CharSequence s, int start, int count, int after) { + } + + public void onTextChanged(CharSequence s, int start, int before, int count) { + try { + String s2 = (s.toString()).replace("#", ""); + if (s2.length() == 6 || s2.length() == 8) { + int color = convertToColorInt(s2); + mColorPickerView.setCenterColor(color); + mTransparencyBar.setProgress(Color.alpha(color)); + } + } + catch (NumberFormatException e) { + } + } + }; + + //Source: http://www.anddev.org/announce_color_picker_dialog-t10771.html + static final int[] STATE_FOCUSED = {android.R.attr.state_focused}; + static final int[] STATE_PRESSED = {android.R.attr.state_pressed}; + + static class TextSeekBarDrawable extends Drawable implements Runnable { + + private static final long DELAY = 50; + private String mText; + private Drawable mProgress; + private Paint mPaint; + private Paint mOutlinePaint; + private float mTextWidth; + private boolean mActive; + private float mTextXScale; + private int mDelta; + private ScrollAnimation mAnimation; + + public TextSeekBarDrawable(Resources res, String label, boolean labelOnRight) { + mText = label; + mProgress = res.getDrawable(android.R.drawable.progress_horizontal); + mPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mPaint.setTypeface(Typeface.DEFAULT_BOLD); + mPaint.setTextSize(16); + mPaint.setColor(0xff000000); + mOutlinePaint = new Paint(mPaint); + mOutlinePaint.setStyle(Style.STROKE); + mOutlinePaint.setStrokeWidth(3); + mOutlinePaint.setColor(0xbbffc300); + mOutlinePaint.setMaskFilter(new BlurMaskFilter(1, Blur.NORMAL)); + mTextWidth = mOutlinePaint.measureText(mText); + mTextXScale = labelOnRight? 1 : 0; + mAnimation = new ScrollAnimation(); + } + + @Override + protected void onBoundsChange(Rect bounds) { + mProgress.setBounds(bounds); + } + + @Override + protected boolean onStateChange(int[] state) { + mActive = StateSet.stateSetMatches(STATE_FOCUSED, state) | StateSet.stateSetMatches(STATE_PRESSED, state); + invalidateSelf(); + return false; + } + + @Override + public boolean isStateful() { + return true; + } + + @Override + protected boolean onLevelChange(int level) { +// Log.d(TAG, "onLevelChange " + level); + if (level < 4000 && mDelta <= 0) { +// Log.d(TAG, "onLevelChange scheduleSelf ++"); + mDelta = 1; + mAnimation.startScrolling(mTextXScale, 1); + scheduleSelf(this, SystemClock.uptimeMillis() + DELAY); + } else + if (level > 6000 && mDelta >= 0) { +// Log.d(TAG, "onLevelChange scheduleSelf --"); + mDelta = -1; + mAnimation.startScrolling(mTextXScale, 0); + scheduleSelf(this, SystemClock.uptimeMillis() + DELAY); + } + return mProgress.setLevel(level); + } + + @Override + public void draw(Canvas canvas) { + mProgress.draw(canvas); + + if (mAnimation.hasStarted() && !mAnimation.hasEnded()) { + // pending animation + mAnimation.getTransformation(AnimationUtils.currentAnimationTimeMillis(), null); + mTextXScale = mAnimation.getCurrent(); +// Log.d(TAG, "draw " + mTextX + " " + SystemClock.uptimeMillis()); + } + + Rect bounds = getBounds(); + float x = 6 + mTextXScale * (bounds.width() - mTextWidth - 6 - 6); + float y = (bounds.height() + mPaint.getTextSize()) / 2; + mOutlinePaint.setAlpha(mActive? 255 : 255 / 2); + mPaint.setAlpha(mActive? 255 : 255 / 2); + canvas.drawText(mText, x, y, mOutlinePaint); + canvas.drawText(mText, x, y, mPaint); + } + + @Override + public int getOpacity() { + return PixelFormat.TRANSLUCENT; + } + + @Override + public void setAlpha(int alpha) { + } + + @Override + public void setColorFilter(ColorFilter cf) { + } + + public void run() { + mAnimation.getTransformation(AnimationUtils.currentAnimationTimeMillis(), null); + // close interpolation of mTextX + mTextXScale = mAnimation.getCurrent(); + if (!mAnimation.hasEnded()) { + scheduleSelf(this, SystemClock.uptimeMillis() + DELAY); + } + invalidateSelf(); +// Log.d(TAG, "run " + mTextX + " " + SystemClock.uptimeMillis()); + } + } + + static class ScrollAnimation extends Animation { + private static final long DURATION = 750; + private float mFrom; + private float mTo; + private float mCurrent; + + public ScrollAnimation() { + setDuration(DURATION); + setInterpolator(new DecelerateInterpolator()); + } + + public void startScrolling(float from, float to) { + mFrom = from; + mTo = to; + startNow(); + } + + @Override + protected void applyTransformation(float interpolatedTime, Transformation t) { + mCurrent = mFrom + (mTo - mFrom) * interpolatedTime; +// Log.d(TAG, "applyTransformation " + mCurrent); + } + + public float getCurrent() { + return mCurrent; + } + } +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerPreference.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerPreference.java new file mode 100644 index 0000000..441e9c3 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerPreference.java @@ -0,0 +1,637 @@ +package de.bjusystems.vdrmanager.gui.colorpicker; + +/* + * Copyright (C) 2007 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. + */ + + +import android.content.Context; +import android.content.DialogInterface; +import android.content.res.Resources; +import android.graphics.BlurMaskFilter; +import android.graphics.BlurMaskFilter.Blur; +import android.graphics.Canvas; +import android.graphics.Color; +import android.graphics.ColorFilter; +import android.graphics.ColorMatrix; +import android.graphics.Paint; +import android.graphics.Paint.Style; +import android.graphics.PixelFormat; +import android.graphics.Rect; +import android.graphics.RectF; +import android.graphics.Shader; +import android.graphics.SweepGradient; +import android.graphics.Typeface; +import android.graphics.drawable.Drawable; +import android.os.SystemClock; +import android.preference.DialogPreference; +import android.text.Editable; +import android.text.TextWatcher; +import android.util.AttributeSet; +import android.util.StateSet; +import android.view.MotionEvent; +import android.view.View; +import android.view.animation.Animation; +import android.view.animation.AnimationUtils; +import android.view.animation.DecelerateInterpolator; +import android.view.animation.Transformation; +import android.widget.CheckBox; +import android.widget.EditText; +import android.widget.LinearLayout; +import android.widget.SeekBar; +import android.widget.TextView; + +/** + * Color Picker dialog as DialogPreference + * @author lado + * + */ +public class ColorPickerPreference extends DialogPreference { + + public static interface OnColorChangedListener { + void colorChanged(int color); + } + + //private OnColorChangedListener mListener; + private int mInitialColor; + + //private int color; + + private class ColorPickerView extends View { + private Paint mPaint; + private Paint mCenterPaint; + private final int[] mColors; + private ColorPickerPreference dialog; + //private OnColorChangedListener mListener; + + ColorPickerView(final ColorPickerPreference d,// OnColorChangedListener l, + int color) { + super(d.getContext()); + dialog = d; + //mListener = l; + mColors = new int[] { 0xFFFF0000, 0xFFFF00FF, 0xFF0000FF, + 0xFF00FFFF, 0xFF00FF00, 0xFFFFFF00, 0xFFFFFFFF, 0xFF808080, + 0xFF000000, 0xFFFF0000 }; + Shader s = new SweepGradient(0, 0, mColors, null); + + mPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mPaint.setShader(s); + mPaint.setStyle(Style.STROKE); + mPaint.setStrokeWidth(32); + + mCenterPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mCenterPaint.setColor(color); + mCenterPaint.setStrokeWidth(5); + } + + private boolean mTrackingCenter; + private boolean mHighlightCenter; + + @Override + protected void onDraw(Canvas canvas) { + float r = CENTER_X - mPaint.getStrokeWidth() * 0.5f; + + canvas.translate(CENTER_X, CENTER_X); + + canvas.drawOval(new RectF(-r, -r, r, r), mPaint); + canvas.drawCircle(0, 0, CENTER_RADIUS, mCenterPaint); + + if (mTrackingCenter) { + int c = mCenterPaint.getColor(); + mCenterPaint.setStyle(Style.STROKE); + + if (mHighlightCenter) { + mCenterPaint.setAlpha(0xFF); + } else { + mCenterPaint.setAlpha(0x80); + } + canvas.drawCircle(0, 0, + CENTER_RADIUS + mCenterPaint.getStrokeWidth(), + mCenterPaint); + + mCenterPaint.setStyle(Style.FILL); + mCenterPaint.setColor(c); + } + } + + @Override + protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { + setMeasuredDimension(CENTER_X * 2, CENTER_Y * 2); + } + + private static final int CENTER_X = 100; + private static final int CENTER_Y = 100; + private static final int CENTER_RADIUS = 32; + + private int floatToByte(float x) { + int n = Math.round(x); + return n; + } + + private int pinToByte(int n) { + if (n < 0) { + n = 0; + } else if (n > 255) { + n = 255; + } + return n; + } + + public void setCenterColor(int color) { + mCenterPaint.setColor(color); + invalidate(); + } + + public void setTransparency(int alpha) { + int color = mCenterPaint.getColor(); + int newColor = Color.argb(alpha, Color.red(color), + Color.green(color), Color.blue(color)); + mCenterPaint.setColor(newColor); + mEditText.setText(convertToARGB(newColor)); + invalidate(); + } + + private int ave(int s, int d, float p) { + return s + Math.round(p * (d - s)); + } + + private int interpColor(int colors[], float unit) { + if (unit <= 0) { + return colors[0]; + } + if (unit >= 1) { + return colors[colors.length - 1]; + } + + float p = unit * (colors.length - 1); + int i = (int) p; + p -= i; + + // now p is just the fractional part [0...1) and i is the index + int c0 = colors[i]; + int c1 = colors[i + 1]; + int a = ave(Color.alpha(c0), Color.alpha(c1), p); + int r = ave(Color.red(c0), Color.red(c1), p); + int g = ave(Color.green(c0), Color.green(c1), p); + int b = ave(Color.blue(c0), Color.blue(c1), p); + + return Color.argb(a, r, g, b); + } + + private int rotateColor(int color, float rad) { + float deg = rad * 180 / 3.1415927f; + int r = Color.red(color); + int g = Color.green(color); + int b = Color.blue(color); + + ColorMatrix cm = new ColorMatrix(); + ColorMatrix tmp = new ColorMatrix(); + + cm.setRGB2YUV(); + tmp.setRotate(0, deg); + cm.postConcat(tmp); + tmp.setYUV2RGB(); + cm.postConcat(tmp); + + final float[] a = cm.getArray(); + + int ir = floatToByte(a[0] * r + a[1] * g + a[2] * b); + int ig = floatToByte(a[5] * r + a[6] * g + a[7] * b); + int ib = floatToByte(a[10] * r + a[11] * g + a[12] * b); + + return Color.argb(Color.alpha(color), pinToByte(ir), pinToByte(ig), + pinToByte(ib)); + } + + private static final float PI = 3.1415926f; + + @Override + public boolean onTouchEvent(MotionEvent event) { + float x = event.getX() - CENTER_X; + float y = event.getY() - CENTER_Y; + boolean inCenter = Math.sqrt(x * x + y * y) <= CENTER_RADIUS; + + switch (event.getAction()) { + case MotionEvent.ACTION_DOWN: + mTrackingCenter = inCenter; + if (inCenter) { + mHighlightCenter = true; + invalidate(); + break; + } + case MotionEvent.ACTION_MOVE: + if (mTrackingCenter) { + if (mHighlightCenter != inCenter) { + mHighlightCenter = inCenter; + invalidate(); + } + } else { + float angle = (float) Math.atan2(y, x); + // need to turn angle [-PI ... PI] into unit [0....1] + float unit = angle / (2 * PI); + if (unit < 0) { + unit += 1; + } + int color = interpColor(mColors, unit); + mCenterPaint.setColor(color); + mEditText.setText(convertToARGB(color)); + invalidate(); + } + break; + case MotionEvent.ACTION_UP: + if (mTrackingCenter) { + if (inCenter) { + //color = mCenterPaint.getColor(); + dialog.onClick(dialog.getDialog(), DialogInterface.BUTTON_POSITIVE); + dialog.getDialog().dismiss(); + } + mTrackingCenter = false; // so we draw w/o halo + invalidate(); + } + break; + } + return true; + } + } + + private String convertToARGB(int color) { + String alpha = Integer.toHexString(Color.alpha(color)); + String red = Integer.toHexString(Color.red(color)); + String green = Integer.toHexString(Color.green(color)); + String blue = Integer.toHexString(Color.blue(color)); + + if (alpha.length() == 1) { + alpha = "0" + alpha; + } + + if (red.length() == 1) { + red = "0" + red; + } + + if (green.length() == 1) { + green = "0" + green; + } + + if (blue.length() == 1) { + blue = "0" + blue; + } + + return "#" + alpha + red + green + blue; + } + + private int convertToColorInt(String argb) throws NumberFormatException { + + int alpha = -1, red = -1, green = -1, blue = -1; + + if (argb.length() == 8) { + alpha = Integer.parseInt(argb.substring(0, 2), 16); + red = Integer.parseInt(argb.substring(2, 4), 16); + green = Integer.parseInt(argb.substring(4, 6), 16); + blue = Integer.parseInt(argb.substring(6, 8), 16); + } else if (argb.length() == 6) { + alpha = 255; + red = Integer.parseInt(argb.substring(0, 2), 16); + green = Integer.parseInt(argb.substring(2, 4), 16); + blue = Integer.parseInt(argb.substring(4, 6), 16); + } + + return Color.argb(alpha, red, green, blue); + } + + //private Context mContext; + private EditText mEditText; + private ColorPickerView mColorPickerView; + private SeekBar mTransparencyBar; + + // public ColorPickerDialog(Context context, OnColorChangedListener + // listener, int initialColor) { + // + // mContext = context; + // mListener = listener; + // mInitialColor = initialColor; + // } + +// private OnColorChangedListener onColorChangedListener = new OnColorChangedListener() { +// public void colorChanged(int color) { +// //mListener.colorChanged(color); +// // dismiss(); +// } +// }; + + private SeekBar.OnSeekBarChangeListener onTransparencyChangedListener = new SeekBar.OnSeekBarChangeListener() { + + public void onProgressChanged(SeekBar seekBar, int progress, + boolean fromUser) { + mColorPickerView.setTransparency(progress); + } + + public void onStartTrackingTouch(SeekBar seekBar) { + } + + public void onStopTrackingTouch(SeekBar seekBar) { + } + }; + + private TextWatcher mEditTextListener = new TextWatcher() { + + public void afterTextChanged(Editable s) { + } + + public void beforeTextChanged(CharSequence s, int start, int count, + int after) { + } + + public void onTextChanged(CharSequence s, int start, int before, + int count) { + try { + String s2 = (s.toString()).replace("#", ""); + if (s2.length() == 6 || s2.length() == 8) { + int color = convertToColorInt(s2); + mColorPickerView.setCenterColor(color); + mTransparencyBar.setProgress(Color.alpha(color)); + } + } catch (NumberFormatException e) { + } + } + }; + + // Source: http://www.anddev.org/announce_color_picker_dialog-t10771.html + static final int[] STATE_FOCUSED = { android.R.attr.state_focused }; + static final int[] STATE_PRESSED = { android.R.attr.state_pressed }; + + static class TextSeekBarDrawable extends Drawable implements Runnable { + + private static final String TAG = "TextSeekBarDrawable"; + private static final long DELAY = 50; + private String mText; + private Drawable mProgress; + private Paint mPaint; + private Paint mOutlinePaint; + private float mTextWidth; + private boolean mActive; + private float mTextXScale; + private int mDelta; + private ScrollAnimation mAnimation; + + public TextSeekBarDrawable(Resources res, String label, + boolean labelOnRight) { + mText = label; + mProgress = res.getDrawable(android.R.drawable.progress_horizontal); + mPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mPaint.setTypeface(Typeface.DEFAULT_BOLD); + mPaint.setTextSize(16); + mPaint.setColor(0xff000000); + mOutlinePaint = new Paint(mPaint); + mOutlinePaint.setStyle(Style.STROKE); + mOutlinePaint.setStrokeWidth(3); + mOutlinePaint.setColor(0xbbffc300); + mOutlinePaint.setMaskFilter(new BlurMaskFilter(1, Blur.NORMAL)); + mTextWidth = mOutlinePaint.measureText(mText); + mTextXScale = labelOnRight ? 1 : 0; + mAnimation = new ScrollAnimation(); + } + + @Override + protected void onBoundsChange(Rect bounds) { + mProgress.setBounds(bounds); + } + + @Override + protected boolean onStateChange(int[] state) { + mActive = StateSet.stateSetMatches(STATE_FOCUSED, state) + | StateSet.stateSetMatches(STATE_PRESSED, state); + invalidateSelf(); + return false; + } + + @Override + public boolean isStateful() { + return true; + } + + @Override + protected boolean onLevelChange(int level) { + // Log.d(TAG, "onLevelChange " + level); + if (level < 4000 && mDelta <= 0) { + // Log.d(TAG, "onLevelChange scheduleSelf ++"); + mDelta = 1; + mAnimation.startScrolling(mTextXScale, 1); + scheduleSelf(this, SystemClock.uptimeMillis() + DELAY); + } else if (level > 6000 && mDelta >= 0) { + // Log.d(TAG, "onLevelChange scheduleSelf --"); + mDelta = -1; + mAnimation.startScrolling(mTextXScale, 0); + scheduleSelf(this, SystemClock.uptimeMillis() + DELAY); + } + return mProgress.setLevel(level); + } + + @Override + public void draw(Canvas canvas) { + mProgress.draw(canvas); + + if (mAnimation.hasStarted() && !mAnimation.hasEnded()) { + // pending animation + mAnimation.getTransformation( + AnimationUtils.currentAnimationTimeMillis(), null); + mTextXScale = mAnimation.getCurrent(); + // Log.d(TAG, "draw " + mTextX + " " + + // SystemClock.uptimeMillis()); + } + + Rect bounds = getBounds(); + float x = 6 + mTextXScale * (bounds.width() - mTextWidth - 6 - 6); + float y = (bounds.height() + mPaint.getTextSize()) / 2; + mOutlinePaint.setAlpha(mActive ? 255 : 255 / 2); + mPaint.setAlpha(mActive ? 255 : 255 / 2); + canvas.drawText(mText, x, y, mOutlinePaint); + canvas.drawText(mText, x, y, mPaint); + } + + @Override + public int getOpacity() { + return PixelFormat.TRANSLUCENT; + } + + @Override + public void setAlpha(int alpha) { + } + + @Override + public void setColorFilter(ColorFilter cf) { + } + + public void run() { + mAnimation.getTransformation( + AnimationUtils.currentAnimationTimeMillis(), null); + // close interpolation of mTextX + mTextXScale = mAnimation.getCurrent(); + if (!mAnimation.hasEnded()) { + scheduleSelf(this, SystemClock.uptimeMillis() + DELAY); + } + invalidateSelf(); + // Log.d(TAG, "run " + mTextX + " " + SystemClock.uptimeMillis()); + } + } + + static class ScrollAnimation extends Animation { + private static final String TAG = "ScrollAnimation"; + private static final long DURATION = 750; + private float mFrom; + private float mTo; + private float mCurrent; + + public ScrollAnimation() { + setDuration(DURATION); + setInterpolator(new DecelerateInterpolator()); + } + + public void startScrolling(float from, float to) { + mFrom = from; + mTo = to; + startNow(); + } + + @Override + protected void applyTransformation(float interpolatedTime, + Transformation t) { + mCurrent = mFrom + (mTo - mFrom) * interpolatedTime; + // Log.d(TAG, "applyTransformation " + mCurrent); + } + + public float getCurrent() { + return mCurrent; + } + } + + /** + * {@inheritDoc} + */ + @Override + protected View onCreateDialogView() { + + LinearLayout layout = new LinearLayout(getContext()); + layout.setOrientation(LinearLayout.VERTICAL); + layout.setGravity(android.view.Gravity.CENTER); + + LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams( + LinearLayout.LayoutParams.FILL_PARENT, + LinearLayout.LayoutParams.WRAP_CONTENT); + layoutParams.setMargins(10, 0, 10, 5); + + TextView tv = new TextView(getContext()); + tv.setText("Pick a Color"); + layout.addView(tv, layoutParams); + + mColorPickerView = new ColorPickerView(this, +// onColorChangedListener, + mInitialColor); + layout.addView(mColorPickerView, layoutParams); + + mTransparencyBar = new SeekBar(getContext()); + mTransparencyBar.setMax(255); + mTransparencyBar.setProgressDrawable(new TextSeekBarDrawable(getContext() + .getResources(), "alpha", true)); + mTransparencyBar.setProgress(Color.alpha(mInitialColor)); + mTransparencyBar + .setOnSeekBarChangeListener(onTransparencyChangedListener); + layout.addView(mTransparencyBar, layoutParams); + + mEditText = new EditText(getContext()); + mEditText.addTextChangedListener(mEditTextListener); + mEditText.setText(convertToARGB(mInitialColor)); + layout.addView(mEditText, layoutParams); + + CheckBox cb = new CheckBox(getContext()); + + +// OnColorChangedListener l = new OnColorChangedListener() { +// public void colorChanged(int color) { +// mListener.colorChanged(color); +// } +// }; + return layout; + } + + + @Override + protected void onSetInitialValue(boolean restoreValue, Object defaultValue) { + mInitialColor = (restoreValue ? getPersistedInt(mInitialColor) : (Integer) defaultValue); + persistInt(mInitialColor); + } + /** + * {@inheritDoc} + */ + @Override + public void setDefaultValue(final Object defaultValue) { + super.setDefaultValue(defaultValue); + // if (defaultValue instanceof String) { + // this.defValue = Utils.parseLong((String) defaultValue, + // this.defValue); + // } else if (defaultValue instanceof Long) { + // this.defValue = (Long) defaultValue; + // } + } + + + public ColorPickerPreference(Context context, AttributeSet attrs) { + super(context, attrs); + this.setPersistent(true); + mInitialColor = this.getPersistedInt(0); + } + + + @Override + protected void onDialogClosed(boolean positiveResult) { + super.onDialogClosed(positiveResult); + + if (positiveResult) { + int c = mColorPickerView.mCenterPaint.getColor(); + callChangeListener(c); + persistInt(c); + mInitialColor = c; + + } + } + +// @Override +// protected void onSetInitialValue(boolean restorePersistedValue, +// Object defaultValue) { +// mInitialColor = (restorePersistedValue ? getPersistedInt(mInitialColor) : (Integer) defaultValue); +// } + + // public ColorPickerDialog(Context context, + // OnColorChangedListener listener, + // int initialColor) { + // //super(context); + // + // mListener = listener; + // mInitialColor = initialColor; + // } + // + // @Override + // protected void onCreate(Bundle savedInstanceState) { + // super.onCreate(savedInstanceState); + // OnColorChangedListener l = new OnColorChangedListener() { + // public void colorChanged(int color) { + // mListener.colorChanged(color); + // dismiss(); + // } + // }; + // + // setContentView(new ColorPickerView(getContext(), l, mInitialColor)); + // setTitle("Pick a Color"); + // } +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerView.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerView.java new file mode 100644 index 0000000..b645bf0 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/gui/colorpicker/ColorPickerView.java @@ -0,0 +1,177 @@ +/* + * Copyright (C) 2011 Menny Even Danan + * + * 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. + */ + +/* +http://blog.evendanan.net/2011/08/Fingerpainting-app-for-Hagar-OR-Multitouch-sample-code +*/ +package de.bjusystems.vdrmanager.gui.colorpicker; + +import android.content.Context; +import android.graphics.Canvas; +import android.graphics.Color; +import android.graphics.Paint; +import android.graphics.RectF; +import android.graphics.Shader; +import android.graphics.SweepGradient; +import android.util.DisplayMetrics; +import android.view.MotionEvent; +import android.view.View; + + +class ColorPickerView extends View { + private Paint mPaint; + private Paint mCenterPaint; + private final int[] mColors; + private ColorPickerDialog.OnColorChangedListener mListener; + + ColorPickerView(Context c, ColorPickerDialog.OnColorChangedListener l, int color) { + super(c); + mListener = l; + mColors = new int[]{ + 0xFFFF0000, 0xFFFF00FF, 0xFF0000FF, 0xFF00FFFF, 0xFF00FF00, + 0xFFFFFF00, 0xFFFFFFFF, 0xFF000000, 0xFFFF0000 + }; + Shader s = new SweepGradient(0, 0, mColors, null); + + mPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mPaint.setShader(s); + mPaint.setStyle(Paint.Style.STROKE); + mPaint.setStrokeWidth(32); + + mCenterPaint = new Paint(Paint.ANTI_ALIAS_FLAG); + mCenterPaint.setColor(color); + mCenterPaint.setStrokeWidth(5); + + + DisplayMetrics dm = c.getResources().getDisplayMetrics(); + + CENTER_X = Math.min(dm.widthPixels, dm.heightPixels) / 3; + CENTER_Y = CENTER_X; + } + + private boolean mTrackingCenter; + private boolean mHighlightCenter; + + @Override + protected void onDraw(Canvas canvas) { + float r = CENTER_X - mPaint.getStrokeWidth() * 0.5f; + + canvas.translate(CENTER_X, CENTER_X); + + canvas.drawOval(new RectF(-r, -r, r, r), mPaint); + canvas.drawCircle(0, 0, CENTER_RADIUS, mCenterPaint); + + if (mTrackingCenter) { + int c = mCenterPaint.getColor(); + mCenterPaint.setStyle(Paint.Style.STROKE); + + if (mHighlightCenter) { + mCenterPaint.setAlpha(0xFF); + } else { + mCenterPaint.setAlpha(0x80); + } + canvas.drawCircle(0, 0, + CENTER_RADIUS + mCenterPaint.getStrokeWidth(), + mCenterPaint); + + mCenterPaint.setStyle(Paint.Style.FILL); + mCenterPaint.setColor(c); + } + } + + @Override + protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { + + setMeasuredDimension(CENTER_X * 2, CENTER_Y * 2); + } + + private int CENTER_X = 100; + private int CENTER_Y = 100; + private int CENTER_RADIUS = 32; + + private int ave(int s, int d, float p) { + return s + Math.round(p * (d - s)); + } + + private int interpColor(int colors[], float unit) { + if (unit <= 0) { + return colors[0]; + } + if (unit >= 1) { + return colors[colors.length - 1]; + } + + float p = unit * (colors.length - 1); + int i = (int) p; + p -= i; + + // now p is just the fractional part [0...1) and i is the index + int c0 = colors[i]; + int c1 = colors[i + 1]; + int a = ave(Color.alpha(c0), Color.alpha(c1), p); + int r = ave(Color.red(c0), Color.red(c1), p); + int g = ave(Color.green(c0), Color.green(c1), p); + int b = ave(Color.blue(c0), Color.blue(c1), p); + + return Color.argb(a, r, g, b); + } + + private static final float PI = 3.1415926f; + + @Override + public boolean onTouchEvent(MotionEvent event) { + float x = event.getX() - CENTER_X; + float y = event.getY() - CENTER_Y; + boolean inCenter = Math.sqrt(x * x + y * y) <= CENTER_RADIUS; + + switch (event.getAction()) { + case MotionEvent.ACTION_DOWN: + mTrackingCenter = inCenter; + if (inCenter) { + mHighlightCenter = true; + invalidate(); + break; + } + case MotionEvent.ACTION_MOVE: + if (mTrackingCenter) { + if (mHighlightCenter != inCenter) { + mHighlightCenter = inCenter; + invalidate(); + } + } else { + float angle = (float) Math.atan2(y, x); + // need to turn angle [-PI ... PI] into unit [0....1] + float unit = angle / (2 * PI); + if (unit < 0) { + unit += 1; + } + mCenterPaint.setColor(interpColor(mColors, unit)); + invalidate(); + } + break; + case MotionEvent.ACTION_UP: + if (mTrackingCenter) { + if (inCenter) { + mListener.colorChanged(mCenterPaint.getColor()); + } + mTrackingCenter = false; // so we draw w/o halo + invalidate(); + } + break; + } + return true; + } +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/FaListDialog.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/FaListDialog.java new file mode 100644 index 0000000..7ea9844 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/FaListDialog.java @@ -0,0 +1,200 @@ +package de.bjusystems.vdrmanager.remote; + + +import android.app.Dialog; +import android.content.Context; +import android.os.Bundle; +import android.view.LayoutInflater; +import android.view.View; +import android.widget.AdapterView; +import android.widget.ArrayAdapter; +import android.widget.ListView; +import android.widget.SearchView; + +import java.io.Serializable; + +import de.bjusystems.vdrmanager.R; + +public class FaListDialog extends Dialog implements + SearchView.OnQueryTextListener, SearchView.OnCloseListener { + + private static final String ITEMS = "items"; + + private ArrayAdapter listAdapter; + + private SearchableItem<String> searchableItem; + + public FaListDialog(Context context) { + super(context); + } + + @Override + public void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + + // Getting the layout inflater to inflate the view in an alert dialog. + LayoutInflater inflater = LayoutInflater.from(getContext()); + + // Crash on orientation change #7 + // Change Start + // Description: As the instance was re initializing to null on rotating the device, + // getting the instance from the saved instance + // Change End + + View rootView = inflater.inflate(R.layout.searchable_list_dialog, null); + + final ListView viewById = (ListView) rootView.findViewById(R.id.listItems); + viewById.setOnItemClickListener(new AdapterView.OnItemClickListener() { + @Override + public void onItemClick(AdapterView<?> parent, View view, int position, long id) { + String item = String.valueOf(listAdapter.getItem(position)); + if (searchableItem != null) { + searchableItem.onSearchableItemClicked(item, position); + } + FaListDialog.this.dismiss(); + } + }); + ((SearchView) rootView.findViewById(R.id.search)).setOnQueryTextListener(new SearchView.OnQueryTextListener() { + @Override + public boolean onQueryTextSubmit(String query) { + return false; + } + + @Override + public boolean onQueryTextChange(String newText) { + listAdapter.getFilter().filter(newText); + return false; + } + }); +// +// //create the adapter by passing your ArrayList data + listAdapter = ArrayAdapter.createFromResource(getContext(), R.array.font, R.layout.simple_list_item_1_fa); + viewById.setAdapter(listAdapter); + setContentView(rootView); + } + + @Override + public boolean onClose() { + return false; + } + + @Override + public boolean onQueryTextSubmit(String query) { + return false; + } + + @Override + public boolean onQueryTextChange(String newText) { + return false; + } + + public SearchableItem getSearchableItem() { + return searchableItem; + } + + public void setSearchableItem(SearchableItem searchableItem) { + this.searchableItem = searchableItem; + } + +// // Crash on orientation change #7 +// // Change Start +// // Description: Saving the instance of searchable item instance. +// @Override +// public void onSaveInstanceState(Bundle outState) { +// outState.putSerializable("item", _searchableItem); +// super.onSaveInstanceState(outState); +// } +// // Change End +// +// public void setTitle(String strTitle) { +// _strTitle = strTitle; +// } +// +// public void setPositiveButton(String strPositiveButtonText) { +// _strPositiveButtonText = strPositiveButtonText; +// } +// +// public void setPositiveButton(String strPositiveButtonText, DialogInterface.OnClickListener onClickListener) { +// _strPositiveButtonText = strPositiveButtonText; +// _onClickListener = onClickListener; +// } +// +// public void setOnSearchableItemClickListener(SearchableItem searchableItem) { +// this._searchableItem = searchableItem; +// } +// +// public void setOnSearchTextChangedListener(OnSearchTextChanged onSearchTextChanged) { +// this._onSearchTextChanged = onSearchTextChanged; +// } +// +// private void setData(View rootView) { +// SearchManager searchManager = (SearchManager) getActivity().getSystemService(Context +// .SEARCH_SERVICE); +// +// _searchView = (SearchView) rootView.findViewById(R.id.search); +// _searchView.setSearchableInfo(searchManager.getSearchableInfo(getActivity().getComponentName +// ())); +// _searchView.setIconifiedByDefault(false); +// _searchView.setOnQueryTextListener(this); +// _searchView.setOnCloseListener(this); +// _searchView.clearFocus(); +// InputMethodManager mgr = (InputMethodManager) getActivity().getSystemService(Context +// .INPUT_METHOD_SERVICE); +// mgr.hideSoftInputFromWindow(_searchView.getWindowToken(), 0); +// +// +// List items = (List) getArguments().getSerializable(ITEMS); +// +// _listViewItems = (ListView) rootView.findViewById(R.id.listItems); +// +// //create the adapter by passing your ArrayList data +// listAdapter = new ArrayAdapter(getActivity(), android.R.layout.simple_list_item_1, +// items); +// //attach the adapter to the list +// _listViewItems.setAdapter(listAdapter); +// +// _listViewItems.setTextFilterEnabled(true); +// +// _listViewItems.setOnItemClickListener(new AdapterView.OnItemClickListener() { +// @Override +// public void onItemClick(AdapterView<?> parent, View view, int position, long id) { +// _searchableItem.onSearchableItemClicked(listAdapter.getItem(position), position); +// getDialog().dismiss(); +// } +// }); +// } +// +// @Override +// public boolean onClose() { +// return false; +// } +// +// @Override +// public boolean onQueryTextSubmit(String s) { +// _searchView.clearFocus(); +// return true; +// } +// +// @Override +// public boolean onQueryTextChange(String s) { +//// listAdapter.filterData(s); +// if (TextUtils.isEmpty(s)) { +//// _listViewItems.clearTextFilter(); +// ((ArrayAdapter) _listViewItems.getAdapter()).getFilter().filter(null); +// } else { +// ((ArrayAdapter) _listViewItems.getAdapter()).getFilter().filter(s); +// } +// if (null != _onSearchTextChanged) { +// _onSearchTextChanged.onSearchTextChanged(s); +// } +// return true; +// } + + public interface SearchableItem<T> extends Serializable { + void onSearchableItemClicked(T item, int position); + } + + public interface OnSearchTextChanged { + void onSearchTextChanged(String strText); + } +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/HITK.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/HITK.java index 5d0c596..10513b3 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/HITK.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/HITK.java @@ -15,16 +15,16 @@ public enum HITK { Green, Yellow, Blue, - Zero("0"), - One("1"), - Two("2"), - Three("3"), - Four("4"), - Five("5"), - Six("6"), - Seven("7"), - Eight("8"), - Nine("9"), + Zero("0"), + One("1"), + Two("2"), + Three("3"), + Four("4"), + Five("5"), + Six("6"), + Seven("7"), + Eight("8"), + Nine("9"), Info, Play_Pause("Play/Pause"), Play, diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/RemoteActivity.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/RemoteActivity.java index 7711a4a..7b73761 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/RemoteActivity.java +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/remote/RemoteActivity.java @@ -4,6 +4,7 @@ package de.bjusystems.vdrmanager.remote; import android.app.Activity; import android.app.AlertDialog; import android.content.Context; +import android.content.ContextWrapper; import android.content.DialogInterface; import android.content.Intent; import android.content.SharedPreferences; @@ -13,7 +14,6 @@ import android.os.Build; import android.os.Bundle; import android.os.Environment; import android.util.Log; -import android.util.Pair; import android.view.ContextMenu; import android.view.KeyEvent; import android.view.Menu; @@ -51,13 +51,22 @@ import java.util.Set; import de.androvdr.widget.AnimatedTextView; import de.androvdr.widget.FontAwesome; +import de.bjusystems.vdrmanager.ButtonMapping; import de.bjusystems.vdrmanager.R; import de.bjusystems.vdrmanager.backup.IOUtils; import de.bjusystems.vdrmanager.data.Preferences; -import de.bjusystems.vdrmanager.gui.ColoredButton; import de.bjusystems.vdrmanager.gui.Utils; +import de.bjusystems.vdrmanager.gui.colorpicker.ColorPickerDialog; import de.bjusystems.vdrmanager.tasks.VoidAsyncTask; +import static de.bjusystems.vdrmanager.ButtonMapping.COLOR; +import static de.bjusystems.vdrmanager.ButtonMapping.COLOR_PREFIX; +import static de.bjusystems.vdrmanager.ButtonMapping.KEY; +import static de.bjusystems.vdrmanager.ButtonMapping.KEY_PREFIX; +import static de.bjusystems.vdrmanager.ButtonMapping.LABEL; +import static de.bjusystems.vdrmanager.ButtonMapping.LABEL_PREFIX; +import static de.bjusystems.vdrmanager.ButtonMapping.NO_COLOR; + /** * The type Remote activity. */ @@ -187,22 +196,20 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On public void export() { SharedPreferences sharedPref = getSharedPreferences("remote_" + Preferences.get().getCurrentVdr().getId(), Context.MODE_PRIVATE); ViewGroup viewGroup = (ViewGroup) findViewById(R.id.remoteroot); - HashMap<String, Pair<String, String>> map = new HashMap<>(); + HashMap<String, ButtonMapping> map = new HashMap<>(); collect(viewGroup, map, sharedPref); - if(map.isEmpty()){ + if (map.isEmpty()) { Utils.say(this, R.string.remote_nothing_to_import); return; } JSONObject root = new JSONObject(); try { - for (Map.Entry<String, Pair<String, String>> e : map.entrySet()) { - JSONObject pair = new JSONObject(); - Pair<String, String> stringStringPair = e.getValue(); - pair.put("key", stringStringPair.first); - pair.put("label", stringStringPair.second); - root.put(e.getKey(), pair); + for (Map.Entry<String, ButtonMapping> e : map.entrySet()) { + JSONObject button = new JSONObject(); + ButtonMapping buttonMapping = e.getValue(); + root.put(e.getKey(), buttonMapping.toJson()); } } catch (JSONException jse) { Utils.say(this, jse.getLocalizedMessage()); @@ -248,7 +255,7 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On * @param map the map * @param sharedPref the shared pref */ - public void collect(ViewGroup viewGroup, HashMap<String, Pair<String, String>> map, SharedPreferences sharedPref) { + public void collect(ViewGroup viewGroup, HashMap<String, ButtonMapping> map, SharedPreferences sharedPref) { for (int i = 0; i < viewGroup.getChildCount(); i++) { View v = viewGroup.getChildAt(i); if (v instanceof ViewGroup) { @@ -258,12 +265,13 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On continue; } String tagKey = String.valueOf(v.getTag()); - String hitk = sharedPref.getString("key_" + tagKey, null); - String label = sharedPref.getString("label_" + tagKey, null); - if (hitk == null && label == null) { + String hitk = sharedPref.getString(KEY_PREFIX + tagKey, null); + String label = sharedPref.getString(LABEL_PREFIX + tagKey, null); + Integer color = sharedPref.getInt(COLOR_PREFIX + tagKey, -1); + if (hitk == null && label == null && color == -1) { continue; } - map.put(tagKey, Pair.create(hitk, label)); + map.put(tagKey, new ButtonMapping(hitk, label, color)); } } } @@ -317,14 +325,24 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On ((Button) v).setOnClickListener(this); ((Button) v).setOnLongClickListener(this); - String hitk = sharedPref.getString("key_" + String.valueOf(v.getTag()), null); + String hitk = sharedPref.getString(KEY_PREFIX + String.valueOf(v.getTag()), null); setOverrideTag(v, hitk); - String label = sharedPref.getString("label_" + String.valueOf(v.getTag()), null); + String label = sharedPref.getString(LABEL_PREFIX + String.valueOf(v.getTag()), null); setOverrideLabel((Button) v, label); + Integer color = sharedPref.getInt(COLOR_PREFIX + String.valueOf(v.getTag()), NO_COLOR); + setOverrideColor((Button) v, color); + } } } + private void setOverrideColor(Button v, Integer color) { + if (color == null || color == NO_COLOR) { + return; + } + v.setTextColor(color); + } + private void setOverrideLabel(Button b, CharSequence label) { if (label == null) { return; @@ -334,7 +352,7 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On private void restart() { - if(getIntent() != null) { + if (getIntent() != null) { getIntent().removeExtra(Intent.EXTRA_STREAM); } if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { @@ -412,6 +430,18 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On MenuItem item = menu.findItem(R.id.remapback); } + + private Activity scanForActivity(Context cont) { + if (cont == null) + return null; + else if (cont instanceof Activity) + return (Activity) cont; + else if (cont instanceof ContextWrapper) + return scanForActivity(((ContextWrapper) cont).getBaseContext()); + + return null; + } + @Override public boolean onLongClick(final View v) { @@ -420,48 +450,130 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On return true; } - CharSequence text = ((Button) v).getText(); final String tag = (String) v.getTag(); + + final Button button = (Button) v; + final CharSequence initilHitkLabel = button.getText(); final String override = (String) v.getTag(TAG_KEY); - String current = override != null ? override : tag; + final String initialHitk = override != null ? override : tag; - View view = getLayoutInflater().inflate(R.layout.edit_remote_key, null); + final View rview = getLayoutInflater().inflate(R.layout.edit_remote_key, null); - final EditText hitk = (EditText) view.findViewById(R.id.hitk); - TextView hitkLabel = (TextView) view.findViewById(R.id.hitkLabel); - if (v instanceof ColoredButton) { - hitk.setVisibility(View.GONE); - hitkLabel.setVisibility(View.GONE); - } else { - hitk.setVisibility(View.VISIBLE); - hitkLabel.setVisibility(View.VISIBLE); - hitk.setTypeface( - FontAwesome.getFontAwesome(this) - ); - } - hitk.setText(text); - final Spinner hitkspinner = (Spinner) view.findViewById(R.id.hitkSpinner); + final EditText hitk = (EditText) rview.findViewById(R.id.hitk); + TextView hitkLabel = (TextView) rview.findViewById(R.id.hitkLabel); + View hitkLabelColorPicker = rview.findViewById(R.id.hitkLabelColorPicker); + View faPicker = rview.findViewById(R.id.faPicker); + + faPicker.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + ArrayList items = new ArrayList(); + FaListDialog faListDialog = new FaListDialog(RemoteActivity.this); + faListDialog.setSearchableItem(new FaListDialog.SearchableItem<String>() { + @Override + public void onSearchableItemClicked(String item, int position) { + hitk.setText(item.substring(0,1)); + hitk.setSelection(hitk.getText(). + length()); + } + }); + //faListDialog.setOnSearchableItemClickListener(new FaListDialog.SearchableItem() { + // @Override + //public void onSearchableItemClicked(Object item, int position) { + +// } +// }); + + + faListDialog.show(); +// AlertDialog.Builder builder = new AlertDialog.Builder(RemoteActivity.this); +// View view = getLayoutInflater().inflate(R.layout.searchspinner, null); +// builder.setView(view); +// if (view instanceof ViewGroup) { +// ViewGroup faPickerVG = (ViewGroup) view; +// for (int i = 0; i < faPickerVG.getChildCount(); ++i) { +// final View childAt = faPickerVG.getChildAt(i); +// if (childAt instanceof TextView) { +// ((TextView) childAt).setTypeface(FontAwesome.getFontAwesome(RemoteActivity.this)); +// } +// } +// } +// builder.create().show(); + + } + }); +// if (v instanceof ColoredButton) { +// hitk.setVisibility(View.GONE); +// hitkLabel.setVisibility(View.GONE); +// } else { + hitk.setVisibility(View.VISIBLE); + hitkLabel.setVisibility(View.VISIBLE); + hitk.setTypeface( + FontAwesome.getFontAwesome(this)); + //); + //} + hitk.setText(initilHitkLabel); + hitk.setSelection(hitk.getText(). + + length()); + + final int initialTextColor = button.getCurrentTextColor(); + final int[] currentTextColor = {initialTextColor}; + hitk.setTextColor(currentTextColor[0]); + final ColorPickerDialog colorPicker = new ColorPickerDialog( + + RemoteActivity.this, null, currentTextColor[0]); + colorPicker + .setOnColorChangedListener(new ColorPickerDialog.OnColorChangedListener() { + @Override + public void colorChanged(int color) { + currentTextColor[0] = color; + hitk.setTextColor(currentTextColor[0]); + + colorPicker.dismiss(); + } + }); + hitkLabelColorPicker.setOnClickListener(new OnClickListener() { + @Override + public void onClick(View v) { + + colorPicker.show(); + } + }); + + + final Spinner hitkspinner = (Spinner) rview.findViewById(R.id.hitkSpinner); final ArrayList<String> keys = new ArrayList<>(); - for (de.bjusystems.vdrmanager.remote.HITK hk : de.bjusystems.vdrmanager.remote.HITK.values()) { + for ( + de.bjusystems.vdrmanager.remote.HITK hk : de.bjusystems.vdrmanager.remote.HITK.values()) + + { keys.add(hk.getValue()); } + ArrayAdapter<CharSequence> adapter = new ArrayAdapter<CharSequence>(this, android.R.layout.simple_spinner_dropdown_item, keys.toArray(new String[]{})); // Specify the layout to use when the list of choices appears // hitkspinner.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); // Apply the adapter to the spinner hitkspinner.setAdapter(adapter); int selected = -1; - for (int i = 0; i < keys.size(); ++i) { + for ( + int i = 0; i < keys.size(); ++i) + + { String k = keys.get(i); - if (k.equals(current)) { + if (k.equals(initialHitk)) { selected = i; break; } } hitkspinner.setSelection(selected); - hitkspinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { + hitkspinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() + + { @Override public void onItemSelected(AdapterView<?> parent, View view, int position, long id) { @@ -474,26 +586,54 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On }); AlertDialog.Builder builder = new AlertDialog.Builder(this); - builder.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() { + builder.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() + + { @Override public void onClick(DialogInterface dialog, int which) { CharSequence nhk = hitk.getText(); - ((Button) v).setText(nhk); String hitk = (String) hitkspinner.getSelectedItem(); - putVdrKey("key_" + tag, hitk); - putVdrKey("label_" + tag, nhk); + if (initialTextColor == currentTextColor[0] &&// + initilHitkLabel.toString().equals(nhk.toString()) && // + initialHitk.equals(hitk) + ) { + return; + } + + ((Button) v).setText(nhk); + ((Button) v).setTextColor(currentTextColor[0]); + putVdrKey(KEY_PREFIX + tag, hitk); + putVdrKey(LABEL_PREFIX + tag, nhk); + if (currentTextColor[0] != NO_COLOR) { + putVdrKey(COLOR_PREFIX + tag, currentTextColor[0]); + } setOverrideTag(v, hitk); } }) - .setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() { + . + + setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int which) { + + } + }). + setNeutralButton(R.string.reset, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { - + removeVdrKey(KEY_PREFIX + tag); + removeVdrKey(LABEL_PREFIX + tag); + removeVdrKey(COLOR_PREFIX + tag); + restart(); } - }).setView(view); + }) + + .setView(rview); + + builder.create(). - builder.create().show(); + show(); return false; @@ -539,14 +679,17 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On if (all.contains(next) == false) { continue; } - JSONObject pair = object.getJSONObject(next); - String key = pair.getString("key"); + JSONObject button = object.getJSONObject(next); + String key = button.getString(KEY); if (all.contains(key) == false) { continue; } - String value = pair.getString("label"); - edit.putString("key_" + next, key); - edit.putString("label_" + next, value); + String value = button.getString(LABEL); + edit.putString(KEY_PREFIX + next, key); + edit.putString(LABEL_PREFIX + next, value); + if (button.getInt(COLOR) != NO_COLOR) { + edit.putInt(COLOR_PREFIX + next, button.getInt(COLOR)); + } counter++; } edit.commit(); @@ -570,6 +713,20 @@ public class RemoteActivity extends Activity implements OnClickListener, View.On edit.commit(); } + private void removeVdrKey(String key) { + SharedPreferences sharedPref = getSharedPreferences("remote_" + Preferences.get().getCurrentVdr().getId(), Context.MODE_PRIVATE); + SharedPreferences.Editor edit = sharedPref.edit(); + edit.remove(key); + edit.commit(); + } + + private void putVdrKey(String key, Integer value) { + SharedPreferences sharedPref = getSharedPreferences("remote_" + Preferences.get().getCurrentVdr().getId(), Context.MODE_PRIVATE); + SharedPreferences.Editor edit = sharedPref.edit(); + edit.putInt(key, value); + edit.commit(); + } + private String getCurrentTag(View view) { Object tag = view.getTag(); if (tag instanceof String == false) { diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/utils/VdrManagerExceptionHandler.java b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/utils/VdrManagerExceptionHandler.java new file mode 100644 index 0000000..bde604c --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/java/de/bjusystems/vdrmanager/utils/VdrManagerExceptionHandler.java @@ -0,0 +1,96 @@ +package de.bjusystems.vdrmanager.utils; + +import android.content.Context; +import android.content.Intent; + +import java.util.logging.Logger; + +/** + * The type Vdr manager exception handler. + */ +public class VdrManagerExceptionHandler implements Thread.UncaughtExceptionHandler { + private Context context; + + /** + * The Log. + */ + Logger log = Logger.getLogger(VdrManagerExceptionHandler.class.getSimpleName()); + + private Thread.UncaughtExceptionHandler previous; + + private static VdrManagerExceptionHandler INSTANCE; + + /** + * The constant RECEIVER. + */ + public static final String RECEIVER = "herrlado@gmail.com"; + + private VdrManagerExceptionHandler(Context context, + Thread.UncaughtExceptionHandler previous) { + this.context = context; + this.previous = previous; + + } + + /** + * Get vdr manager exception handler. + * + * @param context the context + * @param previous the previous + * @return the vdr manager exception handler + */ + public static VdrManagerExceptionHandler get(Context context, + Thread.UncaughtExceptionHandler previous) { + + if (INSTANCE != null) { + return INSTANCE; + } + INSTANCE = new VdrManagerExceptionHandler(context, previous); + + return INSTANCE; + } + + @Override + public void uncaughtException(Thread thread, Throwable e) { + + log.warning(e.getMessage()); + + StackTraceElement[] arr = e.getStackTrace(); + String report = e.toString() + "\n\n"; + report += "--------- Stack trace ---------\n\n"; + for (int i = 0; i < arr.length; i++) { + report += " " + arr[i].toString() + "\n"; + } + report += "-------------------------------\n\n"; + + // If the exception was thrown in a background thread inside + // AsyncTask, then the actual exception can be found with getCause + report += "--------- Cause ---------\n\n"; + Throwable cause = e.getCause(); + if (cause != null) { + report += cause.toString() + "\n\n"; + arr = cause.getStackTrace(); + for (int i = 0; i < arr.length; i++) { + report += " " + arr[i].toString() + "\n"; + } + } + report += "-------------------------------\n\n"; + + Intent sendIntent = new Intent(Intent.ACTION_SEND); + String subject = "Force Close Report VDR Manager"; + String body = "Sendlog for VDR Manager\n\n\n" + report + + "\n\n"; + + sendIntent.putExtra(Intent.EXTRA_EMAIL, + new String[]{RECEIVER}); + sendIntent.putExtra(Intent.EXTRA_TEXT, body); + sendIntent.putExtra(Intent.EXTRA_SUBJECT, subject); + sendIntent.setType("message/rfc822"); + + + context.startActivity(Intent.createChooser(sendIntent, + "Force Close Report VDR Manager")); + + previous.uncaughtException(thread, e); + } +} diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout-land/remote.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout-land/remote.xml new file mode 100644 index 0000000..c7e01a8 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout-land/remote.xml @@ -0,0 +1,399 @@ +<?xml version="1.0" encoding="utf-8"?> +<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" + xmlns:app="http://schemas.android.com/apk/res-auto" + android:id="@+id/remoteroot" + android:layout_width="fill_parent" + android:layout_height="fill_parent" + android:orientation="vertical" + android:padding="5dp"> + + + <LinearLayout + android:id="@+id/resultwrapper" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_alignParentEnd="true" + android:layout_alignParentRight="true" + android:layout_alignParentTop="true"> + + <de.androvdr.widget.AnimatedTextView + android:id="@+id/result" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:gravity="right" + android:maxLines="1" + android:textSize="10sp" /> + </LinearLayout> + + <LinearLayout + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:layout_below="@+id/resultwrapper" + android:orientation="horizontal"> + + <RelativeLayout + android:layout_width="wrap_content" + android:layout_height="match_parent" + android:layout_weight="1" + android:orientation="vertical"> + + + <LinearLayout + android:id="@+id/rows0" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" + android:layout_marginBottom="10dp" + android:orientation="horizontal"> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/Power" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Power" + android:text="XXX" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Back" + android:text="@string/back" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Setup" + android:text="@string/f085" /> + </LinearLayout> + + <RelativeLayout + android:id="@+id/navigation" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_above="@+id/rows1" + android:layout_alignParentEnd="true" + android:layout_alignParentRight="true" + android:layout_below="@+id/colorButtons"> + + <de.androvdr.widget.SquareButton + android:id="@+id/ok" + style="@style/cursorButton" + android:layout_centerVertical="true" + android:layout_gravity="center_horizontal" + android:layout_toLeftOf="@+id/right" + android:layout_toStartOf="@+id/right" + android:tag="Ok" + android:text="@string/ok" /> + + + <de.androvdr.widget.SquareButton + android:id="@+id/right" + style="@style/cursorButton" + android:layout_centerVertical="true" + android:layout_toEndOf="@+id/up" + android:layout_toRightOf="@+id/up" + android:tag="Right" + android:text="@string/f061" /> + + + <de.androvdr.widget.SquareButton + android:id="@+id/left" + style="@style/cursorButton" + android:layout_centerVertical="true" + android:layout_toLeftOf="@+id/ok" + android:layout_toStartOf="@+id/ok" + android:tag="Left" + android:text="@string/f060" /> + + <de.androvdr.widget.SquareButton + android:id="@+id/up" + style="@style/cursorButton" + android:layout_above="@+id/ok" + android:layout_centerHorizontal="true" + android:layout_gravity="center_horizontal" + android:tag="Up" + android:text="@string/f062" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/ChannelUp" + style="@style/volChanButton" + + android:layout_alignParentEnd="true" + android:layout_alignParentRight="true" + android:layout_alignTop="@+id/up" + android:tag="Channel+" + android:text="@string/f0aa" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/VolumeUp" + style="@style/volChanButton" + android:layout_height="wrap_content" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" + android:layout_alignTop="@+id/up" + android:tag="Volume+" + android:text="@string/f028" /> + + <de.androvdr.widget.SquareButton + android:id="@+id/down" + style="@style/cursorButton" + + android:layout_below="@+id/ok" + + android:layout_gravity="center_horizontal" + android:layout_toLeftOf="@+id/right" + android:layout_toStartOf="@+id/right" + android:tag="Down" + android:text="@string/f063" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/ChannelDown" + style="@style/volChanButton" + android:layout_alignBottom="@+id/down" + android:layout_alignParentEnd="true" + android:layout_alignParentRight="true" + android:tag="Channel-" + android:text="@string/f0ab" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/VolumeDown" + style="@style/volChanButton" + android:layout_alignBottom="@+id/down" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" + android:tag="Volume-" + android:text="@string/f027" /> + + </RelativeLayout> + + + <LinearLayout + android:id="@+id/colorButtons" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_alignParentEnd="true" + android:layout_alignParentRight="true" + android:layout_below="@+id/rows0" + android:orientation="horizontal"> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/red" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Red" + android:text="@string/remotesquares" + android:textColor="@color/red" /> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/green" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Green" + android:text="@string/remotesquares" + android:textColor="@color/green" /> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/yellow" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Yellow" + android:text="@string/remotesquares" + android:textColor="@color/yellow" /> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/blue" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Blue" + android:text="@string/remotesquares" + android:textColor="@color/blue" /> + + + </LinearLayout> + + + <LinearLayout + android:id="@+id/rows1" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_above="@+id/rows2" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" + android:orientation="horizontal"> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Mute" + android:text="@string/fa_mute" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Info" + android:text="@string/f129" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Back" + android:text="@string/f177" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Menu" + android:text="@string/f0c9" /> + + </LinearLayout> + + + <LinearLayout + + android:id="@+id/rows2" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_alignParentBottom="true" + android:layout_marginBottom="10dp" + android:layout_marginTop="10dp" + android:orientation="horizontal"> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Audio" + android:text="@string/f025" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Subtitles" + android:text="@string/fa_bars" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="PrevChannel" + android:text="@string/f0e2" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Commands" + android:text="@string/f120" /> + </LinearLayout> + + + </RelativeLayout> + + <RelativeLayout + android:layout_width="wrap_content" + android:layout_height="match_parent" + android:layout_weight="1"> + + <LinearLayout + android:layout_width="match_parent" + android:layout_height="match_parent" + android:layout_alignParentBottom="true" + android:layout_centerInParent="true" + android:orientation="horizontal"> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Audio" + android:text="@string/f025" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Subtitles" + android:text="S" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="PrevChannel" + android:text="@string/f0e2" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Commands" + android:text="@string/f120" /> + </LinearLayout> + + + + </RelativeLayout> + + + </LinearLayout> + +</RelativeLayout> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout-land/remote_test.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout-land/remote_test.xml new file mode 100644 index 0000000..8ac2b55 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout-land/remote_test.xml @@ -0,0 +1,344 @@ +<?xml version="1.0" encoding="utf-8"?> +<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" + xmlns:app="http://schemas.android.com/apk/res-auto" + android:id="@+id/remoteroot" + android:layout_width="fill_parent" + android:layout_height="fill_parent" + android:orientation="vertical" + android:padding="5dp"> + + + + <LinearLayout + android:id="@+id/resultwrapper" + android:layout_width="fill_parent" + android:layout_alignParentEnd="true" + android:layout_alignParentRight="true" + android:layout_alignParentTop="true" + android:layout_height="wrap_content"> + <de.androvdr.widget.AnimatedTextView + android:id="@+id/result" + android:maxLines="1" + android:layout_width="0dp" + android:layout_weight="1" + android:layout_height="wrap_content" + android:textSize="10sp" + android:gravity="right" /> + </LinearLayout> + + + + <LinearLayout + android:id="@+id/rows0" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:orientation="horizontal" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" + android:layout_marginBottom="10dp" + android:layout_below="@+id/resultwrapper"> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Power" + android:text="" + android:id="@+id/Power" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Back" + android:text="Back" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="" + /> + + + + + + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Setup" + android:text="" /> + </LinearLayout> + + <RelativeLayout + android:id="@+id/navigation" + + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_alignParentRight="true" + android:layout_alignParentEnd="true" + android:layout_below="@+id/colorButtons" + android:layout_above="@+id/rows1"> + + <de.androvdr.widget.SquareButton + android:id="@+id/ok" + style="@style/cursorButton" + android:layout_centerVertical="true" + android:layout_gravity="center_horizontal" + android:layout_toLeftOf="@+id/right" + android:layout_toStartOf="@+id/right" + android:tag="Ok" + android:text="OK" /> + + + <de.androvdr.widget.SquareButton + android:id="@+id/right" + style="@style/cursorButton" + android:tag="Right" + android:text="" + android:layout_centerVertical="true" + android:layout_toRightOf="@+id/up" + android:layout_toEndOf="@+id/up" /> + + + <de.androvdr.widget.SquareButton + android:id="@+id/left" + style="@style/cursorButton" + android:tag="Left" + android:text="" + android:layout_centerVertical="true" + android:layout_toLeftOf="@+id/ok" + android:layout_toStartOf="@+id/ok" /> + + <de.androvdr.widget.SquareButton + android:id="@+id/up" + style="@style/cursorButton" + android:layout_gravity="center_horizontal" + android:tag="Up" + android:text="" + android:layout_above="@+id/ok" + android:layout_centerHorizontal="true" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/ChannelUp" + style="@style/volChanButton" + + android:tag="Channel+" + android:text="" + android:layout_alignTop="@+id/up" + android:layout_alignParentRight="true" + android:layout_alignParentEnd="true" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/VolumeUp" + style="@style/volChanButton" + android:layout_height="wrap_content" + android:tag="Volume+" + android:text="" + android:layout_alignTop="@+id/up" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" /> + + <de.androvdr.widget.SquareButton + android:id="@+id/down" + style="@style/cursorButton" + + android:layout_gravity="center_horizontal" + + android:tag="Down" + android:text="" + android:layout_below="@+id/ok" + android:layout_toLeftOf="@+id/right" + android:layout_toStartOf="@+id/right" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/ChannelDown" + style="@style/volChanButton" + android:tag="Channel-" + android:text="" + android:layout_alignBottom="@+id/down" + android:layout_alignParentRight="true" + android:layout_alignParentEnd="true" /> + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/VolumeDown" + style="@style/volChanButton" + android:tag="Volume-" + android:text="" + android:layout_alignBottom="@+id/down" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" /> + + </RelativeLayout> + + + + <LinearLayout + android:id="@+id/colorButtons" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:orientation="horizontal" + android:layout_alignParentRight="true" + android:layout_alignParentEnd="true" + android:layout_below="@+id/rows0"> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/red" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Red" + android:text="" + android:textColor="@color/red" + /> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/green" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:text="" + android:tag="Green" + android:textColor="@color/green" + /> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/yellow" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Yellow" + android:text="" + android:textColor="@color/yellow" + /> + + + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/blue" + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Blue" + android:text="" + android:textColor="@color/blue" + /> + + + </LinearLayout> + + + <LinearLayout + android:id="@+id/rows1" + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:layout_alignParentLeft="true" + android:layout_alignParentStart="true" + android:orientation="horizontal" + android:layout_above="@+id/rows2"> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Mute" + android:text="" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Info" + android:text="" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Back" + android:text="" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Menu" + android:text="" /> + + </LinearLayout> + + + <LinearLayout + + android:layout_width="fill_parent" + android:layout_height="wrap_content" + android:id="@+id/rows2" + android:orientation="horizontal" + android:layout_marginTop="10dp" + android:layout_marginBottom="10dp" + android:layout_alignParentBottom="true"> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Audio" + android:text="" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Subtitles" + android:text="S" /> + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="PrevChannel" + android:text="" /> + + + <de.androvdr.widget.FontAwesomeButton + style="?android:attr/buttonStyleSmall" + android:layout_width="0dp" + + android:layout_height="wrap_content" + android:layout_weight="1" + android:tag="Commands" + android:text="" /> + </LinearLayout> + + +</RelativeLayout> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/edit_remote_key.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/edit_remote_key.xml index 2dfe156..ea20cc2 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/edit_remote_key.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/edit_remote_key.xml @@ -9,7 +9,7 @@ android:id="@+id/hitkLabel" android:layout_width="wrap_content" android:layout_height="wrap_content" - android:layout_weight="1" + android:clickable="true" android:text="@string/label" /> @@ -26,8 +26,19 @@ <de.androvdr.widget.FontAwesomeButton android:layout_width="wrap_content" android:layout_height="wrap_content" + android:id="@+id/faPicker" android:text="" /> + <de.androvdr.widget.FontAwesomeButton + android:id="@+id/hitkLabelColorPicker" + android:layout_width="wrap_content" + android:textColor="@color/yellow" + android:layout_height="wrap_content" + android:text="" /> + + + + </LinearLayout> <TextView @@ -40,26 +51,4 @@ android:id="@+id/hitkSpinner" android:layout_width="match_parent" android:layout_height="wrap_content" /> - - <LinearLayout - android:layout_width="match_parent" - android:layout_height="wrap_content" - android:orientation="horizontal" - android:visibility="gone"> - - <Button - android:id="@+id/button7" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:layout_gravity="right" - android:layout_weight="1" - android:text="@android:string/cancel" /> - - <Button - android:id="@+id/button6" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:layout_weight="1" - android:text="@android:string/ok" /> - </LinearLayout> </LinearLayout> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/fa_search.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/fa_search.xml new file mode 100644 index 0000000..8764059 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/fa_search.xml @@ -0,0 +1,21 @@ +<?xml version="1.0" encoding="UTF-8"?> +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" + android:layout_width="match_parent" + android:layout_height="match_parent" + android:orientation="vertical" + android:paddingLeft="8dp" + android:paddingRight="8dp" + android:paddingTop="8dp"> + + <SearchView + android:id="@+id/faSearch" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:iconifiedByDefault="false" /> + + <ListView + android:id="@+id/faItems" + android:layout_width="match_parent" + android:layout_height="wrap_content" /> + +</LinearLayout> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/remote.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/remote.xml index c75d83e..4604b07 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/remote.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/remote.xml @@ -8,45 +8,44 @@ android:padding="5dp"> - <LinearLayout android:id="@+id/resultwrapper" android:layout_width="fill_parent" + android:layout_height="wrap_content" android:layout_alignParentEnd="true" android:layout_alignParentRight="true" - android:layout_alignParentTop="true" - android:layout_height="wrap_content"> - <de.androvdr.widget.AnimatedTextView - android:id="@+id/result" - android:maxLines="1" - android:layout_width="0dp" - android:layout_weight="1" - android:layout_height="wrap_content" - android:textSize="10sp" - android:gravity="right" /> - </LinearLayout> + android:layout_alignParentTop="true"> + <de.androvdr.widget.AnimatedTextView + android:id="@+id/result" + android:layout_width="0dp" + android:layout_height="wrap_content" + android:layout_weight="1" + android:gravity="right" + android:maxLines="1" + android:textSize="10sp" /> + </LinearLayout> <LinearLayout android:id="@+id/rows0" android:layout_width="fill_parent" android:layout_height="wrap_content" - android:orientation="horizontal" android:layout_alignParentLeft="true" android:layout_alignParentStart="true" + android:layout_below="@+id/resultwrapper" android:layout_marginBottom="10dp" - android:layout_below="@+id/resultwrapper"> + android:orientation="horizontal"> <de.androvdr.widget.FontAwesomeButton - style="?android:attr/buttonStyleSmall" + android:id="@+id/Power" + style="?android:attr/buttonStyleSmall" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:tag="Power" - android:text="" - android:id="@+id/Power" /> + android:text="@string/fa_power_off" /> <de.androvdr.widget.FontAwesomeButton style="?android:attr/buttonStyleSmall" @@ -62,13 +61,7 @@ android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" - android:tag="" - /> - - - - - + android:tag="" /> <de.androvdr.widget.FontAwesomeButton @@ -85,10 +78,10 @@ android:layout_width="fill_parent" android:layout_height="wrap_content" - android:layout_alignParentRight="true" + android:layout_above="@+id/rows1" android:layout_alignParentEnd="true" - android:layout_below="@+id/colorButtons" - android:layout_above="@+id/rows1"> + android:layout_alignParentRight="true" + android:layout_below="@+id/colorButtons"> <de.androvdr.widget.SquareButton android:id="@+id/ok" @@ -104,93 +97,92 @@ <de.androvdr.widget.SquareButton android:id="@+id/right" style="@style/cursorButton" - android:tag="Right" - android:text="▶" android:layout_centerVertical="true" + android:layout_toEndOf="@+id/up" android:layout_toRightOf="@+id/up" - android:layout_toEndOf="@+id/up" /> + android:tag="Right" + android:text="" /> <de.androvdr.widget.SquareButton android:id="@+id/left" style="@style/cursorButton" - android:tag="Left" - android:text="◀" android:layout_centerVertical="true" android:layout_toLeftOf="@+id/ok" - android:layout_toStartOf="@+id/ok" /> + android:layout_toStartOf="@+id/ok" + android:tag="Left" + android:text="" /> <de.androvdr.widget.SquareButton android:id="@+id/up" style="@style/cursorButton" + android:layout_above="@+id/ok" + android:layout_centerHorizontal="true" android:layout_gravity="center_horizontal" android:tag="Up" - android:text="▲" - android:layout_above="@+id/ok" - android:layout_centerHorizontal="true" /> + android:text="" /> <de.androvdr.widget.FontAwesomeButton android:id="@+id/ChannelUp" style="@style/volChanButton" - android:tag="Channel+" - android:text="" - android:layout_alignTop="@+id/up" + android:layout_alignParentEnd="true" android:layout_alignParentRight="true" - android:layout_alignParentEnd="true" /> + android:layout_alignTop="@+id/up" + android:tag="Channel+" + android:text="" /> <de.androvdr.widget.FontAwesomeButton android:id="@+id/VolumeUp" style="@style/volChanButton" android:layout_height="wrap_content" - android:tag="Volume+" - android:text="" - android:layout_alignTop="@+id/up" android:layout_alignParentLeft="true" - android:layout_alignParentStart="true" /> + android:layout_alignParentStart="true" + android:layout_alignTop="@+id/up" + android:tag="Volume+" + android:text="" /> <de.androvdr.widget.SquareButton android:id="@+id/down" style="@style/cursorButton" - android:layout_gravity="center_horizontal" - - android:tag="Down" - android:text="▼" android:layout_below="@+id/ok" + + android:layout_gravity="center_horizontal" android:layout_toLeftOf="@+id/right" - android:layout_toStartOf="@+id/right" /> + android:layout_toStartOf="@+id/right" + android:tag="Down" + android:text="" /> <de.androvdr.widget.FontAwesomeButton android:id="@+id/ChannelDown" style="@style/volChanButton" - android:tag="Channel-" - android:text="" android:layout_alignBottom="@+id/down" + android:layout_alignParentEnd="true" android:layout_alignParentRight="true" - android:layout_alignParentEnd="true" /> + android:tag="Channel-" + android:text="" /> <de.androvdr.widget.FontAwesomeButton android:id="@+id/VolumeDown" style="@style/volChanButton" - android:tag="Volume-" - android:text="" android:layout_alignBottom="@+id/down" android:layout_alignParentLeft="true" - android:layout_alignParentStart="true" /> + android:layout_alignParentStart="true" + android:tag="Volume-" + android:text="" /> </RelativeLayout> - <LinearLayout android:id="@+id/colorButtons" android:layout_width="fill_parent" android:layout_height="wrap_content" - android:orientation="horizontal" - android:layout_alignParentRight="true" android:layout_alignParentEnd="true" - android:layout_below="@+id/rows0"> + android:layout_alignParentRight="true" + android:layout_below="@+id/rows0" + android:orientation="horizontal"> <de.androvdr.widget.FontAwesomeButton @@ -200,33 +192,30 @@ android:layout_height="wrap_content" android:layout_weight="1" android:tag="Red" - android:text="" - android:textColor="@color/red" - /> + android:text="@string/remotesquares" + android:textColor="@color/red" /> <de.androvdr.widget.FontAwesomeButton android:id="@+id/green" style="?android:attr/buttonStyleSmall" - android:layout_width="0dp" + android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" - android:text="" android:tag="Green" - android:textColor="@color/green" - /> + android:text="@string/remotesquares" + android:textColor="@color/green" /> <de.androvdr.widget.FontAwesomeButton android:id="@+id/yellow" style="?android:attr/buttonStyleSmall" - android:layout_width="0dp" + android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:tag="Yellow" - android:text="" - android:textColor="@color/yellow" - /> + android:text="@string/remotesquares" + android:textColor="@color/yellow" /> <de.androvdr.widget.FontAwesomeButton @@ -236,9 +225,8 @@ android:layout_height="wrap_content" android:layout_weight="1" android:tag="Blue" - android:text="" - android:textColor="@color/blue" - /> + android:text="@string/remotesquares" + android:textColor="@color/blue" /> </LinearLayout> @@ -248,10 +236,10 @@ android:id="@+id/rows1" android:layout_width="fill_parent" android:layout_height="wrap_content" + android:layout_above="@+id/rows2" android:layout_alignParentLeft="true" android:layout_alignParentStart="true" - android:orientation="horizontal" - android:layout_above="@+id/rows2"> + android:orientation="horizontal"> <de.androvdr.widget.FontAwesomeButton style="?android:attr/buttonStyleSmall" @@ -260,7 +248,7 @@ android:layout_height="wrap_content" android:layout_weight="1" android:tag="Mute" - android:text="" /> + android:text="@string/fa_mute" /> <de.androvdr.widget.FontAwesomeButton @@ -295,13 +283,13 @@ <LinearLayout + android:id="@+id/rows2" android:layout_width="fill_parent" android:layout_height="wrap_content" - android:id="@+id/rows2" - android:orientation="horizontal" - android:layout_marginTop="10dp" + android:layout_alignParentBottom="true" android:layout_marginBottom="10dp" - android:layout_alignParentBottom="true"> + android:layout_marginTop="10dp" + android:orientation="horizontal"> <de.androvdr.widget.FontAwesomeButton style="?android:attr/buttonStyleSmall" @@ -309,7 +297,7 @@ android:layout_height="wrap_content" android:layout_weight="1" android:tag="Audio" - android:text="" /> + android:text="@string/f025" /> <de.androvdr.widget.FontAwesomeButton @@ -318,7 +306,7 @@ android:layout_height="wrap_content" android:layout_weight="1" android:tag="Subtitles" - android:text="S" /> + android:text="@string/fa_bars" /> <de.androvdr.widget.FontAwesomeButton style="?android:attr/buttonStyleSmall" diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/searchspinner.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/searchspinner.xml new file mode 100644 index 0000000..c71b36f --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/searchspinner.xml @@ -0,0 +1,6 @@ +<?xml version="1.0" encoding="utf-8"?> +<com.toptoche.searchablespinnerlibrary.SearchableSpinner xmlns:android="http://schemas.android.com/apk/res/android" + android:id="@+id/spinner" + android:entries="@array/font" + android:layout_width="wrap_content" + android:layout_height="wrap_content" /> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/simple_list_item_1_fa.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/simple_list_item_1_fa.xml new file mode 100644 index 0000000..6a493e1 --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/layout/simple_list_item_1_fa.xml @@ -0,0 +1,27 @@ +<?xml version="1.0" encoding="utf-8"?> +<!-- Copyright (C) 2006 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. +--> + +<de.androvdr.widget.FontAwesomeTextView xmlns:android="http://schemas.android.com/apk/res/android" + android:id="@android:id/text1" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:textAppearance="?android:attr/textAppearanceListItemSmall" + android:gravity="center_vertical" + android:paddingStart="?android:attr/listPreferredItemPaddingStart" + android:paddingEnd="?android:attr/listPreferredItemPaddingEnd" + android:minHeight="?android:attr/listPreferredItemHeightSmall" + android:paddingLeft="?android:attr/listPreferredItemPaddingLeft" + android:paddingRight="?android:attr/listPreferredItemPaddingRight" /> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/arrays.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/arrays.xml index d53afcb..e43e39e 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/arrays.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/arrays.xml @@ -46,6 +46,7 @@ <item>has</item> <item>hls</item> </array> + <string-array name="vdr_ip46_mode_values"> <item>ip4</item> @@ -53,5 +54,794 @@ <item>ip46</item> <item>ip64</item> </string-array> + <string-array name="font"> + <item> 500px </item> + <item> address-book </item> + <item> address-book-o </item> + <item> address-card </item> + <item> address-card-o </item> + <item> adjust </item> + <item> adn </item> + <item> align-center </item> + <item> align-justify </item> + <item> align-left </item> + <item> align-right </item> + <item> amazon </item> + <item> ambulance </item> + <item> american-sign-language-interpreting </item> + <item> anchor </item> + <item> android </item> + <item> angellist </item> + <item> angle-double-down </item> + <item> angle-double-left </item> + <item> angle-double-right </item> + <item> angle-double-up </item> + <item> angle-down </item> + <item> angle-left </item> + <item> angle-right </item> + <item> angle-up </item> + <item> apple </item> + <item> archive </item> + <item> area-chart </item> + <item> arrow-circle-down </item> + <item> arrow-circle-left </item> + <item> arrow-circle-o-down </item> + <item> arrow-circle-o-left </item> + <item> arrow-circle-o-right </item> + <item> arrow-circle-o-up </item> + <item> arrow-circle-right </item> + <item> arrow-circle-up </item> + <item> arrow-down </item> + <item> arrow-left </item> + <item> arrow-right </item> + <item> arrow-up </item> + <item> arrows </item> + <item> arrows-alt </item> + <item> arrows-h </item> + <item> arrows-v </item> + <item> asl-interpreting </item> + <item> assistive-listening-systems </item> + <item> asterisk </item> + <item> at </item> + <item> audio-description </item> + <item> automobile </item> + <item> backward </item> + <item> balance-scale </item> + <item> ban </item> + <item> bandcamp </item> + <item> bank </item> + <item> bar-chart </item> + <item> bar-chart-o </item> + <item> barcode </item> + <item> bars </item> + <item> bath </item> + <item> bathtub </item> + <item> battery </item> + <item> battery-0 </item> + <item> battery-1 </item> + <item> battery-2 </item> + <item> battery-3 </item> + <item> battery-4 </item> + <item> battery-empty </item> + <item> battery-full </item> + <item> battery-half </item> + <item> battery-quarter </item> + <item> battery-three-quarters </item> + <item> bed </item> + <item> beer </item> + <item> behance </item> + <item> behance-square </item> + <item> bell </item> + <item> bell-o </item> + <item> bell-slash </item> + <item> bell-slash-o </item> + <item> bicycle </item> + <item> binoculars </item> + <item> birthday-cake </item> + <item> bitbucket </item> + <item> bitbucket-square </item> + <item> bitcoin </item> + <item> black-tie </item> + <item> blind </item> + <item> bluetooth </item> + <item> bluetooth-b </item> + <item> bold </item> + <item> bolt </item> + <item> bomb </item> + <item> book </item> + <item> bookmark </item> + <item> bookmark-o </item> + <item> braille </item> + <item> briefcase </item> + <item> btc </item> + <item> bug </item> + <item> building </item> + <item> building-o </item> + <item> bullhorn </item> + <item> bullseye </item> + <item> bus </item> + <item> buysellads </item> + <item> cab </item> + <item> calculator </item> + <item> calendar </item> + <item> calendar-check-o </item> + <item> calendar-minus-o </item> + <item> calendar-o </item> + <item> calendar-plus-o </item> + <item> calendar-times-o </item> + <item> camera </item> + <item> camera-retro </item> + <item> car </item> + <item> caret-down </item> + <item> caret-left </item> + <item> caret-right </item> + <item> caret-square-o-down </item> + <item> caret-square-o-left </item> + <item> caret-square-o-right </item> + <item> caret-square-o-up </item> + <item> caret-up </item> + <item> cart-arrow-down </item> + <item> cart-plus </item> + <item> cc </item> + <item> cc-amex </item> + <item> cc-diners-club </item> + <item> cc-discover </item> + <item> cc-jcb </item> + <item> cc-mastercard </item> + <item> cc-paypal </item> + <item> cc-stripe </item> + <item> cc-visa </item> + <item> certificate </item> + <item> chain </item> + <item> chain-broken </item> + <item> check </item> + <item> check-circle </item> + <item> check-circle-o </item> + <item> check-square </item> + <item> check-square-o </item> + <item> chevron-circle-down </item> + <item> chevron-circle-left </item> + <item> chevron-circle-right </item> + <item> chevron-circle-up </item> + <item> chevron-down </item> + <item> chevron-left </item> + <item> chevron-right </item> + <item> chevron-up </item> + <item> child </item> + <item> chrome </item> + <item> circle </item> + <item> circle-o </item> + <item> circle-o-notch </item> + <item> circle-thin </item> + <item> clipboard </item> + <item> clock-o </item> + <item> clone </item> + <item> close </item> + <item> cloud </item> + <item> cloud-download </item> + <item> cloud-upload </item> + <item> cny </item> + <item> code </item> + <item> code-fork </item> + <item> codepen </item> + <item> codiepie </item> + <item> coffee </item> + <item> cog </item> + <item> cogs </item> + <item> columns </item> + <item> comment </item> + <item> comment-o </item> + <item> commenting </item> + <item> commenting-o </item> + <item> comments </item> + <item> comments-o </item> + <item> compass </item> + <item> compress </item> + <item> connectdevelop </item> + <item> contao </item> + <item> copy </item> + <item> copyright </item> + <item> creative-commons </item> + <item> credit-card </item> + <item> credit-card-alt </item> + <item> crop </item> + <item> crosshairs </item> + <item> css3 </item> + <item> cube </item> + <item> cubes </item> + <item> cut </item> + <item> cutlery </item> + <item> dashboard </item> + <item> dashcube </item> + <item> database </item> + <item> deaf </item> + <item> deafness </item> + <item> dedent </item> + <item> delicious </item> + <item> desktop </item> + <item> deviantart </item> + <item> diamond </item> + <item> digg </item> + <item> dollar </item> + <item> dot-circle-o </item> + <item> download </item> + <item> dribbble </item> + <item> drivers-license </item> + <item> drivers-license-o </item> + <item> dropbox </item> + <item> drupal </item> + <item> edge </item> + <item> edit </item> + <item> eercast </item> + <item> eject </item> + <item> ellipsis-h </item> + <item> ellipsis-v </item> + <item> empire </item> + <item> envelope </item> + <item> envelope-o </item> + <item> envelope-open </item> + <item> envelope-open-o </item> + <item> envelope-square </item> + <item> envira </item> + <item> eraser </item> + <item> etsy </item> + <item> eur </item> + <item> euro </item> + <item> exchange </item> + <item> exclamation </item> + <item> exclamation-circle </item> + <item> exclamation-triangle </item> + <item> expand </item> + <item> expeditedssl </item> + <item> external-link </item> + <item> external-link-square </item> + <item> eye </item> + <item> eye-slash </item> + <item> eyedropper </item> + <item> fa </item> + <item> facebook </item> + <item> facebook-f </item> + <item> facebook-official </item> + <item> facebook-square </item> + <item> fast-backward </item> + <item> fast-forward </item> + <item> fax </item> + <item> feed </item> + <item> female </item> + <item> fighter-jet </item> + <item> file </item> + <item> file-archive-o </item> + <item> file-audio-o </item> + <item> file-code-o </item> + <item> file-excel-o </item> + <item> file-image-o </item> + <item> file-movie-o </item> + <item> file-o </item> + <item> file-pdf-o </item> + <item> file-photo-o </item> + <item> file-picture-o </item> + <item> file-powerpoint-o </item> + <item> file-sound-o </item> + <item> file-text </item> + <item> file-text-o </item> + <item> file-video-o </item> + <item> file-word-o </item> + <item> file-zip-o </item> + <item> files-o </item> + <item> film </item> + <item> filter </item> + <item> fire </item> + <item> fire-extinguisher </item> + <item> firefox </item> + <item> first-order </item> + <item> flag </item> + <item> flag-checkered </item> + <item> flag-o </item> + <item> flash </item> + <item> flask </item> + <item> flickr </item> + <item> floppy-o </item> + <item> folder </item> + <item> folder-o </item> + <item> folder-open </item> + <item> folder-open-o </item> + <item> font </item> + <item> font-awesome </item> + <item> fonticons </item> + <item> fort-awesome </item> + <item> forumbee </item> + <item> forward </item> + <item> foursquare </item> + <item> free-code-camp </item> + <item> frown-o </item> + <item> futbol-o </item> + <item> gamepad </item> + <item> gavel </item> + <item> gbp </item> + <item> ge </item> + <item> gear </item> + <item> gears </item> + <item> genderless </item> + <item> get-pocket </item> + <item> gg </item> + <item> gg-circle </item> + <item> gift </item> + <item> git </item> + <item> git-square </item> + <item> github </item> + <item> github-alt </item> + <item> github-square </item> + <item> gitlab </item> + <item> gittip </item> + <item> glass </item> + <item> glide </item> + <item> glide-g </item> + <item> globe </item> + <item> google </item> + <item> google-plus </item> + <item> google-plus-circle </item> + <item> google-plus-official </item> + <item> google-plus-square </item> + <item> google-wallet </item> + <item> graduation-cap </item> + <item> gratipay </item> + <item> grav </item> + <item> group </item> + <item> h-square </item> + <item> hacker-news </item> + <item> hand-grab-o </item> + <item> hand-lizard-o </item> + <item> hand-o-down </item> + <item> hand-o-left </item> + <item> hand-o-right </item> + <item> hand-o-up </item> + <item> hand-paper-o </item> + <item> hand-peace-o </item> + <item> hand-pointer-o </item> + <item> hand-rock-o </item> + <item> hand-scissors-o </item> + <item> hand-spock-o </item> + <item> hand-stop-o </item> + <item> handshake-o </item> + <item> hard-of-hearing </item> + <item> hashtag </item> + <item> hdd-o </item> + <item> header </item> + <item> headphones </item> + <item> heart </item> + <item> heart-o </item> + <item> heartbeat </item> + <item> history </item> + <item> home </item> + <item> hospital-o </item> + <item> hotel </item> + <item> hourglass </item> + <item> hourglass-1 </item> + <item> hourglass-2 </item> + <item> hourglass-3 </item> + <item> hourglass-end </item> + <item> hourglass-half </item> + <item> hourglass-o </item> + <item> hourglass-start </item> + <item> houzz </item> + <item> html5 </item> + <item> i-cursor </item> + <item> id-badge </item> + <item> id-card </item> + <item> id-card-o </item> + <item> ils </item> + <item> image </item> + <item> imdb </item> + <item> inbox </item> + <item> indent </item> + <item> industry </item> + <item> info </item> + <item> info-circle </item> + <item> inr </item> + <item> instagram </item> + <item> institution </item> + <item> internet-explorer </item> + <item> intersex </item> + <item> ioxhost </item> + <item> italic </item> + <item> joomla </item> + <item> jpy </item> + <item> jsfiddle </item> + <item> key </item> + <item> keyboard-o </item> + <item> krw </item> + <item> language </item> + <item> laptop </item> + <item> lastfm </item> + <item> lastfm-square </item> + <item> leaf </item> + <item> leanpub </item> + <item> legal </item> + <item> lemon-o </item> + <item> level-down </item> + <item> level-up </item> + <item> life-bouy </item> + <item> life-buoy </item> + <item> life-ring </item> + <item> life-saver </item> + <item> lightbulb-o </item> + <item> line-chart </item> + <item> link </item> + <item> linkedin </item> + <item> linkedin-square </item> + <item> linode </item> + <item> linux </item> + <item> list </item> + <item> list-alt </item> + <item> list-ol </item> + <item> list-ul </item> + <item> location-arrow </item> + <item> lock </item> + <item> long-arrow-down </item> + <item> long-arrow-left </item> + <item> long-arrow-right </item> + <item> long-arrow-up </item> + <item> low-vision </item> + <item> magic </item> + <item> magnet </item> + <item> mail-forward </item> + <item> mail-reply </item> + <item> mail-reply-all </item> + <item> male </item> + <item> map </item> + <item> map-marker </item> + <item> map-o </item> + <item> map-pin </item> + <item> map-signs </item> + <item> mars </item> + <item> mars-double </item> + <item> mars-stroke </item> + <item> mars-stroke-h </item> + <item> mars-stroke-v </item> + <item> maxcdn </item> + <item> meanpath </item> + <item> medium </item> + <item> medkit </item> + <item> meetup </item> + <item> meh-o </item> + <item> mercury </item> + <item> microchip </item> + <item> microphone </item> + <item> microphone-slash </item> + <item> minus </item> + <item> minus-circle </item> + <item> minus-square </item> + <item> minus-square-o </item> + <item> mixcloud </item> + <item> mobile </item> + <item> mobile-phone </item> + <item> modx </item> + <item> money </item> + <item> moon-o </item> + <item> mortar-board </item> + <item> motorcycle </item> + <item> mouse-pointer </item> + <item> music </item> + <item> navicon </item> + <item> neuter </item> + <item> newspaper-o </item> + <item> object-group </item> + <item> object-ungroup </item> + <item> odnoklassniki </item> + <item> odnoklassniki-square </item> + <item> opencart </item> + <item> openid </item> + <item> opera </item> + <item> optin-monster </item> + <item> outdent </item> + <item> pagelines </item> + <item> paint-brush </item> + <item> paper-plane </item> + <item> paper-plane-o </item> + <item> paperclip </item> + <item> paragraph </item> + <item> paste </item> + <item> pause </item> + <item> pause-circle </item> + <item> pause-circle-o </item> + <item> paw </item> + <item> paypal </item> + <item> pencil </item> + <item> pencil-square </item> + <item> pencil-square-o </item> + <item> percent </item> + <item> phone </item> + <item> phone-square </item> + <item> photo </item> + <item> picture-o </item> + <item> pie-chart </item> + <item> pied-piper </item> + <item> pied-piper-alt </item> + <item> pied-piper-pp </item> + <item> pinterest </item> + <item> pinterest-p </item> + <item> pinterest-square </item> + <item> plane </item> + <item> play </item> + <item> play-circle </item> + <item> play-circle-o </item> + <item> plug </item> + <item> plus </item> + <item> plus-circle </item> + <item> plus-square </item> + <item> plus-square-o </item> + <item> podcast </item> + <item> power-off </item> + <item> print </item> + <item> product-hunt </item> + <item> puzzle-piece </item> + <item> qq </item> + <item> qrcode </item> + <item> question </item> + <item> question-circle </item> + <item> question-circle-o </item> + <item> quora </item> + <item> quote-left </item> + <item> quote-right </item> + <item> ra </item> + <item> random </item> + <item> ravelry </item> + <item> rebel </item> + <item> recycle </item> + <item> reddit </item> + <item> reddit-alien </item> + <item> reddit-square </item> + <item> refresh </item> + <item> registered </item> + <item> remove </item> + <item> renren </item> + <item> reorder </item> + <item> repeat </item> + <item> reply </item> + <item> reply-all </item> + <item> resistance </item> + <item> retweet </item> + <item> rmb </item> + <item> road </item> + <item> rocket </item> + <item> rotate-left </item> + <item> rotate-right </item> + <item> rouble </item> + <item> rss </item> + <item> rss-square </item> + <item> rub </item> + <item> ruble </item> + <item> rupee </item> + <item> s15 </item> + <item> safari </item> + <item> save </item> + <item> scissors </item> + <item> scribd </item> + <item> search </item> + <item> search-minus </item> + <item> search-plus </item> + <item> sellsy </item> + <item> send </item> + <item> send-o </item> + <item> server </item> + <item> share </item> + <item> share-alt </item> + <item> share-alt-square </item> + <item> share-square </item> + <item> share-square-o </item> + <item> shekel </item> + <item> sheqel </item> + <item> shield </item> + <item> ship </item> + <item> shirtsinbulk </item> + <item> shopping-bag </item> + <item> shopping-basket </item> + <item> shopping-cart </item> + <item> shower </item> + <item> sign-in </item> + <item> sign-language </item> + <item> sign-out </item> + <item> signal </item> + <item> signing </item> + <item> simplybuilt </item> + <item> sitemap </item> + <item> skyatlas </item> + <item> skype </item> + <item> slack </item> + <item> sliders </item> + <item> slideshare </item> + <item> smile-o </item> + <item> snapchat </item> + <item> snapchat-ghost </item> + <item> snapchat-square </item> + <item> snowflake-o </item> + <item> soccer-ball-o </item> + <item> sort </item> + <item> sort-alpha-asc </item> + <item> sort-alpha-desc </item> + <item> sort-amount-asc </item> + <item> sort-amount-desc </item> + <item> sort-asc </item> + <item> sort-desc </item> + <item> sort-down </item> + <item> sort-numeric-asc </item> + <item> sort-numeric-desc </item> + <item> sort-up </item> + <item> soundcloud </item> + <item> space-shuttle </item> + <item> spinner </item> + <item> spoon </item> + <item> spotify </item> + <item> square </item> + <item> square-o </item> + <item> stack-exchange </item> + <item> stack-overflow </item> + <item> star </item> + <item> star-half </item> + <item> star-half-empty </item> + <item> star-half-full </item> + <item> star-half-o </item> + <item> star-o </item> + <item> steam </item> + <item> steam-square </item> + <item> step-backward </item> + <item> step-forward </item> + <item> stethoscope </item> + <item> sticky-note </item> + <item> sticky-note-o </item> + <item> stop </item> + <item> stop-circle </item> + <item> stop-circle-o </item> + <item> street-view </item> + <item> strikethrough </item> + <item> stumbleupon </item> + <item> stumbleupon-circle </item> + <item> subscript </item> + <item> subway </item> + <item> suitcase </item> + <item> sun-o </item> + <item> superpowers </item> + <item> superscript </item> + <item> support </item> + <item> table </item> + <item> tablet </item> + <item> tachometer </item> + <item> tag </item> + <item> tags </item> + <item> tasks </item> + <item> taxi </item> + <item> telegram </item> + <item> television </item> + <item> tencent-weibo </item> + <item> terminal </item> + <item> text-height </item> + <item> text-width </item> + <item> th </item> + <item> th-large </item> + <item> th-list </item> + <item> themeisle </item> + <item> thermometer </item> + <item> thermometer-0 </item> + <item> thermometer-1 </item> + <item> thermometer-2 </item> + <item> thermometer-3 </item> + <item> thermometer-4 </item> + <item> thermometer-empty </item> + <item> thermometer-full </item> + <item> thermometer-half </item> + <item> thermometer-quarter </item> + <item> thermometer-three-quarters </item> + <item> thumb-tack </item> + <item> thumbs-down </item> + <item> thumbs-o-down </item> + <item> thumbs-o-up </item> + <item> thumbs-up </item> + <item> ticket </item> + <item> times </item> + <item> times-circle </item> + <item> times-circle-o </item> + <item> times-rectangle </item> + <item> times-rectangle-o </item> + <item> tint </item> + <item> toggle-down </item> + <item> toggle-left </item> + <item> toggle-off </item> + <item> toggle-on </item> + <item> toggle-right </item> + <item> toggle-up </item> + <item> trademark </item> + <item> train </item> + <item> transgender </item> + <item> transgender-alt </item> + <item> trash </item> + <item> trash-o </item> + <item> tree </item> + <item> trello </item> + <item> tripadvisor </item> + <item> trophy </item> + <item> truck </item> + <item> try </item> + <item> tty </item> + <item> tumblr </item> + <item> tumblr-square </item> + <item> turkish-lira </item> + <item> tv </item> + <item> twitch </item> + <item> twitter </item> + <item> twitter-square </item> + <item> umbrella </item> + <item> underline </item> + <item> undo </item> + <item> universal-access </item> + <item> university </item> + <item> unlink </item> + <item> unlock </item> + <item> unlock-alt </item> + <item> unsorted </item> + <item> upload </item> + <item> usb </item> + <item> usd </item> + <item> user </item> + <item> user-circle </item> + <item> user-circle-o </item> + <item> user-md </item> + <item> user-o </item> + <item> user-plus </item> + <item> user-secret </item> + <item> user-times </item> + <item> users </item> + <item> vcard </item> + <item> vcard-o </item> + <item> venus </item> + <item> venus-double </item> + <item> venus-mars </item> + <item> viacoin </item> + <item> viadeo </item> + <item> viadeo-square </item> + <item> video-camera </item> + <item> vimeo </item> + <item> vimeo-square </item> + <item> vine </item> + <item> vk </item> + <item> volume-control-phone </item> + <item> volume-down </item> + <item> volume-off </item> + <item> volume-up </item> + <item> warning </item> + <item> wechat </item> + <item> weibo </item> + <item> weixin </item> + <item> whatsapp </item> + <item> wheelchair </item> + <item> wheelchair-alt </item> + <item> wifi </item> + <item> wikipedia-w </item> + <item> window-close </item> + <item> window-close-o </item> + <item> window-maximize </item> + <item> window-minimize </item> + <item> window-restore </item> + <item> windows </item> + <item> won </item> + <item> wordpress </item> + <item> wpbeginner </item> + <item> wpexplorer </item> + <item> wpforms </item> + <item> wrench </item> + <item> xing </item> + <item> xing-square </item> + <item> y-combinator </item> + <item> y-combinator-square </item> + <item> yahoo </item> + <item> yc </item> + <item> yc-square </item> + <item> yelp </item> + <item> yen </item> + <item> yoast </item> + <item> youtube </item> + <item> youtube-play </item> + <item> youtube-square </item> + </string-array> + -</resources>
\ No newline at end of file +</resources> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/colorpicker.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/colorpicker.xml new file mode 100644 index 0000000..3be024e --- /dev/null +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/colorpicker.xml @@ -0,0 +1,23 @@ +<?xml version="1.0" encoding="utf-8"?> +<!-- + Copyright (C) 2007 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. +--> + +<resources> + <string name="pref_summary_drawer_color">Set the color for the drawer background</string> + <string name="pref_dialog_title_color_picker">Pick a color.</string> + <string name="pref_dialog_color_picker_alpha">alpha</string> + <string name="pref_dialog_message_color_picker">Tap on center color to confirm.\nPress back to cancel.</string> +</resources>
\ No newline at end of file diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/dimens.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/dimens.xml index 1ee0176..16758e5 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/dimens.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/dimens.xml @@ -4,4 +4,6 @@ <dimen name="item_margin">0dp</dimen> <dimen name="item_inset">2dp</dimen> <dimen name="recycler_height">200dp</dimen> + <dimen name="color_picker_center">90dip</dimen> + <dimen name="color_picker_radius">30dip</dimen> </resources> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/font.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/font.xml deleted file mode 100644 index 554cc96..0000000 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/font.xml +++ /dev/null @@ -1,13 +0,0 @@ -<?xml version="1.0" encoding="utf-8" ?> - -<resources> - <string-array name="font"> - <item> 500px</item> - <item> address-book</item> - <item> address-book-o</item> - <item> address-card</item> - <item> address-card-o</item> - <item> adjust</item> - <item> adn</item> - </string-array> -</resources> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/strings.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/strings.xml index 3a21c46..0ff0cd0 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/strings.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/strings.xml @@ -571,4 +571,26 @@ <string name="permission_rationale">The app needs Storage permissions to import/export.</string> <string name="remote_keys_imported">Remote Keys imported: %1$s</string> <string name="remote_nothing_to_import" >No custom mapping…</string> + <string name="reset">Reset</string> + <string name="back">Back</string> + <string name="ok">OK</string> + <string name="f061"></string> + <string name="f060"></string> + <string name="f062"></string> + <string name="remotesquares"></string> + <string name="fa_mute"></string> + <string name="f129"></string> + <string name="f177"></string> + <string name="f0c9"></string> + <string name="f0e2"></string> + <string name="f120"></string> + <string name="f027"></string> + <string name="f0ab"></string> + <string name="f063"></string> + <string name="f028"></string> + <string name="f0aa"></string> + <string name="f085"></string> + <string name="fa_power_off"></string> + <string name="fa_bars"></string> + <string name="f025"></string> </resources> diff --git a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/styles.xml b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/styles.xml index 8ab89d1..f028cdc 100644 --- a/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/styles.xml +++ b/vdrmanager/de.bjusystems.vdrmanager/src/main/res/values/styles.xml @@ -84,7 +84,7 @@ <style name="AppTheme" parent="@style/Base.Theme.AppCompat" /> <style name="cursorButton"> - <item name="android:layout_width">70dp</item> + <item name="android:layout_width">50dp</item> <item name="android:layout_height">wrap_content</item> <item name="android:layout_margin">5dp</item> </style> |