1*90c8c64dSAndroid Build Coastguard Worker /* 2*90c8c64dSAndroid Build Coastguard Worker * Copyright 2013 The Android Open Source Project 3*90c8c64dSAndroid Build Coastguard Worker * 4*90c8c64dSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*90c8c64dSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*90c8c64dSAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*90c8c64dSAndroid Build Coastguard Worker * 8*90c8c64dSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*90c8c64dSAndroid Build Coastguard Worker * 10*90c8c64dSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*90c8c64dSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*90c8c64dSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*90c8c64dSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*90c8c64dSAndroid Build Coastguard Worker * limitations under the License. 15*90c8c64dSAndroid Build Coastguard Worker */ 16*90c8c64dSAndroid Build Coastguard Worker 17*90c8c64dSAndroid Build Coastguard Worker package com.example.android.textlinkify; 18*90c8c64dSAndroid Build Coastguard Worker 19*90c8c64dSAndroid Build Coastguard Worker import android.app.Activity; 20*90c8c64dSAndroid Build Coastguard Worker import android.graphics.Typeface; 21*90c8c64dSAndroid Build Coastguard Worker import android.os.Bundle; 22*90c8c64dSAndroid Build Coastguard Worker import android.text.Html; 23*90c8c64dSAndroid Build Coastguard Worker import android.text.SpannableString; 24*90c8c64dSAndroid Build Coastguard Worker import android.text.Spanned; 25*90c8c64dSAndroid Build Coastguard Worker import android.text.method.LinkMovementMethod; 26*90c8c64dSAndroid Build Coastguard Worker import android.text.style.StyleSpan; 27*90c8c64dSAndroid Build Coastguard Worker import android.text.style.URLSpan; 28*90c8c64dSAndroid Build Coastguard Worker import android.widget.TextView; 29*90c8c64dSAndroid Build Coastguard Worker 30*90c8c64dSAndroid Build Coastguard Worker /** 31*90c8c64dSAndroid Build Coastguard Worker * This sample demonstrates how clickable links can be added to a 32*90c8c64dSAndroid Build Coastguard Worker * {@link android.widget.TextView}. 33*90c8c64dSAndroid Build Coastguard Worker * 34*90c8c64dSAndroid Build Coastguard Worker * <p>This can be done in three ways: 35*90c8c64dSAndroid Build Coastguard Worker * <ul> 36*90c8c64dSAndroid Build Coastguard Worker * <li><b>Automatically:</b> Text added to a TextView can automatically be linkified by enabling 37*90c8c64dSAndroid Build Coastguard Worker * autoLinking. In XML, use the android:autoLink property, programatically call 38*90c8c64dSAndroid Build Coastguard Worker * {@link android.widget.TextView#setAutoLinkMask(int)} using an option from 39*90c8c64dSAndroid Build Coastguard Worker * {@link android.text.util.Linkify}</li> 40*90c8c64dSAndroid Build Coastguard Worker * 41*90c8c64dSAndroid Build Coastguard Worker * <li><b>Parsing a String as HTML:</b> See {@link android.text.Html#fromHtml(String)})</li> 42*90c8c64dSAndroid Build Coastguard Worker * 43*90c8c64dSAndroid Build Coastguard Worker * <li><b>Manually by constructing a {@link android.text.SpannableString}:</b> Consisting of 44*90c8c64dSAndroid Build Coastguard Worker * {@link android.text.style.StyleSpan} and {@link android.text.style.URLSpan} objects that 45*90c8c64dSAndroid Build Coastguard Worker * are contained within a {@link android.text.SpannableString}</li> 46*90c8c64dSAndroid Build Coastguard Worker * </ul></p> 47*90c8c64dSAndroid Build Coastguard Worker * 48*90c8c64dSAndroid Build Coastguard Worker */ 49*90c8c64dSAndroid Build Coastguard Worker public class MainActivity extends Activity { 50*90c8c64dSAndroid Build Coastguard Worker 51*90c8c64dSAndroid Build Coastguard Worker @Override onCreate(Bundle savedInstanceState)52*90c8c64dSAndroid Build Coastguard Worker protected void onCreate(Bundle savedInstanceState) { 53*90c8c64dSAndroid Build Coastguard Worker super.onCreate(savedInstanceState); 54*90c8c64dSAndroid Build Coastguard Worker 55*90c8c64dSAndroid Build Coastguard Worker setContentView(R.layout.sample_main); 56*90c8c64dSAndroid Build Coastguard Worker 57*90c8c64dSAndroid Build Coastguard Worker // BEGIN_INCLUDE(text_auto_linkify) 58*90c8c64dSAndroid Build Coastguard Worker /* 59*90c8c64dSAndroid Build Coastguard Worker * text_auto_linkify shows the android:autoLink property, which 60*90c8c64dSAndroid Build Coastguard Worker * automatically linkifies things like URLs and phone numbers 61*90c8c64dSAndroid Build Coastguard Worker * found in the text. No java code is needed to make this 62*90c8c64dSAndroid Build Coastguard Worker * work. 63*90c8c64dSAndroid Build Coastguard Worker * This can also be enabled programmatically by calling 64*90c8c64dSAndroid Build Coastguard Worker * .setAutoLinkMask(Linkify.ALL) before the text is set on the TextView. 65*90c8c64dSAndroid Build Coastguard Worker * 66*90c8c64dSAndroid Build Coastguard Worker * See android.text.util.Linkify for other options, for example only 67*90c8c64dSAndroid Build Coastguard Worker * auto-linking email addresses or phone numbers 68*90c8c64dSAndroid Build Coastguard Worker */ 69*90c8c64dSAndroid Build Coastguard Worker // END_INCLUDE(text_auto_linkify) 70*90c8c64dSAndroid Build Coastguard Worker 71*90c8c64dSAndroid Build Coastguard Worker // BEGIN_INCLUDE(text_html_resource) 72*90c8c64dSAndroid Build Coastguard Worker /* 73*90c8c64dSAndroid Build Coastguard Worker * text_html_resource has links specified by putting anchor tags (<a>) in the string 74*90c8c64dSAndroid Build Coastguard Worker * resource. By default these links will appear but not 75*90c8c64dSAndroid Build Coastguard Worker * respond to user input. To make them active, you need to 76*90c8c64dSAndroid Build Coastguard Worker * call setMovementMethod() on the TextView object. 77*90c8c64dSAndroid Build Coastguard Worker */ 78*90c8c64dSAndroid Build Coastguard Worker TextView textViewResource = (TextView) findViewById(R.id.text_html_resource); 79*90c8c64dSAndroid Build Coastguard Worker textViewResource.setText( 80*90c8c64dSAndroid Build Coastguard Worker Html.fromHtml(getResources().getString(R.string.link_text_manual))); 81*90c8c64dSAndroid Build Coastguard Worker textViewResource.setMovementMethod(LinkMovementMethod.getInstance()); 82*90c8c64dSAndroid Build Coastguard Worker // END_INCLUDE(text_html_resource) 83*90c8c64dSAndroid Build Coastguard Worker 84*90c8c64dSAndroid Build Coastguard Worker // BEGIN_INCLUDE(text_html_program) 85*90c8c64dSAndroid Build Coastguard Worker /* 86*90c8c64dSAndroid Build Coastguard Worker * text_html_program shows creating text with links from HTML in the Java 87*90c8c64dSAndroid Build Coastguard Worker * code, rather than from a string resource. Note that for a 88*90c8c64dSAndroid Build Coastguard Worker * fixed string, using a (localizable) resource as shown above 89*90c8c64dSAndroid Build Coastguard Worker * is usually a better way to go; this example is intended to 90*90c8c64dSAndroid Build Coastguard Worker * illustrate how you might display text that came from a 91*90c8c64dSAndroid Build Coastguard Worker * dynamic source (eg, the network). 92*90c8c64dSAndroid Build Coastguard Worker */ 93*90c8c64dSAndroid Build Coastguard Worker TextView textViewHtml = (TextView) findViewById(R.id.text_html_program); 94*90c8c64dSAndroid Build Coastguard Worker textViewHtml.setText( 95*90c8c64dSAndroid Build Coastguard Worker Html.fromHtml( 96*90c8c64dSAndroid Build Coastguard Worker "<b>text_html_program: Constructed from HTML programmatically.</b>" 97*90c8c64dSAndroid Build Coastguard Worker + " Text with a <a href=\"http://www.google.com\">link</a> " 98*90c8c64dSAndroid Build Coastguard Worker + "created in the Java source code using HTML.")); 99*90c8c64dSAndroid Build Coastguard Worker textViewHtml.setMovementMethod(LinkMovementMethod.getInstance()); 100*90c8c64dSAndroid Build Coastguard Worker // END_INCLUDE(text_html_program) 101*90c8c64dSAndroid Build Coastguard Worker 102*90c8c64dSAndroid Build Coastguard Worker // BEGIN_INCLUDE(text_spannable) 103*90c8c64dSAndroid Build Coastguard Worker /* 104*90c8c64dSAndroid Build Coastguard Worker * text_spannable illustrates constructing a styled string containing a 105*90c8c64dSAndroid Build Coastguard Worker * link without using HTML at all. Again, for a fixed string 106*90c8c64dSAndroid Build Coastguard Worker * you should probably be using a string resource, not a 107*90c8c64dSAndroid Build Coastguard Worker * hardcoded value. 108*90c8c64dSAndroid Build Coastguard Worker */ 109*90c8c64dSAndroid Build Coastguard Worker SpannableString ss = new SpannableString( 110*90c8c64dSAndroid Build Coastguard Worker "text_spannable: Manually created spans. Click here to dial the phone."); 111*90c8c64dSAndroid Build Coastguard Worker 112*90c8c64dSAndroid Build Coastguard Worker /* 113*90c8c64dSAndroid Build Coastguard Worker * Make the first 38 characters bold by applying a StyleSpan with bold typeface. 114*90c8c64dSAndroid Build Coastguard Worker * 115*90c8c64dSAndroid Build Coastguard Worker * Characters 45 to 49 (the word "here") is made clickable by applying a URLSpan 116*90c8c64dSAndroid Build Coastguard Worker * pointing to a telephone number. Clicking it opens the "tel:" URL that starts the dialer. 117*90c8c64dSAndroid Build Coastguard Worker * 118*90c8c64dSAndroid Build Coastguard Worker * The SPAN_EXCLUSIVE_EXCLUSIVE flag defines this span as exclusive, which means 119*90c8c64dSAndroid Build Coastguard Worker * that it will not expand to include text inserted on either side of this span. 120*90c8c64dSAndroid Build Coastguard Worker */ 121*90c8c64dSAndroid Build Coastguard Worker ss.setSpan(new StyleSpan(Typeface.BOLD), 0, 39, 122*90c8c64dSAndroid Build Coastguard Worker Spanned.SPAN_INCLUSIVE_INCLUSIVE); 123*90c8c64dSAndroid Build Coastguard Worker ss.setSpan(new URLSpan("tel:4155551212"), 40 + 6, 40 + 10, 124*90c8c64dSAndroid Build Coastguard Worker Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); 125*90c8c64dSAndroid Build Coastguard Worker 126*90c8c64dSAndroid Build Coastguard Worker TextView textViewSpan = (TextView) findViewById(R.id.text_spannable); 127*90c8c64dSAndroid Build Coastguard Worker textViewSpan.setText(ss); 128*90c8c64dSAndroid Build Coastguard Worker 129*90c8c64dSAndroid Build Coastguard Worker /* 130*90c8c64dSAndroid Build Coastguard Worker * Set the movement method to move between links in this TextView. 131*90c8c64dSAndroid Build Coastguard Worker * This means that the user traverses through links in this TextView, automatically 132*90c8c64dSAndroid Build Coastguard Worker * handling appropriate scrolling and key commands. 133*90c8c64dSAndroid Build Coastguard Worker */ 134*90c8c64dSAndroid Build Coastguard Worker textViewSpan.setMovementMethod(LinkMovementMethod.getInstance()); 135*90c8c64dSAndroid Build Coastguard Worker // END_INCLUDE(text_spannable) 136*90c8c64dSAndroid Build Coastguard Worker } 137*90c8c64dSAndroid Build Coastguard Worker 138*90c8c64dSAndroid Build Coastguard Worker } 139