Android'de textview için yuvarlak köşe


171

Bir metin görünümüm var ve köşesinin yuvarlak olmasını istiyorum. Bunu kullanarak yapılabileceğini zaten biliyorum android:background="@drawable/somefile". Benim durumumda, bu etiket zaten dahil olduğundan tekrar kullanamazsınız. Örneğin android:background="@drawable/mydialogbox", arka planda görüntü oluşturmak için zaten var

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="fill_parent"
    android:layout_gravity="top"
    android:background="@drawable/mydialogbox"
    android:orientation="horizontal" >

    <TextView
        android:id="@+id/textview_name"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true" />

    </LinearLayout>

</RelativeLayout>

yani textview(textview_name)yuvarlak köşe ile de istediğimde bu nasıl başarılabilir.


4
Cevabınızı aldıysanız cevabınızı kabul edin, böylece diğerleriniz katkınızdan yardım alabilir
MilapTank

Yanıtlar:


438

1) oluşturma rounded_corner.xmliçinde drawableklasörün ve aşağıdaki içerik eklemek,

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >         
   <stroke
          android:width="1dp"
          android:color="@color/common_border_color" />

   <solid android:color="#ffffff" />

   <padding
           android:left="1dp"
           android:right="1dp"
           android:bottom="1dp"
           android:top="1dp" />

   <corners android:radius="5dp" />
</shape>

2) Bu çekilebilir öğeyi TextViewbackground özelliğinde ayarlayın. Örneğin:

android:background="@drawable/rounded_corner"

Umarım bu sizin için yararlıdır.


16
Cevap, gönderen kişinin ayrıntılı olarak açıklamadığı doğrudur. Bir xml oluşturmanız gerekir [ör. rounded_view.xml] 'yi yukarıdaki kodla çizilebilir klasörünüze ekleyin. Ve metin görünümünüzü çevreleyen düzeninizde bunu bir parametre android olarak koyun: background = "@ drawable / rounded_view"
Sharjeel Ahmed

4
android: background = "@ drawable / rounded_corner" burada uzantı kullanmıyor!
Boris Gafurov

4
android:shape="rectangle"Sizin için işe yaramadıysa ekleyin
kristyna

Otomatik olarak çalışmadıysa projenizi yeniden oluşturun
adek111

18

Yanında radius, yuvarlak köşeye bazı özellik varmış gibi topRightRadius, topLeftRadius, bottomRightRadius,bottomLeftRadius

