Suche…


Tönen Sie ein Zeichen

Ein Drawable kann mit einer bestimmten Farbe eingefärbt werden. Dies ist hilfreich, um verschiedene Designs in Ihrer Anwendung zu unterstützen und die Anzahl an zeichnungsfähigen Ressourcendateien zu reduzieren.

Verwenden von Framework-APIs für SDK 21+:

Drawable d = context.getDrawable(R.drawable.ic_launcher);
d.setTint(Color.WHITE);

Verwenden der android.support.v4-Bibliothek im SDK 4+:

//Load the untinted resource
final Drawable drawableRes = ContextCompat.getDrawable(context, R.drawable.ic_launcher);
//Wrap it with the compatibility library so it can be altered
Drawable tintedDrawable = DrawableCompat.wrap(drawableRes);
//Apply a coloured tint
DrawableCompat.setTint(tintedDrawable, Color.WHITE);
//At this point you may use the tintedDrawable just as you usually would 
//(and drawableRes can be discarded)

//NOTE: If your original drawableRes was in use somewhere (i.e. it was the result of 
//a call to a `getBackground()` method then at this point you still need to replace 
//the background. setTint does *not* alter the instance that drawableRes points to, 
//but instead creates a new drawable instance

Bitte beachten Sie nicht, dass sich int color nicht auf eine int color bezieht. Sie sind jedoch nicht auf die in der Klasse "Color" definierten Farben beschränkt. Wenn Sie in Ihrem XML eine Farbe definiert haben, die Sie verwenden möchten, müssen Sie zunächst dessen Wert ermitteln.

Sie können die Verwendung von Color.WHITE mithilfe der folgenden Methoden ersetzen

Beim Targeting älterer APIs:

getResources().getColor(R.color.your_color);

Oder zu neueren Zielen:

ContextCompat.getColor(context, R.color.your_color);

Ansicht mit abgerundeten Ecken erstellen

Erstellen Sie eine zeichnungsfähige Datei mit dem Namen custom_rectangle.xml in einem Zeichnungsordner :

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

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

    <corners android:radius="10dip" />

    <stroke
        android:width="1dp"
        android:color="@android:color/white" />

</shape>

Wenden Sie jetzt den Rechteckhintergrund auf Ansicht an :

mView.setBackGround(R.drawlable.custom_rectangle);

Referenz-Screenshot:

Geben Sie hier die Bildbeschreibung ein

Kreisförmige Ansicht

Für eine kreisförmige Ansicht (in diesem Fall TextView ) erstellen Sie im drawble- Ordner eine drawble round_view.xml :

<?xml version="1.0" encoding="utf-8"?>
<shape
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">
    <solid android:color="#FAA23C" />
    <stroke android:color="#FFF" android:width="2dp" />
</shape>

Weisen Sie das Drawable der Ansicht zu:

    <TextView
        android:id="@+id/game_score"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:background="@drawable/round_score"
        android:padding="6dp"
        android:text="100"
        android:textColor="#fff"
        android:textSize="20sp"
        android:textStyle="bold"
        android:gravity="center" />

Jetzt sollte es wie der orange Kreis aussehen:

Geben Sie hier die Bildbeschreibung ein

Kundenspezifisch gezeichnet

Erweitern Sie Ihre Klasse mit Drawable und überschreiben Sie diese Methoden

public class IconDrawable extends Drawable {
    /**
     * Paint for drawing the shape
     */
    private Paint paint;
    /**
     * Icon drawable to be drawn to the center of the shape
     */
    private Drawable icon;
    /**
     * Desired width and height of icon
     */
    private int desiredIconHeight, desiredIconWidth;

    /**
     * Public constructor for the Icon drawable
     *
     * @param icon            pass the drawable of the icon to be drawn at the center
     * @param backgroundColor background color of the shape
     */
    public IconDrawable(Drawable icon, int backgroundColor) {
        this.icon = icon;
        paint = new Paint(Paint.ANTI_ALIAS_FLAG);
        paint.setColor(backgroundColor);
        desiredIconWidth = 50;
        desiredIconHeight = 50;
    }

    @Override
    public void draw(Canvas canvas) {
        //if we are setting this drawable to a 80dpX80dp imageview 
        //getBounds will return that measurements,we can draw according to that width.
        Rect bounds = getBounds();
        //drawing the circle with center as origin and center distance as radius
        canvas.drawCircle(bounds.centerX(), bounds.centerY(), bounds.centerX(), paint);
        //set the icon drawable's bounds to the center of the shape
        icon.setBounds(bounds.centerX() - (desiredIconWidth / 2), bounds.centerY() - (desiredIconHeight / 2), (bounds.centerX() - (desiredIconWidth / 2)) + desiredIconWidth, (bounds.centerY() - (desiredIconHeight / 2)) + desiredIconHeight);
        //draw the icon to the bounds
        icon.draw(canvas);

    }

    @Override
    public void setAlpha(int alpha) {
        //sets alpha to your whole shape
        paint.setAlpha(alpha);
    }

    @Override
    public void setColorFilter(ColorFilter colorFilter) {
       //sets color filter to your whole shape
        paint.setColorFilter(colorFilter);
    }

    @Override
    public int getOpacity() {
        //give the desired opacity of the shape
        return PixelFormat.TRANSLUCENT;
    }
}

Deklarieren Sie eine ImageView in Ihrem Layout

<ImageView
   android:layout_width="80dp"
   android:id="@+id/imageView"
   android:layout_height="80dp" />

Stellen Sie Ihre benutzerdefinierte Zeichnung auf die ImageView ein

 IconDrawable iconDrawable=new IconDrawable(ContextCompat.getDrawable(this,android.R.drawable.ic_media_play),ContextCompat.getColor(this,R.color.pink_300));
 imageView.setImageDrawable(iconDrawable);

Bildschirmfoto

Geben Sie hier die Bildbeschreibung ein Geben Sie hier die Bildbeschreibung ein Geben Sie hier die Bildbeschreibung ein



Modified text is an extract of the original Stack Overflow Documentation
Lizenziert unter CC BY-SA 3.0
Nicht angeschlossen an Stack Overflow