TextView Border Top в другом цвете - PullRequest
4 голосов
/ 30 ноября 2011

У меня есть TextView, и я хочу поместить другой цвет на верхнюю границу (скажем, белый), я пытаюсь что-то вроде этого, но не работает (поставить белую границу для всех полей - слева, справа, сверху, снизу)

<TextView 
android:layout_height="50dip" 
android:text="@string/total" 
android:background="@drawable/border_top_textview"
android:textColor="#FFFFFF" 
android:id="@+id/totalCash" 
android:layout_width="match_parent" 
android:gravity="center_vertical" 
android:textSize="26dip" 
android:layout_weight="0.3" 
android:textStyle="bold"></TextView>

и border_top_textview.xml

<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item>
  <shape android:shape="rectangle">
       <stroke android:width="2dp" android:height="2dp" android:color="#FFFFFF" />

        <solid android:color="#000000" />
            <padding android:top="1dp" android:bottom="1dp" />
   </shape></item></layer-list>

Ответы [ 3 ]

3 голосов
/ 30 ноября 2011

Самый простой способ - использовать 9-полосное изображение в качестве фона с желаемой рамкой.

или

попробуйте это, может быть, это поможет вам, это создаст ЛИНУЮ на вершине, которая будет выглядеть как граница:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
<item>
    <shape android:shape="line">
        <stroke android:width="5dp" android:color="#FFFF00" />
        <solid android:color="#00000000" />

        <padding android:top="25dp" />

    </shape>
</item>
</layer-list>
2 голосов
/ 30 ноября 2011
public class MyTextView extends TextView {

      public MyTextView(Context context, AttributeSet attrs, int defStyle) {
           super(context, attrs, defStyle);
      }
      public MyTextView(Context context, AttributeSet attrs) {
            super(context, attrs);
      }
      public MyTextView(Context context) {
            super(context);
      }
      @Override
      protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
            Rect rect = new Rect();
            Paint paint = new Paint();
            paint.setStyle(Paint.Style.STROKE);
            paint.setColor(Color.WHITE);
            paint.setStrokeWidth(3);
            getLocalVisibleRect(rect);
           canvas.drawRect(rect, paint);       
      }
}

xml Файл:

<?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">
        <samples.test.MyTextView 
                 android:layout_width="fill_parent"
                 android:layout_height="wrap_content"
                 android:text="@string/hello" />
</LinearLayout>

Смотрите здесь

Попробуйте этот хитрый способ использовать изображение в качестве рамки и используйте этот код, он будет работать нормально.

enter code here

  <TextView
    android:id="@+id/text1" 
    android:layout_width="100dp"
    android:layout_height="wrap_content"
    android:drawableTop="@drawable/header1" 
    android:gravity="center" 
    android:textAppearance="?android:attr/textAppearanceMedium" 
    android:textStyle="bold"             
    android:textSize="20sp"
    android:textColor="@drawable/selector_icon_text_color"
    android:text="Hussain">
    </TextView>
2 голосов
/ 30 ноября 2011

Здесь вы можете поместить эти строки в тег формы,

<stroke android:width="4dp" android:color="#FFFFFF" />
<padding android:left="0dp" android:top="7dp"
android:right="0dp" android:bottom="0dp" />

положи верхний отступ по крайней мере 5dp и сделай другие 0dp

...