209

I have a TextView and I want to add a bullet symbol in my text through XML. Is it possible?

Mridang Agarwalla
  • 43,201
  • 71
  • 221
  • 382
Pria
  • 2,743
  • 4
  • 27
  • 30

11 Answers11

468

You have to use the right character encoding to accomplish this effect. You could try with •


Update

Just to clarify: use `setText("\u2022 Bullet");` to add the bullet programmatically. `0x2022 = 8226`
Glorfindel
  • 21,988
  • 13
  • 81
  • 109
Benny Skogberg
  • 10,431
  • 11
  • 53
  • 83
80

This worked for me:

<string name="text_with_bullet">Text with a \u2022</string>
Sagar Maiyad
  • 12,655
  • 9
  • 63
  • 99
jackbijou
  • 901
  • 6
  • 5
33

Copy paste: •. I've done it with other weird characters, such as ◄ and ►.

Edit: here's an example. The two Buttons at the bottom have android:text="◄" and "►".

Felix
  • 88,392
  • 43
  • 149
  • 167
  • 8
    The problem is when line wraps. It will not indent a 2nd line – Bostone Sep 21 '10 at 21:36
  • 4
    just use a linear layout with orientation horizontal, first textview with "Icon and Space" second :=) the text, => all intended – cV2 Aug 15 '11 at 16:10
21

Prolly a better solution out there somewhere, but this is what I did.

<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        >
        <TableRow>    
            <TextView
                android:layout_column="1"
                android:text="•"></TextView>
            <TextView
                android:layout_column="2"
                android:layout_width="wrap_content"
                android:text="First line"></TextView>
        </TableRow>
        <TableRow>    
            <TextView
                android:layout_column="1"
                android:text="•"></TextView>
            <TextView
                android:layout_column="2"
                android:layout_width="wrap_content"
                android:text="Second line"></TextView>
        </TableRow>
  </TableLayout>

It works like you want, but a workaround really.

The Cageybee
  • 273
  • 2
  • 6
12

You may try BulletSpan as described in Android docs.

SpannableString string = new SpannableString("Text with\nBullet point");
string.setSpan(new BulletSpan(40, color, 20), 10, 22, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

Result

Faisal Naseer
  • 4,110
  • 1
  • 37
  • 55
8

Another best way to add bullet in any text view is stated below two steps:

First, create a drawable

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">

    <!--set color of the bullet-->
   <solid 
       android:color="#666666"/> //set color of bullet

    <!--set size of the bullet-->
   <size 
       android:width="120dp"
        android:height="120dp"/>
</shape>

Then add this drawable in textview and set its pedding by using below properties

android:drawableStart="@drawable/bullet"
android:drawablePadding="10dp"
Asadullah Mumtaz
  • 171
  • 1
  • 14
6

This is how i ended up doing it.

 <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:orientation="horizontal">

            <View
                android:layout_width="20dp"
                android:layout_height="20dp"
                android:background="@drawable/circle"
                android:drawableStart="@drawable/ic_bullet_point" />

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="10dp"
                android:text="Your text"
                android:textColor="#000000"
                android:textSize="14sp" />
        </LinearLayout>

and the code for drawbale/circle.xml is

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
  android:innerRadius="0dp"
  android:shape="ring"
  android:thickness="5dp"
  android:useLevel="false">

 <solid android:color="@color/black1" />

</shape>
Irfan
  • 956
  • 9
  • 16
5

With Unicode we can do it easily, but if want to change color of bullet, I tried with colored bullet image and set it as drawableStart and it worked

<TextView     
    android:text="Hello bullet"
    android:drawableStart="@drawable/bulleticon" >
</TextView>
Ryan M
  • 18,333
  • 31
  • 67
  • 74
Aditya Vyas-Lakhan
  • 13,409
  • 16
  • 61
  • 96
0

Since android doesnt support <ol>, <ul> or <li> html elements, I had to do it like this

<string name="names"><![CDATA[<p><h2>List of Names:</h2></p><p>&#8226;name1<br />&#8226;name2<br /></p>]]></string>

if you want to maintain custom space then use </pre> tag

Aniruddha K.M
  • 7,361
  • 3
  • 43
  • 52
0

(almost) all of the options are about using html tags.

you can use drawables for your TextView if it has only one line of text.

something like this:

<TextView
            android:id="@+id/tv_with_bullet"
            android:layout_width="match_parent"
            android:layout_height="50dp"
            app:drawableStartCompat="@drawable/ic_desired_bullet_icon" />

and add your desired bullet drawable in SVG. it literally takes no space and makes you free of adding complicated string literals. you can also download the SVG file for a bullet point in here

0

I create this extensión function in Kotlin

fun TextView.addBulletPoints(bulletSymbol: Char = '•') {
    //•‣⁃∙◎◦⦾⦿
    val lines = text?.split("\n") ?: emptyList()
    val builder = SpannableStringBuilder()

    for (line in lines) {
        builder.append("$bulletSymbol ")
        builder.append(line.trim())
        builder.append("\n")
    }

    text = builder
}

or alternative API 24 upper

fun TextView.addBulletPoints(bulletGapWidth: Int = 32, bulletRadius: Int = 12, color: Int = currentTextColor) {
    val lines = text?.split("\n") ?: emptyList()
    val builder = SpannableStringBuilder()

    for (line in lines) {
        val start = builder.length
        builder.append(line.trim())
        builder.setSpan(BulletSpan(bulletGapWidth, color, bulletRadius), start, builder.length, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE)
        builder.append("\n")
    }

    text = builder
}
Codelaby
  • 2,604
  • 1
  • 25
  • 25