3

我正在研究如何通过以下方式在我的应用程序中自定义数字:

  1. 主题:文档显示了如何更改表单的颜色主题,但没有显示如何(如果可能)更改视图布局或添加/删除视图元素。我可以更改 DigitsAuthButton 的文本吗?另一个非常重要的示例是更改 android 操作系统后退按钮的功能。
  2. 流程:我想自定义身份验证流程。例如,当我的服务器中的电话号码无效时,Android 用户将被定向到新屏幕(不一定是注册/创建帐户)。我还想实现自定义错误处理(即确认码不正确时的自定义对话等)

如果它是我想要做的正确工具,以及如果是,我将如何处理这些自定义,我希望任何有使用 Digits 经验的人提供反馈。

4

2 回答 2

2

您可以查看Cannonball 示例项目,它是开源的。要更改 DigitsAuthButton 的文本,您可以通过扩展 DigitsAuthButton 添加自定义的 Digits 按钮:

public class DigitsRegisterButton extends DigitsAuthButton {
    public DigitsRegisterButton(Context c) {
        super(c);
        init();
    }
    public DigitsRegisterButton(Context c, AttributeSet attrs) {
        super(c, attrs);
        init();
    }

    public DigitsRegisterButton(Context c, AttributeSet attrs, int defStyle) {
        super(c, attrs, defStyle);
        init();
    }

    private void init() {
        if (isInEditMode()) {
            return;
        }

        setBackgroundResource(R.drawable.digits_button_bg);

        // Modifying the text here..
        setText(getResources().getString(R.string.digits_register_text));

        setTextColor(getResources().getColor(R.color.theme_color));
    }
}

然后你可以在你的布局中使用和自定义它:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <com.pinchat.pinchat.view.DigitsRegisterButton
        android:id="@+id/signup_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/digits_button_bg"
        android:text="@string/digits_register_text"
        android:textColor="@color/theme_color"
        android:textSize="@dimen/digits_register_btn_text"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true"
        android:drawableStart="@drawable/ic_signin_phone"
        android:drawableLeft="@drawable/ic_signin_phone"/>
</RelativeLayout>

我还没有尝试过你的第二个查询。但由于代码是开源的,你可以看一下——GitHub上的Digits。这个存储库也有一个值得一看的示例。

于 2015-09-20T13:07:51.367 回答
1

自定义 DigitsAuthButton 按钮的最简单方法如下:

  1. 创建一个新的背景图像并将其命名为 dgts__digits_btn.png ==> 这将替换 digiAuth 按钮的 bg 图像。
  2. 通过在 dimens.xml 中添加 tw__login_btn_drawable_padding 属性来更改 DigitsAuthButton 按钮周围的填充
  3. 通过在 strings.xml 中添加名称为“dgts__login_digits_text”的字符串条目来更改默认 DigitsAuthButton 按钮文本
  4. 通过在 dimens.xml 中添加“tw__login_btn_text_size”来更改文本大小
  5. DigitsAuthButton 通过添加“tw__login_btn_right_padding”和dimens.xml 来填充按钮

希望这可以帮助。

于 2016-01-19T17:52:04.770 回答