Вы можете сделать это в коде, найдя и заменив URLSpan
экземпляры версиями без подчеркивания. После вызова Linkify.addLinks()
вызовите функцию, stripUnderlines()
вставленную ниже в каждый из ваших TextView
s:
private void stripUnderlines(TextView textView) {
Spannable s = new SpannableString(textView.getText());
URLSpan[] spans = s.getSpans(0, s.length(), URLSpan.class);
for (URLSpan span: spans) {
int start = s.getSpanStart(span);
int end = s.getSpanEnd(span);
s.removeSpan(span);
span = new URLSpanNoUnderline(span.getURL());
s.setSpan(span, start, end, 0);
}
textView.setText(s);
}
Для этого требуется настроенная версия URLSpan, которая не включает свойство «подчеркивание» TextPaint:
private class URLSpanNoUnderline extends URLSpan {
public URLSpanNoUnderline(String url) {
super(url);
}
@Override public void updateDrawState(TextPaint ds) {
super.updateDrawState(ds);
ds.setUnderlineText(false);
}
}
tel:2125551212
.new URLSpanNoUnderline
Вызов должен быть принят ,span.getURL()
чтобы сохранить эту информацию, в противном случае вы создаете плохие ссылки , которые вызывают исключения при нажатии. Я поместил это предлагаемое решение в очередь на редактирование вашего ответа, поскольку у меня самого нет прав на редактирование.Spannable s = (Spannable) textView.getText()
сSpannable s = new SpannableString(textView.getText());
не работает для меня. Если я вернусь к кастингу, он будет работать, только если у TextView естьandroid:textIsSelectable=true
. Есть идеи, почему?android:autoLink
атрибутом? В противном случае кажется, что вам нужно создать свои собственные методы onclick для встроенной функциональности.Учитывая textView и контент:
TextView textView = (TextView) findViewById(R.id.your_text_view_id); String content = "your <a href='http://some.url'>html</a> content";
Вот краткий способ убрать подчеркивание с гиперссылок:
Spannable s = (Spannable) Html.fromHtml(content); for (URLSpan u: s.getSpans(0, s.length(), URLSpan.class)) { s.setSpan(new UnderlineSpan() { public void updateDrawState(TextPaint tp) { tp.setUnderlineText(false); } }, s.getSpanStart(u), s.getSpanEnd(u), 0); } textView.setText(s);
Это основано на подходе, предложенном robUx4.
Для того, чтобы ссылки стали кликабельными, вам также необходимо позвонить:
textView.setMovementMethod(LinkMovementMethod.getInstance());
источник
String content = getResources().getString(R.string.content);
содержащая ссылку больше не работает.res/values/strings.xml
которой содержится то же самое, что и в примере. Можете ли вы проверить в конце концов?>
=>
,<
=<
и т. д. Например:<string name="link_to_google" ><a href="https://www.google.com/">Google</a></string>
см. developer.android.com/guide/topics/resources/string-resourceUnderlineSpan
уже существует, но можно установить только подчеркивание.Другое решение - добавить на каждый существующий интервал без подчеркивания
URLSpan
. Таким образом, состояние подчеркивания отключается непосредственно перед рисованием. Таким образом вы сохраните своиURLSpan
(возможно, пользовательские) классы и все другие стили, установленные в другом месте.public class NoUnderlineSpan extends UnderlineSpan { public NoUnderlineSpan() {} public NoUnderlineSpan(Parcel src) {} @Override public void updateDrawState(TextPaint ds) { ds.setUnderlineText(false); } }
Вот как вы установите его, не удаляя существующий объект URLSpan:
URLSpan[] spans = s.getSpans(0, s.length(), URLSpan.class); for (URLSpan span: spans) { int start = s.getSpanStart(span); int end = s.getSpanEnd(span); NoUnderlineSpan noUnderline = new NoUnderlineSpan(); s.setSpan(noUnderline, start, end, 0); }
источник
Я реализовал решение, которое, на мой взгляд, более элегантно. Я сделал обычай
TextView
. Таким образом, вам не нужно выполнять дополнительный код для каждогоTextView
с гиперссылками.package com.example.view; import android.content.Context; import android.support.v7.widget.AppCompatTextView; import android.text.Spannable; import android.text.SpannableString; import android.text.style.URLSpan; import android.util.AttributeSet; import com.example.utils.UrlSpanNoUnderline; public class TextViewNoUnderline extends AppCompatTextView { public TextViewNoUnderline(Context context) { this(context, null); } public TextViewNoUnderline(Context context, AttributeSet attrs) { this(context, attrs, android.R.attr.textViewStyle); } public TextViewNoUnderline(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); setSpannableFactory(Factory.getInstance()); } private static class Factory extends Spannable.Factory { private final static Factory sInstance = new Factory(); public static Factory getInstance() { return sInstance; } @Override public Spannable newSpannable(CharSequence source) { return new SpannableNoUnderline(source); } } private static class SpannableNoUnderline extends SpannableString { public SpannableNoUnderline(CharSequence source) { super(source); } @Override public void setSpan(Object what, int start, int end, int flags) { if (what instanceof URLSpan) { what = new UrlSpanNoUnderline((URLSpan) what); } super.setSpan(what, start, end, flags); } } }
И код для UrlSpanNoUnderline:
package com.jankstudios.smmagazine.utils; import android.text.TextPaint; import android.text.style.URLSpan; public class UrlSpanNoUnderline extends URLSpan { public UrlSpanNoUnderline(URLSpan src) { super(src.getURL()); } @Override public void updateDrawState(TextPaint ds) { super.updateDrawState(ds); ds.setUnderlineText(false); } }
источник
Вот функция расширения Kotlin :
fun TextView.removeLinksUnderline() { val spannable = SpannableString(text) for (u in spannable.getSpans(0, spannable.length, URLSpan::class.java)) { spannable.setSpan(object : URLSpan(u.url) { override fun updateDrawState(ds: TextPaint) { super.updateDrawState(ds) ds.isUnderlineText = false } }, spannable.getSpanStart(u), spannable.getSpanEnd(u), 0) } text = spannable }
Применение:
txtView.removeLinksUnderline()
источник
Всякий раз, когда пытайтесь удалить подчеркивание URL-адреса с помощью spannable, я предлагаю только следующие вещи:
1> Создание собственного класса:
private class URLSpanNoUnderline extends URLSpan { public URLSpanNoUnderline(String url) { super(url); } @Override public void updateDrawState(TextPaint ds) { super.updateDrawState(ds); ds.setUnderlineText(false); } }
Для этого требуется настроенная версия URLSpan которая не включает свойство «подчеркивание» TextPaint.
2> setSpan с расширяемым текстом:
spannableText.setSpan(new URLSpanNoUnderline(UrlText), 0, UrlText.length() , 0);
Здесь spannableText - это объект SpannableString ... !!!
источник
Если вы используете свойство Autolink Textview и хотите удалить подчеркивание, вы можете использовать его:
Сначала расширьте UnderlineSpan и удалите подчеркивание:
public class NoUnderlineSpan extends UnderlineSpan { @Override public void updateDrawState(TextPaint ds) { ds.setUnderlineText(false); } }
Во-вторых, создайте экземпляр NoUnderlineSpan, создайте Spannable из текста String и установите для диапазона spannable:
NoUnderlineSpan mNoUnderlineSpan = new NoUnderline(); if (yourTextView.getText() instanceof Spannable) { Spannable s = (Spannable) yourTextView.getText(); s.setSpan(mNoUnderlineSpan, 0, s.length(), Spanned.SPAN_MARK_MARK); }
Ссылка: http://prog3.com/sbdm/blog/maosidiaoxian/article/details/39156563
источник
Если вам просто нужен текст и вас не беспокоит URL-ссылка
Это STRIP ссылки , но СОХРАНИТЬ текст
private Spannable stripLinks(String content) { Spannable s = new SpannableString(content); URLSpan[] spans = s.getSpans(0, s.length(), URLSpan.class); for (URLSpan span : spans) { s.removeSpan(span); } return s; }
дополнительных занятий не требуется
String content = "<a href='http://stackoverflow.com'>Stack Overflow</a> Rocks!"; textView.setText(stripLinks(content));
источник
Вот мой метод
public static void removeUnderlines(Spannable p_Text) { if (p_Text != null && p_Text.toString().length() > 0) { URLSpan[] spans = p_Text.getSpans(0, p_Text.length(), URLSpan.class); for (URLSpan span : spans) { int start = p_Text.getSpanStart(span); int end = p_Text.getSpanEnd(span); p_Text.removeSpan(span); span = new URLSpanNoUnderline(span.getURL()); p_Text.setSpan(span, start, end, 0); } } }
Назовите это так
AppController.removeUnderlines((Spannable) eventEmail.getText());
Appcontroller - это мой класс приложения, в котором я поместил этот метод, чтобы получить к нему доступ из любого места
источник
Для пользователей Xamarin, нашедших этот пост, вот как я заставил его работать:
class URLSpanNoUnderline : URLSpan { public URLSpanNoUnderline (string url) : base (url) { } public override void UpdateDrawState (TextPaint ds) { base.UpdateDrawState (ds); ds.UnderlineText = false; } }
public static void StripUnderlinesFromLinks (this TextView textView) { var spannable = new SpannableStringBuilder (textView.TextFormatted); var spans = spannable.GetSpans (0, spannable.Length (), Java.Lang.Class.FromType (typeof (URLSpan))); foreach (URLSpan span in spans) { var start = spannable.GetSpanStart (span); var end = spannable.GetSpanEnd (span); spannable.RemoveSpan(span); var newSpan = new URLSpanNoUnderline (span.URL); spannable.SetSpan(newSpan, start, end, 0); } textView.TextFormatted = spannable; }
источник
public void setView() { TextView t=(TextView) findViewById(R.id.textView3); t.setText(Html.fromHtml("<a href=http://www.urdusms.net > UrduSMS ")); t.setTextColor(Color.BLACK); t.setGravity(Gravity.CENTER); t.setMovementMethod(LinkMovementMethod.getInstance()); Spannable s = (Spannable) t.getText(); URLSpan[] spans = s.getSpans(0, s.length(), URLSpan.class); for (URLSpan span: spans) { int start = s.getSpanStart(span); int end = s.getSpanEnd(span); s.removeSpan(span); span = new URLSpanline_none(span.getURL()); s.setSpan(span, start, end, 0); } t.setText(s); } //inner class is private class URLSpanline_none extends URLSpan { public URLSpanline_none(String url) { super(url); } @Override public void updateDrawState(TextPaint ds) { super.updateDrawState(ds); ds.setUnderlineText(false); } }
источник