在TextView控件中单击链接弹出Activity

    private void initFreeRegisterText() {
        String strHtml = getResources().getText(R.string.register_up_sms_free_text).toString();
        mFreeRegisterText.setText(Html.fromHtml(strHtml));
        mFreeRegisterText.setMovementMethod(LinkMovementMethod.getInstance());
        CharSequence text = mFreeRegisterText.getText();
        if (text instanceof Spannable) {
            int end = text.length();
            Spannable spannable = (Spannable) mFreeRegisterText.getText();
            URLSpan[] urlSpans = spannable.getSpans(0, end, URLSpan.class);
            SpannableStringBuilder styleBuilder = new SpannableStringBuilder(text);
            styleBuilder.clearSpans();
            for (URLSpan urlSpan : urlSpans) {
                MyClickableSpan myClickableSpan = new MyClickableSpan(urlSpan.getURL());
                styleBuilder.setSpan(myClickableSpan, spannable.getSpanStart(urlSpan), spannable.getSpanEnd(urlSpan), Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
            }
            mFreeRegisterText.setText(styleBuilder);
        }
    }

    private static class MyClickableSpan extends ClickableSpan {
        String mUrl;

        public MyClickableSpan(String url) {
            mUrl = url;
        }

        @Override
        public void updateDrawState(TextPaint ds) {
            ds.setColor(Color.argb(255, 79, 140, 11)); // 设置链接文字颜色
            ds.setUnderlineText(false); //去掉下划线
        }

        @Override
        public void onClick(View widget) {
            AddAccountsBase.showAccountsView(Constant.VALUE_ADD_ACCOUNT_DOWN_SMS_REGISTER);
        }
    }
private final ClickableSpan mLocalClickableSpan = new ClickableSpan() {
    @Override
    public void updateDrawState(TextPaint ds) {
        ds.setColor(Color.argb(255, 79, 140, 11)); // 设置链接文字颜色
        ds.setUnderlineText(false); // 去掉下划线
    }
    @Override
    public void onClick(View widget) {
        AddAccountsBase.showAccountsView(Constant.VALUE_ADD_ACCOUNT_DOWN_SMS_REGISTER);
    }
};
private void initFreeRegText() {
    String strHtml = getResources().getText(R.string.register_up_sms_free_text).toString();
    mFreeRegText.setText(Html.fromHtml(strHtml));
    mFreeRegText.setMovementMethod(LinkMovementMethod.getInstance());
    CharSequence text = mFreeRegText.getText();
    if (text instanceof Spannable) {
        int end = text.length();
        Spannable spannable = (Spannable) mFreeRegText.getText();
        URLSpan[] urlSpans = spannable.getSpans(0, end, URLSpan.class);
        SpannableStringBuilder styleBuilder = new SpannableStringBuilder(text);
        styleBuilder.clearSpans();
        for (URLSpan urlSpan : urlSpans) {
            styleBuilder.setSpan(mLocalClickableSpan, spannable.getSpanStart(urlSpan), spannable.getSpanEnd(urlSpan), Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
        }
        mFreeRegText.setText(styleBuilder);
    }
}
<string name="register_up_sms_free_text">您还可以使用&lt;a  href=\"dowm_sms_reg\"&gt;短信验证注册&lt;/a&gt;。</string><string name="register_up_sms_free_text">您还可以使用<a  href=\"dowm_sms_reg\">短信验证注册</a>。</string>

TextView textview = (TextView) inflate.findViewById(R.id.textView1);
CharSequence charSequence = textview.getText();
SpannableStringBuilder spannableStringBuilder = new SpannableStringBuilder(charSequence);
class ClickCharacterStyle extends CharacterStyle implements UpdateAppearance {
	@Override
	public void updateDrawState(TextPaint tp) {
		tp.setColor(tp.linkColor);
		tp.setUnderlineText(true);
	}
}
spannableStringBuilder.setSpan(new ClickCharacterStyle(), 0, charSequence.length(), SpannableString.SPAN_EXCLUSIVE_EXCLUSIVE);
textview.setText(spannableStringBuilder);


另:在TextView中设置超链接、背景、字体颜色

TextView textview = (TextView) findViewById(R.id.thrid);
SpannableString sp = new SpannableString("这句话中有百度超链接,有高亮显示,这样,或者这样,还有斜体.");
// 设置超链接
sp.setSpan(new URLSpan("http://www.baidu.com"), 5, 7, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
// 设置背景色
sp.setSpan(new BackgroundColorSpan(Color.RED), 17 ,19,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
// 设置字体颜色
sp.setSpan(new ForegroundColorSpan(Color.YELLOW),20,24,Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
// 设置斜体
sp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD_ITALIC), 27, 29, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
textview.setText(sp);//SpannableString对象设置给TextView
textview.setMovementMethod(LinkMovementMethod.getInstance()); //设置TextView可点击

       其中sp是SpannableString对象,该对象即可以修改文本内容,又可以将某段文本设置成一个Span,在Android中,Span表示一段文本的效果,例如,链接形式、图像、带背景色的文本等。

      上面代码中使用setSpan方法将某个区间的文本设置成URLSpan效果,也就是链接显示效果。其中URLSpan表示将文本设置成链接效果,该类是ClickableSpan的子类,在android.text.style包中可以找到URLSpan和ClickableSpan类。实际上,所有的Span类都在android.text.style包中。

sp.setSpan(new ClickableSpan() {
    @Override
    public void onClick(View widget)
    {
        Intent intent = new Intent(Btn1Activity.this, Btn1SecondActivity.class);
        startActivity(intent);
    }
}, 0, 4, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

setSpan方法,该方法有4个参数。第一个参数需要设置一个ClicableSpan对象,第二个和第三个参数分别表示文本中要设置成Span的某段文本的起始位置和终止位置的下一个字符的位置,也就是start和end。最后一个参数是一个标志。在本例中设为Spanned.SPAN_EXCLUSIVE_EXCLUSIVE,该标志在TextView控件中意义不大,但在EditText控件中表示在当前Span效果的前后输入字符时并不应用Span的效果。还可以设置如下几个类似的值。
1.  Spanned.SPAN_EXCLUSIVE_INCLUSIVE:在Span前面输入的字符不应用Span的效果,在后面输入的字符应用Span效果。
2.  Spanned.SPAN_INCLUSIVE_EXCLUSIVE:在Span前面输入的字符应用Span的效果,在后面输入的字符不应用Span效果。
3.  Spanned.SPAN_INCLUSIVE_INCLUSIVE:在Span前后输入的字符都应用Span的效果。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,让我们来实现这个功能。首先,我们需要在主Activity的布局文件添加一个按钮和一个TextView,代码如下: ```xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="16dp"> <Button android:id="@+id/login_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="登录" android:layout_centerInParent="true"/> <TextView android:id="@+id/info_textview" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@id/login_button" android:layout_centerHorizontal="true" android:layout_marginTop="24dp" android:text="请登录"/> </RelativeLayout> ``` 接下来,我们需要在主Activity处理按钮的点击事件,打开子Activity,并等待子Activity返回结果。在子Activity,用户输入的用户名和密码将会被返回给主Activity,并在那里进行验证。如果验证成功,则更新TextView的文本内容;如果验证失败,则显示一个消息对话框。 主Activity的代码如下: ```java public class MainActivity extends AppCompatActivity { private static final int REQUEST_LOGIN = 1; private TextView mInfoTextView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mInfoTextView = findViewById(R.id.info_textview); Button loginButton = findViewById(R.id.login_button); loginButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { Intent intent = new Intent(MainActivity.this, LoginActivity.class); startActivityForResult(intent, REQUEST_LOGIN); } }); } @Override protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == REQUEST_LOGIN && resultCode == RESULT_OK && data != null) { String username = data.getStringExtra(LoginActivity.EXTRA_USERNAME); String password = data.getStringExtra(LoginActivity.EXTRA_PASSWORD); if ("admin".equals(username) && "123456".equals(password)) { mInfoTextView.setText(username + "已登录"); } else { new AlertDialog.Builder(MainActivity.this) .setTitle("登录失败") .setMessage("用户名或密码错误") .setPositiveButton("确定", null) .show(); } } } } ``` 在这个代码,我们使用了一个常量 REQUEST_LOGIN 来标识打开子Activity的请求。在按钮的点击事件,我们使用 startActivityForResult() 方法来打开子Activity,并等待其返回结果。在 onActivityResult() 方法,我们检查请求码和结果码是否匹配,以及是否有数据返回。如果有,则获取返回的用户名和密码,并进行验证。如果验证成功,则更新TextView的文本内容;如果验证失败,则显示一个消息对话框。 现在,让我们来编写子Activity的代码。它的布局文件包含了两个EditText和一个Button,用于输入用户名、密码和提交登录信息。在点击Button时,我们将用户名和密码封装成一个Intent,并使用 setResult() 方法返回给主Activity。如果用户在这个界面上按下了Back键,则不会返回任何数据。 子Activity的代码如下: ```java public class LoginActivity extends AppCompatActivity { public static final String EXTRA_USERNAME = "extra_username"; public static final String EXTRA_PASSWORD = "extra_password"; private EditText mUsernameEditText; private EditText mPasswordEditText; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_login); mUsernameEditText = findViewById(R.id.username_edittext); mPasswordEditText = findViewById(R.id.password_edittext); Button loginButton = findViewById(R.id.login_button); loginButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { String username = mUsernameEditText.getText().toString(); String password = mPasswordEditText.getText().toString(); Intent data = new Intent(); data.putExtra(EXTRA_USERNAME, username); data.putExtra(EXTRA_PASSWORD, password); setResult(RESULT_OK, data); finish(); } }); } @Override public void onBackPressed() { setResult(RESULT_CANCELED); super.onBackPressed(); } } ``` 在这个代码,我们定义了两个常量 EXTRA_USERNAME 和 EXTRA_PASSWORD,用于传递用户名和密码。在 onCreate() 方法,我们获取了两个EditText的引用,并设置了登录按钮的点击事件。在点击事件,我们获取了用户名和密码,将它们封装成一个Intent,并使用 setResult() 方法返回给主Activity。在 onBackPressed() 方法,我们设置了返回结果为 RESULT_CANCELED,以避免用户按下Back键时返回任何数据。 至此,我们已经完成了主Activity和子Activity之间的数据传递和验证。当用户在子Activity输入正确的用户名和密码时,主ActivityTextView将会显示“admin已登录”。否则,将会弹出一个消息对话框,显示“用户名或密码错误”。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值