summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--samples/Support4Demos/res/layout/drawer_layout.xml3
-rw-r--r--samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java99
-rw-r--r--samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java99
3 files changed, 170 insertions, 31 deletions
diff --git a/samples/Support4Demos/res/layout/drawer_layout.xml b/samples/Support4Demos/res/layout/drawer_layout.xml
index 375c8027a..496bd88d5 100644
--- a/samples/Support4Demos/res/layout/drawer_layout.xml
+++ b/samples/Support4Demos/res/layout/drawer_layout.xml
@@ -24,7 +24,8 @@
android:layout_width="match_parent"
android:layout_height="match_parent">
<!-- As the main content view, the view below consumes the entire
- space available using match_parent in both dimensions. -->
+ space available using match_parent in both dimensions. Note that
+ this child does not specify android:layout_gravity attribute. -->
<ScrollView
android:layout_width="match_parent"
android:layout_height="match_parent"
diff --git a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java
index 63149b444..fdec4d88c 100644
--- a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java
+++ b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepActivity.java
@@ -27,6 +27,7 @@ import android.support.v17.leanback.app.GuidedStepFragment;
import android.support.v17.leanback.widget.GuidedAction;
import android.support.v17.leanback.widget.GuidanceStylist;
import android.support.v17.leanback.widget.GuidanceStylist.Guidance;
+import android.text.InputType;
import android.text.TextUtils;
import android.util.Log;
import android.view.ViewGroup;
@@ -44,7 +45,8 @@ public class GuidedStepActivity extends Activity {
private static final int FIRST_NAME = 3;
private static final int LAST_NAME = 4;
- private static final int PAYMENT = 5;
+ private static final int PASSWORD = 5;
+ private static final int PAYMENT = 6;
private static final int OPTION_CHECK_SET_ID = 10;
private static final int DEFAULT_OPTION = 0;
@@ -109,6 +111,31 @@ public class GuidedStepActivity extends Activity {
.build());
}
+ private static void addEditableAction(List<GuidedAction> actions, long id, String title,
+ String editTitle, int editInputType, String desc, String editDesc) {
+ actions.add(new GuidedAction.Builder()
+ .id(id)
+ .title(title)
+ .editTitle(editTitle)
+ .editInputType(editInputType)
+ .description(desc)
+ .editDescription(editDesc)
+ .editable(true)
+ .build());
+ }
+
+ private static void addEditableDescriptionAction(List<GuidedAction> actions, long id,
+ String title, String desc, String editDescription, int descriptionEditInputType) {
+ actions.add(new GuidedAction.Builder()
+ .id(id)
+ .title(title)
+ .description(desc)
+ .editDescription(editDescription)
+ .descriptionEditInputType(descriptionEditInputType)
+ .descriptionEditable(true)
+ .build());
+ }
+
private static void addCheckedAction(List<GuidedAction> actions, int iconResId, Context context,
String title, String desc) {
actions.add(new GuidedAction.Builder()
@@ -146,7 +173,7 @@ public class GuidedStepActivity extends Activity {
if (action.getId() == CONTINUE) {
GuidedStepFragment.add(fm, new SecondStepFragment(), android.R.id.content);
} else {
- getActivity().finish();
+ finishGuidedStepFragments();
}
}
@@ -171,8 +198,12 @@ public class GuidedStepActivity extends Activity {
public void onCreateActions(List<GuidedAction> actions, Bundle savedInstanceState) {
addEditableAction(actions, FIRST_NAME, "Pat", "Your first name");
addEditableAction(actions, LAST_NAME, "Smith", "Your last name");
- addEditableAction(actions, PAYMENT, "Payment", "", "Input credit card number");
+ addEditableAction(actions, PAYMENT, "Payment", "", InputType.TYPE_CLASS_NUMBER,
+ "Input credit card number", "Input credit card number");
+ addEditableDescriptionAction(actions, PASSWORD, "Password", "", "",
+ InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD);
addAction(actions, CONTINUE, "Continue", "Continue");
+ actions.get(actions.size() - 1).setEnabled(false);
}
@Override
@@ -184,16 +215,52 @@ public class GuidedStepActivity extends Activity {
}
@Override
- public void onGuidedActionEdited(GuidedAction action) {
- CharSequence editTitle = action.getEditTitle();
- if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) {
- editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length());
- action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle);
- } else if (editTitle.length() == 0){
- action.setDescription("Input credit card number");
- } else {
- action.setDescription("Error credit card number");
+ public long onGuidedActionEditedAndProceed(GuidedAction action) {
+ if (action.getId() == PAYMENT) {
+ CharSequence editTitle = action.getEditTitle();
+ if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) {
+ editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length());
+ action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle);
+ updateContinue(isPasswordValid());
+ return GuidedAction.ACTION_ID_NEXT;
+ } else if (editTitle.length() == 0){
+ action.setDescription("Input credit card number");
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ } else {
+ action.setDescription("Error credit card number");
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ }
+ } else if (action.getId() == PASSWORD) {
+ CharSequence password = action.getEditDescription();
+ if (password.length() > 0) {
+ if (isPaymentValid()) {
+ updateContinue(true);
+ return GuidedAction.ACTION_ID_NEXT;
+ } else {
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ }
+ } else {
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ }
}
+ return GuidedAction.ACTION_ID_NEXT;
+ }
+
+ boolean isPaymentValid() {
+ return findActionById(PAYMENT).getDescription().subSequence(0, 4).toString().equals("Visa");
+ }
+
+ boolean isPasswordValid() {
+ return findActionById(PASSWORD).getEditDescription().length() > 0;
+ }
+
+ void updateContinue(boolean enabled) {
+ findActionById(CONTINUE).setEnabled(enabled);
+ notifyActionChanged(findActionPositionById(CONTINUE));
}
}
@@ -281,15 +348,17 @@ public class GuidedStepActivity extends Activity {
@Override
public void onCreateActions(List<GuidedAction> actions, Bundle savedInstanceState) {
addAction(actions, CONTINUE, "Done", "All finished");
- addAction(actions, BACK, "Back", "Forgot something...");
+ addAction(actions, BACK, "Start Over", "Let's try this again...");
}
@Override
public void onGuidedActionClicked(GuidedAction action) {
if (action.getId() == CONTINUE) {
- getActivity().finish();
+ finishGuidedStepFragments();
} else {
- getFragmentManager().popBackStack();
+ // pop 4, 3, 2
+ popBackStackToGuidedStepFragment(SecondStepFragment.class,
+ FragmentManager.POP_BACK_STACK_INCLUSIVE);
}
}
diff --git a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java
index 432c6c0f0..5ac34dd37 100644
--- a/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java
+++ b/samples/SupportLeanbackDemos/src/com/example/android/leanback/GuidedStepSupportActivity.java
@@ -29,6 +29,7 @@ import android.support.v17.leanback.app.GuidedStepSupportFragment;
import android.support.v17.leanback.widget.GuidedAction;
import android.support.v17.leanback.widget.GuidanceStylist;
import android.support.v17.leanback.widget.GuidanceStylist.Guidance;
+import android.text.InputType;
import android.text.TextUtils;
import android.util.Log;
import android.view.ViewGroup;
@@ -46,7 +47,8 @@ public class GuidedStepSupportActivity extends FragmentActivity {
private static final int FIRST_NAME = 3;
private static final int LAST_NAME = 4;
- private static final int PAYMENT = 5;
+ private static final int PASSWORD = 5;
+ private static final int PAYMENT = 6;
private static final int OPTION_CHECK_SET_ID = 10;
private static final int DEFAULT_OPTION = 0;
@@ -111,6 +113,31 @@ public class GuidedStepSupportActivity extends FragmentActivity {
.build());
}
+ private static void addEditableAction(List<GuidedAction> actions, long id, String title,
+ String editTitle, int editInputType, String desc, String editDesc) {
+ actions.add(new GuidedAction.Builder()
+ .id(id)
+ .title(title)
+ .editTitle(editTitle)
+ .editInputType(editInputType)
+ .description(desc)
+ .editDescription(editDesc)
+ .editable(true)
+ .build());
+ }
+
+ private static void addEditableDescriptionAction(List<GuidedAction> actions, long id,
+ String title, String desc, String editDescription, int descriptionEditInputType) {
+ actions.add(new GuidedAction.Builder()
+ .id(id)
+ .title(title)
+ .description(desc)
+ .editDescription(editDescription)
+ .descriptionEditInputType(descriptionEditInputType)
+ .descriptionEditable(true)
+ .build());
+ }
+
private static void addCheckedAction(List<GuidedAction> actions, int iconResId, Context context,
String title, String desc) {
actions.add(new GuidedAction.Builder()
@@ -148,7 +175,7 @@ public class GuidedStepSupportActivity extends FragmentActivity {
if (action.getId() == CONTINUE) {
GuidedStepSupportFragment.add(fm, new SecondStepFragment(), android.R.id.content);
} else {
- getActivity().finish();
+ finishGuidedStepSupportFragments();
}
}
@@ -173,8 +200,12 @@ public class GuidedStepSupportActivity extends FragmentActivity {
public void onCreateActions(List<GuidedAction> actions, Bundle savedInstanceState) {
addEditableAction(actions, FIRST_NAME, "Pat", "Your first name");
addEditableAction(actions, LAST_NAME, "Smith", "Your last name");
- addEditableAction(actions, PAYMENT, "Payment", "", "Input credit card number");
+ addEditableAction(actions, PAYMENT, "Payment", "", InputType.TYPE_CLASS_NUMBER,
+ "Input credit card number", "Input credit card number");
+ addEditableDescriptionAction(actions, PASSWORD, "Password", "", "",
+ InputType.TYPE_CLASS_TEXT | InputType.TYPE_TEXT_VARIATION_PASSWORD);
addAction(actions, CONTINUE, "Continue", "Continue");
+ actions.get(actions.size() - 1).setEnabled(false);
}
@Override
@@ -186,16 +217,52 @@ public class GuidedStepSupportActivity extends FragmentActivity {
}
@Override
- public void onGuidedActionEdited(GuidedAction action) {
- CharSequence editTitle = action.getEditTitle();
- if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) {
- editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length());
- action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle);
- } else if (editTitle.length() == 0){
- action.setDescription("Input credit card number");
- } else {
- action.setDescription("Error credit card number");
+ public long onGuidedActionEditedAndProceed(GuidedAction action) {
+ if (action.getId() == PAYMENT) {
+ CharSequence editTitle = action.getEditTitle();
+ if (TextUtils.isDigitsOnly(editTitle) && editTitle.length() == 16) {
+ editTitle = editTitle.subSequence(editTitle.length() - 4, editTitle.length());
+ action.setDescription("Visa XXXX-XXXX-XXXX-"+editTitle);
+ updateContinue(isPasswordValid());
+ return GuidedAction.ACTION_ID_NEXT;
+ } else if (editTitle.length() == 0){
+ action.setDescription("Input credit card number");
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ } else {
+ action.setDescription("Error credit card number");
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ }
+ } else if (action.getId() == PASSWORD) {
+ CharSequence password = action.getEditDescription();
+ if (password.length() > 0) {
+ if (isPaymentValid()) {
+ updateContinue(true);
+ return GuidedAction.ACTION_ID_NEXT;
+ } else {
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ }
+ } else {
+ updateContinue(false);
+ return GuidedAction.ACTION_ID_CURRENT;
+ }
}
+ return GuidedAction.ACTION_ID_NEXT;
+ }
+
+ boolean isPaymentValid() {
+ return findActionById(PAYMENT).getDescription().subSequence(0, 4).toString().equals("Visa");
+ }
+
+ boolean isPasswordValid() {
+ return findActionById(PASSWORD).getEditDescription().length() > 0;
+ }
+
+ void updateContinue(boolean enabled) {
+ findActionById(CONTINUE).setEnabled(enabled);
+ notifyActionChanged(findActionPositionById(CONTINUE));
}
}
@@ -283,15 +350,17 @@ public class GuidedStepSupportActivity extends FragmentActivity {
@Override
public void onCreateActions(List<GuidedAction> actions, Bundle savedInstanceState) {
addAction(actions, CONTINUE, "Done", "All finished");
- addAction(actions, BACK, "Back", "Forgot something...");
+ addAction(actions, BACK, "Start Over", "Let's try this again...");
}
@Override
public void onGuidedActionClicked(GuidedAction action) {
if (action.getId() == CONTINUE) {
- getActivity().finish();
+ finishGuidedStepSupportFragments();
} else {
- getFragmentManager().popBackStack();
+ // pop 4, 3, 2
+ popBackStackToGuidedStepSupportFragment(SecondStepFragment.class,
+ FragmentManager.POP_BACK_STACK_INCLUSIVE);
}
}