Android Studio V3.12环境下TV开发教程(十)添加引导步骤

Android Studio V3.12环境下TV开发教程

(转自Android官网https://developer.android.com/training/tv/start)

文章源自:光谷佳武 https://blog.csdn.net/jiawuhan/article/details/8062


添加引导步骤

您的应用程序可能为用户提供多步骤任务。 例如,您的应用可能需要引导用户购买额外的内容,或设置复杂的配置设置,或者只是确认一个决定。 所有这些任务都需要通过一个或多个有序的步骤或决定来步行用户。

v17 Leanback支持库提供了实现多步用户任务的类。 本课讨论如何使用GuidedStepFragment类来指导用户完成一系列任务。 GuidedStepFragment使用电视用户界面最佳做法,使多步骤任务易于理解并在电视设备上导航。

提供一个步骤的详细信息

GuidedStepFragment代表一系列步骤中的一个步骤。 在视觉上,它提供了左侧的步骤信息的指导视图。 在右侧, GuidedStepFragment提供了一个包含此步骤的可能操作或决定列表的视图。

图1.一个示例引导步骤。

对于多步骤任务中的每一步,请扩展GuidedStepFragment并提供有关用户可采取的步骤和操作的上下文信息。重写onCreateGuidance()并返回一个新的GuidanceStylist.Guidance ,其中包含上下文信息,如步骤标题,描述和图标。

 @覆盖
 publicGuidanceStylist.Guidance onCreateGuidance(Bundled savedInstanceState){
     String title = getString(R.string.guidedstep_first_title);
     String breadcrumb = getString(R.string.guidedstep_first_breadcrumb);
     String description = getString(R.string.guidedstep_first_description);
     Drawable icon = getActivity()。getDrawable(R.drawable.guidedstep_main_icon_1);
    返回新的GuidanceStylist.Guidance(标题,描述,面包屑,图标);
 }

通过在您的activity的onCreate()方法中调用GuidedStepFragment.add() ,将GuidedStepFragment子类添加到所需的活动中。 如果您的活动仅包含GuidedStepFragment对象,请使用GuidedStepFragment.addAsRoot()而不是add()添加第一个GuidedStepFragment  使用addAsRoot()可确保如果用户在查看第一个GuidedStepFragment时按下电视遥控器上的后退按钮,则GuidedStepFragment和父活动都将关闭。

注意: GuidedStepFragment编程方式添加GuidedStepFragment对象,而不是在布局XML文件中。

创建并处理用户操作

通过覆盖onCreateActions()添加用户操作。 在您的重写中,为每个操作项目添加一个新的GuidedAction ,并提供操作字符串,描述和标识。 使用GuidedAction.Builder添加新的操作。

 @覆盖
 public void onCreateActions(List <GuidedAction> actions,Bundle savedInstanceState){
     //为此步骤添加“继续”用户操作
     actions.add(new GuidedAction.Builder()
            .ID(续)
            .title伪(的getString(R.string.guidedstep_continue))
            .DESCRIPTION(的getString(R.string.guidedstep_letsdoit))
            .hasNext(真)
            。建立());
 ...

操作不限于单行选择。 以下是您可以创建的其他类型的操作:

  • 通过设置infoOnly(true)添加信息标签操作。 如果将infoOnly设置为true,则用户无法选择操作。 要提供有关用户选择的其他信息,请使用标签操作。
  • 通过设置editable(true)添加可编辑文本操作。 如果editable是真的,当选择操作时,用户可以使用遥控器或连接的键盘输入文本。 覆盖onGuidedActionEdited()onGuidedActionEditedAndProceed()以获取用户输入的修改后的文本。
  • 通过使用具有公共ID值的checkSetId()将操作分组为一组,可添加一组具有可检查单选按钮的操作。 具有相同检查集ID的同一列表中的所有操作都被视为链接。 当用户选择该组中的一个动作时,该动作将被检查,而所有其他动作变为未选中状态。
  • onCreateActions()使用GuidedDatePickerAction.Builder而不是GuidedAction.Builder添加日期选择器操作。 覆盖onGuidedActionEdited()onGuidedActionEditedAndProceed()以获取用户输入的修改日期值。
  • 添加一个动作,使用子动作让用户从扩展的选择列表中选择。 子动作Add子动作中描述。
  • 添加一个按钮动作,出现在动作列表的右侧,并且可以轻松访问。 按钮操作在添加按钮操作中进行了描述。

您还可以添加一个可视指示器来指示选择操作导致新的步骤 - 通过设置hasNext(true)  对于您可以设置的所有不同属性,请参阅GuidedAction 

要响应操作,请覆盖onGuidedActionClicked()并处理传入的GuidedAction  通过检查GuidedAction.getId()来识别选定的操作。

添加子动作

某些操作可能需要为用户提供一组额外的选择。 GuidedAction可以指定显示为子操作下拉列表的子操作列表。

图2.引导步骤子动作。

子动作列表可以包含常规动作或单选按钮动作,但不包含日期选择器或可编辑的文本动作。 此外,由于系统不支持多个级别的子动作,所以子动作不能拥有自己的一组子动作。 深层嵌套的操作会导致糟糕的用户体验。

要添加子动作,请首先创建并填充充当子动作的GuidedActions列表:

 List <GuidedAction> subActions = new ArrayList <GuidedAction>();
 subActions.add(new GuidedAction.Builder()
        .ID(SUBACTION1)
        .title伪(的getString(R.string.guidedstep_subaction1_title))
        .DESCRIPTION(的getString(R.string.guidedstep_subaction1_desc))
        。建立());
 ...

onCreateActions() ,创建一个顶级GuidedAction ,它将在选择时显示子动作列表:

 @覆盖
 public void onCreateActions(List <GuidedAction> actions,Bundle savedInstanceState){
 ...
     actions.add(new GuidedAction.Builder()
            .ID(子动作)
            .title伪(的getString(R.string.guidedstep_subactions_title))
            .DESCRIPTION(的getString(R.string.guidedstep_subactions_desc))
            .subActions(子动作)
            。建立());
 ...
 }

最后,通过重写onSubGuidedActionClicked()来响应子操作选择:

 @覆盖
 public boolean onSubGuidedActionClicked(GuidedAction action){
    //检查点击哪个动作,并根据需要进行处理
    if(action.getId()== SUBACTION1){
        //选择了Subaction 1
    }
    //返回true以折叠子活动下拉列表或
    // false保持下拉列表展开。
   返回true;
 }

添加按钮操作

如果您的指导步骤中有大量操作,用户可能需要滚动列表才能访问最常用的操作。 使用按钮操作将常用操作与操作列表分开。 按钮操作显示在操作列表的右侧并易于导航到。

图3.引导式步骤按钮操作。

按钮动作的创建和处理就像常规动作一样,但是您可以在onCreateButtonActions()而不是onCreateActions()创建按钮动作。 回应onGuidedActionClicked()按钮操作。

对简单操作使用按钮操作,例如步骤之间的导航操作。 不要将日期选取器操作或其他可编辑操作用作按钮操作。另外,按钮动作不能有子动作。

将引导步骤分组为引导序列

GuidedStepFragment代表一个单独的步骤,但是您可能会按照有序顺序执行几个步骤。 使用GuidedStepFragment.add()将多个GuidedStepFragment对象组合在一起,以将序列中的下一个步骤添加到片段堆栈中。

 @覆盖
 public void onGuidedActionClicked(GuidedAction action){
     FragmentManager fm = getFragmentManager();
     if(action.getId()== CONTINUE){
        GuidedStepFragment.add(fm,new SecondStepFragment());
     }
 ...

如果用户按下电视遥控器上的后退按钮,设备将在片段堆栈中显示前一个GuidedStepFragment  如果您决定提供返回上一步的GuidedAction ,则可以通过调用getFragmentManager().popBackStack()来实现Back行为。 如果您需要将用户返回到序列中更早的步骤,请使用popBackStackToGuidedStepFragment()返回片段堆栈中的特定GuidedStepFragment 

当用户完成序列中的最后一步时,使用finishGuidedStepFragments()从当前堆栈中删除所有GuidedStepFragments并返回到原始父活动。 如果使用addAsRoot()添加第一个GuidedStepFragment ,则调用finishGuidedStepFragments()将关闭父活动。

自定义步骤演示文稿

GuidedStepFragment类可以使用控制表示方面的自定义主题,例如标题文本格式或步骤转换动画。 自定义主题必须继承自Theme_Leanback_GuidedStep ,并且可以为GuidanceStylistGuidedActionsStylist定义的属性提供重写值。

要将自定义主题应用于GuidedStepFragment,请执行以下操作之一:

  • 通过将android:theme属性设置为Android清单中的activity元素,将主题应用于父活动。 设置此属性将主题应用于所有子视图,并且是父活动仅包含GuidedStepFragment对象时应用自定义主题的最简单方法。
  • 如果您的活动已使用自定义主题,并且您不想将GuidedStepFragment样式应用于活动中的其他视图,请将LeanbackGuidedStepTheme_guidedStepTheme属性添加到您现有的自定义活动主题中。 此属性指向只有活动中的GuidedStepFragment对象使用的自定义主题。
  • 如果在作为同一整体多步骤任务的不同活动中使用GuidedStepFragment对象并希望在所有步骤中使用一致的视觉主题,请覆盖GuidedStepFragment.onProvideTheme()并返回您的自定义主题。

有关如何添加样式和主题的更多信息,请参阅样式和主题 

GuidedStepFragment类使用特殊的设计师类来访问和应用主题属性。 GuidanceStylist类使用主题信息来控制左指导视图的呈现,而GuidedActionsStylist类使用主题信息来控制正确操作视图的呈现。

要定制超出自定义主题可以提供的步骤的视觉样式,请在GuidedStepFragment.onCreateGuidanceStylist()GuidedStepFragment.onCreateActionsStylist()GuidedStepFragment.onCreateGuidanceStylist() GuidanceStylistGuidedActionsStylist并返回您的子类。 有关您可以在这些子类中进行自定义的详细信息,请参阅GuidanceStylistGuidedActionsStylist的文档。




猜你喜欢

转载自blog.csdn.net/jiawuhan/article/details/80620644