Kenarlık gri` arka plan TextViewile örnekredwith corner and

bg_rounded.xml

<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <stroke
        android:width="10dp"
        android:color="#f00" />

    <solid android:color="#aaa" />

    <corners
        android:radius="5dp"
        android:topRightRadius="100dp" />
</shape>

Metin görünümü

<TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/bg_rounded"
    android:text="Text"
    android:padding="20dp"
    android:layout_margin="10dp"
    />

Sonuç

resim açıklamasını buraya girin


16

Üst düzey görünümünüzde zaten android: arka plan özellik seti olduğundan, hem eski arka planınızı hem de yeni yuvarlak köşelerin arka planınızı birleştiren yeni bir XML çizilebilir oluşturmak için bir <layer-list>( bağlantı ) kullanabilirsiniz.

<item>Listedeki her öğe bir sonrakinin üzerine çizilir, böylece listedeki son öğe üstte yer alan öğedir.

<?xml version="1.0" encoding="utf-8"?>
<layer-list
    xmlns:android="http://schemas.android.com/apk/res/android" >
    <item>
        <bitmap android:src="@drawable/mydialogbox" />
    </item>
    <item>
        <shape>
            <stroke
                android:width="1dp"
                android:color="@color/common_border_color" />

            <solid android:color="#ffffff" />

            <padding
                    android:left="1dp"
                    android:right="1dp"
                    android:top="1dp" />

            <corners android:radius="5dp" />
        </shape>
    </item>
</layer-list>

6

çekilebilir klasör altında xml gradient.xml dosyası oluştur

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:shape="rectangle"  >
            <corners android:radius="50dip" />
            <stroke android:width="1dip" android:color="#667162" />
            <gradient android:angle="-90" android:startColor="#ffffff" android:endColor="#ffffff" />
        </shape>
    </item>
</selector>

sonra bunu TextView'inize ekleyin

android:background="@drawable/gradient"

6
  1. Çekilebilir Klasöre Sağ Tıkla ve Yeni Dosya Oluştur
  2. Dosyayı size göre adlandırın ve uzantıyı .xml olarak ekleyin .
  3. Aşağıdaki kodu dosyaya ekleyin
  <?xml version="1.0" encoding="utf-8"?>
  <shape xmlns:android="http://schemas.android.com/apk/res/android"
      android:shape="rectangle">
      <corners android:radius="5dp" />
      <stroke android:width="1dp"  />
      <solid android:color="#1e90ff" />
  </shape>
  1. Yuvarlatılmış kenarı istediğiniz yere ekleyin android:background="@drawable/corner"

4

Sağlanan dikdörtgen şeklini (istemediğiniz sürece degrade olmadan) aşağıdaki gibi kullanabilirsiniz:

İçinde drawable/rounded_rectangle.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <corners android:radius="5dp" />
    <stroke android:width="1dp" android:color="#ff0000" />
    <solid android:color="#00ff00" />
</shape>

Ardından metin görünümünüzde:

android:background="@drawable/rounded_rectangle"

Tabii ki, boyutları ve renkleri özelleştirmek isteyeceksiniz.


4

İki adım var

1) Bu dosyayı çekilebilir klasörünüzde oluşturun: - rounded_corner.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
         <corners android:radius="10dp" />  // set radius of corner
         <stroke android:width="2dp" android:color="#ff3478" /> // set color and width of border
         <solid android:color="#FFFFFF" /> // inner bgcolor
</shape>

2) Bu dosyayı TextViewarka plan özelliği olarak ayarlayın .

android:background="@drawable/rounded_corner"

Bu çekmeceyi Düğme veya Düzen Metni'nde de kullanabilirsiniz


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

    <item android:id="@android:id/background">
        <shape>
            <corners android:radius="5dp" />
            <solid android:color="#ffffff"/>

        </shape>
    </item>
</layer-list>

3

Malzeme Bileşenleri Kütüphanesi ile MaterialShapeDrawable.

İle TextView:

    <TextView
        android:id="@+id/textview"
        ../>

Programlı olarak aşağıdakileri uygulayabilirsiniz MaterialShapeDrawable:

float radius = getResources().getDimension(R.dimen.corner_radius);

TextView textView = findViewById(R.id.textview);
ShapeAppearanceModel shapeAppearanceModel = new ShapeAppearanceModel()
        .toBuilder()
        .setAllCorners(CornerFamily.ROUNDED,radius)
        .build();

MaterialShapeDrawable shapeDrawable = new MaterialShapeDrawable(shapeAppearanceModel);
ViewCompat.setBackground(textView,shapeDrawable);

resim açıklamasını buraya girin

Arka plan rengini değiştirmek istiyorsanız ve kenarlık uygulamanız yeterlidir:

shapeDrawable.setFillColor(ContextCompat.getColorStateList(this,R.color.....));
shapeDrawable.setStroke(2.0f, ContextCompat.getColor(this,R.color....));

0

Köşeleri yuvarlamak için SVG'yi kullanabilir ve bir ImageView'e yükleyebilir ve TextView üzerine ImageView getirmek için ConstraintLayout'u kullanabilirsiniz

Yuvarlak ImageView ve yuvarlak TextView için kullandım


0

Yuvarlatılmış bir köşe görüntüsünü o görünümün arka planı olarak kullanmak bunu yapacaktır.

android:background="@drawable/my_custom_image"
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.