[Android] Show the version number on the title for the Android TV UI
- Stop reading version number from native code and use the one from BuildConfig - Show the version number on the title for the Android TV UI
This commit is contained in:
parent
36a0c689d0
commit
9918d6e333
|
@ -0,0 +1,80 @@
|
||||||
|
package org.dolphinemu.dolphinemu.ui.main;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.support.v17.leanback.widget.TitleViewAdapter;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import org.dolphinemu.dolphinemu.R;
|
||||||
|
|
||||||
|
public class CustomTitleView extends LinearLayout implements TitleViewAdapter.Provider {
|
||||||
|
private final TextView mTitleView;
|
||||||
|
private final View mBadgeView;
|
||||||
|
|
||||||
|
private final TitleViewAdapter mTitleViewAdapter = new TitleViewAdapter() {
|
||||||
|
@Override
|
||||||
|
public View getSearchAffordanceView()
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setTitle(CharSequence titleText)
|
||||||
|
{
|
||||||
|
CustomTitleView.this.setTitle(titleText);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setBadgeDrawable(Drawable drawable)
|
||||||
|
{
|
||||||
|
CustomTitleView.this.setBadgeDrawable(drawable);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public CustomTitleView(Context context)
|
||||||
|
{
|
||||||
|
this(context, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CustomTitleView(Context context, AttributeSet attrs)
|
||||||
|
{
|
||||||
|
this(context, attrs, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
public CustomTitleView(Context context, AttributeSet attrs, int defStyle)
|
||||||
|
{
|
||||||
|
super(context, attrs, defStyle);
|
||||||
|
View root = LayoutInflater.from(context).inflate(R.layout.tv_title, this);
|
||||||
|
mTitleView = (TextView) root.findViewById(R.id.title);
|
||||||
|
mBadgeView = root.findViewById(R.id.badge);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTitle(CharSequence title)
|
||||||
|
{
|
||||||
|
if (title != null)
|
||||||
|
{
|
||||||
|
mTitleView.setText(title);
|
||||||
|
mTitleView.setVisibility(View.VISIBLE);
|
||||||
|
mBadgeView.setVisibility(View.VISIBLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setBadgeDrawable(Drawable drawable)
|
||||||
|
{
|
||||||
|
if (drawable != null)
|
||||||
|
{
|
||||||
|
mTitleView.setVisibility(View.GONE);
|
||||||
|
mBadgeView.setVisibility(View.VISIBLE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public TitleViewAdapter getTitleViewAdapter()
|
||||||
|
{
|
||||||
|
return mTitleViewAdapter;
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,9 +2,8 @@ package org.dolphinemu.dolphinemu.ui.main;
|
||||||
|
|
||||||
|
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
|
import org.dolphinemu.dolphinemu.BuildConfig;
|
||||||
import org.dolphinemu.dolphinemu.DolphinApplication;
|
import org.dolphinemu.dolphinemu.DolphinApplication;
|
||||||
import org.dolphinemu.dolphinemu.NativeLibrary;
|
|
||||||
import org.dolphinemu.dolphinemu.R;
|
import org.dolphinemu.dolphinemu.R;
|
||||||
import org.dolphinemu.dolphinemu.model.GameDatabase;
|
import org.dolphinemu.dolphinemu.model.GameDatabase;
|
||||||
import org.dolphinemu.dolphinemu.utils.SettingsFile;
|
import org.dolphinemu.dolphinemu.utils.SettingsFile;
|
||||||
|
@ -27,9 +26,7 @@ public final class MainPresenter
|
||||||
|
|
||||||
public void onCreate()
|
public void onCreate()
|
||||||
{
|
{
|
||||||
// TODO Rather than calling into native code, this should use the commented line below.
|
String versionName = BuildConfig.VERSION_NAME;
|
||||||
// String versionName = BuildConfig.VERSION_NAME;
|
|
||||||
String versionName = NativeLibrary.GetVersionString();
|
|
||||||
mView.setVersionString(versionName);
|
mView.setVersionString(versionName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@ import android.support.v17.leanback.widget.OnItemViewClickedListener;
|
||||||
import android.support.v17.leanback.widget.Presenter;
|
import android.support.v17.leanback.widget.Presenter;
|
||||||
import android.support.v17.leanback.widget.Row;
|
import android.support.v17.leanback.widget.Row;
|
||||||
import android.support.v17.leanback.widget.RowPresenter;
|
import android.support.v17.leanback.widget.RowPresenter;
|
||||||
|
import android.support.v4.content.ContextCompat;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import org.dolphinemu.dolphinemu.R;
|
import org.dolphinemu.dolphinemu.R;
|
||||||
|
@ -45,6 +46,16 @@ public final class TvMainActivity extends Activity implements MainView
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setContentView(R.layout.activity_tv_main);
|
setContentView(R.layout.activity_tv_main);
|
||||||
|
|
||||||
|
setupUI();
|
||||||
|
|
||||||
|
mPresenter.onCreate();
|
||||||
|
|
||||||
|
// Stuff in this block only happens when this activity is newly created (i.e. not a rotation)
|
||||||
|
if (savedInstanceState == null)
|
||||||
|
StartupHandler.HandleInit(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
void setupUI() {
|
||||||
final FragmentManager fragmentManager = getFragmentManager();
|
final FragmentManager fragmentManager = getFragmentManager();
|
||||||
mBrowseFragment = new BrowseFragment();
|
mBrowseFragment = new BrowseFragment();
|
||||||
fragmentManager
|
fragmentManager
|
||||||
|
@ -54,14 +65,9 @@ public final class TvMainActivity extends Activity implements MainView
|
||||||
|
|
||||||
// Set display parameters for the BrowseFragment
|
// Set display parameters for the BrowseFragment
|
||||||
mBrowseFragment.setHeadersState(BrowseFragment.HEADERS_ENABLED);
|
mBrowseFragment.setHeadersState(BrowseFragment.HEADERS_ENABLED);
|
||||||
mBrowseFragment.setTitle(getString(R.string.app_name));
|
mBrowseFragment.setBrandColor(ContextCompat.getColor(this, R.color.dolphin_blue_dark));
|
||||||
mBrowseFragment.setBadgeDrawable(getResources().getDrawable(
|
|
||||||
R.drawable.ic_launcher, null));
|
|
||||||
mBrowseFragment.setBrandColor(getResources().getColor(R.color.dolphin_blue_dark));
|
|
||||||
buildRowsAdapter();
|
buildRowsAdapter();
|
||||||
|
|
||||||
mPresenter.onCreate();
|
|
||||||
|
|
||||||
mBrowseFragment.setOnItemViewClickedListener(
|
mBrowseFragment.setOnItemViewClickedListener(
|
||||||
new OnItemViewClickedListener()
|
new OnItemViewClickedListener()
|
||||||
{
|
{
|
||||||
|
@ -88,12 +94,7 @@ public final class TvMainActivity extends Activity implements MainView
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Stuff in this block only happens when this activity is newly created (i.e. not a rotation)
|
|
||||||
if (savedInstanceState == null)
|
|
||||||
StartupHandler.HandleInit(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* MainView
|
* MainView
|
||||||
*/
|
*/
|
||||||
|
@ -101,7 +102,7 @@ public final class TvMainActivity extends Activity implements MainView
|
||||||
@Override
|
@Override
|
||||||
public void setVersionString(String version)
|
public void setVersionString(String version)
|
||||||
{
|
{
|
||||||
// No-op
|
mBrowseFragment.setTitle(version);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<org.dolphinemu.dolphinemu.ui.main.CustomTitleView
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:id="@+id/browse_title_group"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:padding="16dp"/>
|
|
@ -0,0 +1,31 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<android.support.v17.leanback.widget.TitleView
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<RelativeLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:visibility="gone"
|
||||||
|
android:layout_alignTop="@+id/badge"
|
||||||
|
android:layout_alignBottom="@+id/badge"
|
||||||
|
android:layout_alignParentRight="true"
|
||||||
|
android:id="@+id/title"
|
||||||
|
android:gravity="center_vertical"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textAppearance="?android:attr/textAppearanceSmall"/>
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:visibility="gone"
|
||||||
|
android:layout_toLeftOf="@id/title"
|
||||||
|
android:id="@+id/badge"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:src="@drawable/ic_launcher"/>
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
|
</android.support.v17.leanback.widget.TitleView>
|
|
@ -113,7 +113,7 @@
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<!-- Android TV Themes -->
|
<!-- Android TV Themes -->
|
||||||
<style name="DolphinTvBase" parent="Theme.Leanback">
|
<style name="DolphinTvBase" parent="Theme.Leanback.Browse">
|
||||||
<item name="colorPrimary">@color/dolphin_blue</item>
|
<item name="colorPrimary">@color/dolphin_blue</item>
|
||||||
<item name="colorPrimaryDark">@color/dolphin_blue_dark</item>
|
<item name="colorPrimaryDark">@color/dolphin_blue_dark</item>
|
||||||
|
|
||||||
|
@ -125,6 +125,7 @@
|
||||||
|
|
||||||
<style name="DolphinTvGamecube" parent="DolphinTvBase">
|
<style name="DolphinTvGamecube" parent="DolphinTvBase">
|
||||||
<item name="colorAccent">@color/dolphin_accent_gamecube</item>
|
<item name="colorAccent">@color/dolphin_accent_gamecube</item>
|
||||||
|
<item name="browseTitleViewLayout">@layout/titleview</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="InGameMenuOption" parent="Widget.AppCompat.Button.Borderless">
|
<style name="InGameMenuOption" parent="Widget.AppCompat.Button.Borderless">
|
||||||
|
|
Loading…
Reference in New Issue