Измените TextView на кликабельные слова в пользовательском ListView
У меня есть обычай List
в котором разные кнопки присутствуют в каждом списке. моя цель - сделать единое текстовое представление
<TextView
android:id="@+id/text"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:textColor="#000000"
android:text="Example"
android:textSize="16dp"
android:layout_below="@+id/rl1" />
быть измененным в соответствии с предложением, чтобы каждое слово было кликабельным с
К этому
И Слово, которое будет передано в Функцию.
Я думаю, что если мы сможем разделить один TextView на несколько TextView и сделать их кликабельными, возможно ли это решение без XML?
Любой фрагмент будет благодарен
С уважением
3 ответа
Ваш вопрос требует глубокого использования SpannableString, Androider уже предоставил хороший совет для решения вашей проблемы, но вы сказали, что вы получаете слова динамически из базы данных, поэтому здесь я написал для вас код, который будет обрабатывать динамический контент. Я не проверял это, надеюсь, это должно работать для вас.
MainActivity.java:
public class MainActivity extends AppCompatActivity {
ListView lv ;
public static String [] prgmNameList={"Android Dev","SpearHead Inc"}; // You can put dynamic strings in this array .
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv=(ListView) findViewById(R.id.listView);
lv.setAdapter(new CustomAdapter(this, prgmNameList));
}
}
CustomAdapter:
public class CustomAdapter extends BaseAdapter {
String [] result;
Context context;
private static LayoutInflater inflater=null;
public CustomAdapter(MainActivity activity, String[] prgmNameList) {
result = prgmNameList;
context = activity;
inflater = ( LayoutInflater )context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
@Override
public int getCount() {
return result.length;
}
@Override
public Object getItem(int position) {
return position;
}
@Override
public long getItemId(int position) {
return position;
}
public class Holder
{
TextView tv;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
Holder holder=new Holder();
View rowView = inflater.inflate(R.layout.list_item, null);
holder.tv=(TextView) rowView.findViewById(R.id.textView1);
//holder.tv.setText(result[position]);
String span[] = result[position].split(" ") ;
SpannableString ss = new SpannableString(result[position]);
ClickableSpan spans[] = new ClickableSpan[span.length];
for(int spanCount = 0 ; spanCount < span.length ; spanCount++){
spans[spanCount] = new ClickableSpan() {
@Override
public void onClick(View textView) {
TextView v = (TextView)textView ;
String text = v.getText().toString() ;
Log.d("View" , text);
}
};
}
int start = 0 ;
int end ;
try {
for(int spanCount = 0 ; spanCount < span.length ; spanCount++){
end = span[spanCount].length()-1 ;
ss.setSpan(spans[spanCount], start, end , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
start = span[spanCount].length()+1;
end = span[spanCount].length() + 2 + end ;
}
} catch (Exception e) {
e.printStackTrace();
}
holder.tv.setText(ss);
Log.d("SpannableString" , ss.toString());
return rowView;
}
}
list_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" >
<TextView
android:id="@+id/textView1"
android:layout_gravity="center"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="25dp"
android:text="Hello World" />
</LinearLayout>
activity_main.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.shishupalshakya.spannablestringsample.MainActivity">
<ListView
android:id="@+id/listView"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
</ListView>
</RelativeLayout>
Вставьте код выше в ваше приложение и запустите.
Пожалуйста, попробуйте этот код, потому что вам нужна строка Spannable:
SpannableString ss = new SpannableString("Hello World");
ClickableSpan span1 = new ClickableSpan() {
@Override
public void onClick(View textView) {
// do first word click work
}
};
ClickableSpan span2 = new ClickableSpan() {
@Override
public void onClick(View textView) {
// do second word click work
}
};
ss.setSpan(span1, 0, 4, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
ss.setSpan(span2, 6, 10, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
TextView textView = (TextView) findViewById(R.id.hello);
textView.setText(ss);
textView.setMovementMethod(LinkMovementMethod.getInstance());
Спасибо
Я сделал простой пример, который удовлетворяет ваши требования
SpannableString text = new SpannableString("Text with Clickable word");
// make "Clickable" (characters 10 to 18) display a toast message when touched
final Context context = this;
ClickableSpan clickableSpan = new ClickableSpan() {
@Override
public void onClick(View view) {
Toast.makeText(context, "Clicked!!!", Toast.LENGTH_LONG).show();
}
};
text.setSpan(clickableSpan, 10, 18, 0);
Согласно вашему обновленному ответу
- Вы можете использовать метод contains для строки, чтобы узнать, присутствуют ли слова вашей БД в доступной строке
- тогда вы можете использовать indexOf, чтобы получить их индекс в доступной строке
- у вас уже есть длина слова
так что вы можете сделать этот процесс динамичным легко