Skip to main content

How to click or tap on a TextView text


I know this is so easy (doh...) but I am looking for a way to run a method on tapping or clicking a TextView line of text in an Android App.



I keep thinking about button listeners and anonymous method listener calls, but it just does not seem to apply to TextView.



Can someone point me at some code snippet to show how clicking or tapping on a piece of text in a TextView runs a method?


Source: Tips4allCCNA FINAL EXAM

Comments

  1. You can set the click handler in xml with these attribute:

    android:onClick="onClick"
    android:clickable="true"


    Don't forget the clickable attribute, without it, the click handler isn't called.

    main.xml

    ...

    <TextView
    android:id="@+id/click"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Click Me"
    android:textSize="55sp"
    android:onClick="onClick"
    android:clickable="true"/>
    ...


    MyActivity.java

    public class MyActivity extends Activity {

    public void onClick(View v) {
    ...
    }
    }

    ReplyDelete
  2. OK I have answered my own question (but is it the best way?)

    This is how to run a method when you click or tap on some text in a TextView:

    package com.textviewy;

    import android.app.Activity;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.TextView;

    public class TextyView extends Activity implements OnClickListener {

    TextView t ;
    @Override
    public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    t = (TextView)findViewById(R.id.TextView01);
    t.setOnClickListener(this);
    }

    public void onClick(View arg0) {
    t.setText("My text on click");
    }
    }


    and my main.xml is:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <LinearLayout android:id="@+id/LinearLayout01" android:layout_width="wrap_content" android:layout_height="wrap_content"></LinearLayout>
    <ListView android:id="@+id/ListView01" android:layout_width="wrap_content" android:layout_height="wrap_content"></ListView>
    <LinearLayout android:id="@+id/LinearLayout02" android:layout_width="wrap_content" android:layout_height="wrap_content"></LinearLayout>

    <TextView android:text="This is my first text"
    android:id="@+id/TextView01"
    android:layout_width="wrap_content"
    android:textStyle="bold"
    android:textSize="28dip"
    android:editable = "true"
    android:clickable="true"
    android:layout_height="wrap_content">
    </TextView>
    </LinearLayout>

    ReplyDelete
  3. This may not be quite what you are looking for but this is what worked for what I'm doing. All of this is after my onCreate.


    boilingpointK = (TextView) findViewById(R.id.boilingpointK);

    boilingpointK.setOnClickListener(new View.OnClickListener() {

    public void onClick(View v) {


    if ("Boiling Point K".equals(boilingpointK.getText().toString()))

    boilingpointK.setText("2792");


    else if ("2792".equals(boilingpointK.getText().toString()))

    boilingpointK.setText("Boiling Point K");
    } });

    ReplyDelete

Post a Comment

Popular posts from this blog

Why is this Javascript much *slower* than its jQuery equivalent?

I have a HTML list of about 500 items and a "filter" box above it. I started by using jQuery to filter the list when I typed a letter (timing code added later): $('#filter').keyup( function() { var jqStart = (new Date).getTime(); var search = $(this).val().toLowerCase(); var $list = $('ul.ablist > li'); $list.each( function() { if ( $(this).text().toLowerCase().indexOf(search) === -1 ) $(this).hide(); else $(this).show(); } ); console.log('Time: ' + ((new Date).getTime() - jqStart)); } ); However, there was a couple of seconds delay after typing each letter (particularly the first letter). So I thought it may be slightly quicker if I used plain Javascript (I read recently that jQuery's each function is particularly slow). Here's my JS equivalent: document.getElementById('filter').addEventListener( 'keyup', function () { var jsStart = (new Date).getTime()...