Android - Benutzerdefinierte Komponenten

Implementieren eigener Komponenten in vorgefertigten Komponenten mit erweiterter Unterklasse mit eigener definierter Klasse

Android bietet eine große Liste vorgefertigter Widgets wie Button, TextView, EditText, ListView, CheckBox, RadioButton, Galerie, Spinner, AutoCompleteTextView usw., die Sie direkt in Ihrer Android-Anwendungsentwicklung verwenden können nicht zufrieden mit der vorhandenen Funktionalität eines der verfügbaren Widgets. Android bietet Ihnen die Möglichkeit, eigene benutzerdefinierte Komponenten zu erstellen, die Sie an Ihre Bedürfnisse anpassen können.

Wenn Sie nur kleine Anpassungen an einem vorhandenen Widget oder Layout vornehmen müssen, können Sie das Widget oder Layout einfach in Unterklassen unterteilen und seine Methoden überschreiben, sodass Sie das Erscheinungsbild und die Funktion eines Bildschirmelements präzise steuern können.

In diesem Tutorial erfahren Sie, wie Sie in einfachen Schritten benutzerdefinierte Ansichten erstellen und in Ihrer Anwendung verwenden.

Beispiel für benutzerdefinierte Komponenten in der Hierarchie der benutzerdefinierten Ansicht

Erstellen einer einfachen benutzerdefinierten Komponente

Schritt Beschreibung
1 Mit der Android Studio-IDE erstellen Sie eine Android-Anwendung und benennen sie als myapplication unter einem Paket com.example.tutorialspoint7.myapplication, wie im Kapitel Hello World Example erläutert .
2 Erstellen Sie eine XML- Datei res / values ​​/ attrs.xml , um neue Attribute zusammen mit ihrem Datentyp zu definieren.
3 Erstellen Sie die Datei src / mainactivity.java und fügen Sie den Code hinzu, um Ihre benutzerdefinierte Komponente zu definieren
4 Ändern Sie die Datei res / layout / activity_main.xml und fügen Sie den Code hinzu, um eine Instanz der zusammengesetzten Farbansicht zusammen mit einigen Standardattributen und neuen Attributen zu erstellen.
5 Führen Sie die Anwendung aus, um den Android-Emulator zu starten, und überprüfen Sie das Ergebnis der in der Anwendung vorgenommenen Änderungen.

Erstellen Sie die folgende Attributdatei mit dem Namen attrs.xml in Ihrem Ordner res / values.

<?xml version="1.0" encoding="utf-8"?>
<resources>
   <declare-styleable name="TimeView">
      <declare-styleable name="TimeView">
         <attr name="title" format="string" />
         <attr name="setColor" format="boolean"/>
      </declare-styleable>
   </declare-styleable>
</resources>

Ändern Sie die von der Aktivität verwendete Layoutdatei wie folgt.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
   xmlns:tools="http://schemas.android.com/tools"
   xmlns:custom="http://schemas.android.com/apk/res-auto"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context=".MainActivity" >

   <com.example.tutorialspoint7.myapplication.TimeView
      android:id="@+id/timeView"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:textColor="#fff"
      android:textSize="40sp"
      custom:title="my time view"
      custom:setColor="true" />

   <TextView
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/simple"
      android:layout_below="@id/timeView"
      android:layout_marginTop="10dp" />
</RelativeLayout>

Erstellen Sie die folgende Java-Datei mit dem Namen timeview für Ihre zusammengesetzte Ansicht.

package com.example.tutorialspoint7.myapplication;
/**
 * Created by TutorialsPoint7 on 9/14/2016.
 */
import java.text.SimpleDateFormat;
import java.util.Calendar;

import android.content.Context;
import android.content.res.TypedArray;

import android.graphics.Color;
import android.util.AttributeSet;
import android.widget.TextView;

public class TimeView extends TextView {
   private String titleText;
   private boolean color;

   public TimeView(Context context) {
      super(context);
      setTimeView();
   }

   public TimeView(Context context, AttributeSet attrs) {
      super(context, attrs);
      // retrieved values correspond to the positions of the attributes
         TypedArray typedArray = context.obtainStyledAttributes(attrs, 
            R.styleable.TimeView);
      int count = typedArray.getIndexCount();
      try{
         
         for (int i = 0; i < count; ++i) {
            
            int attr = typedArray.getIndex(i);
            // the attr corresponds to the title attribute
            if(attr == R.styleable.TimeView_title) {
               
               // set the text from the layout
               titleText = typedArray.getString(attr);
               setTimeView();
            } else if(attr == R.styleable.TimeView_setColor) {
               // set the color of the attr "setColor"
               color = typedArray.getBoolean(attr, false);
               decorateText();
            }
         }
      }
        
      // the recycle() will be executed obligatorily
      finally {
         // for reuse
         typedArray.recycle();
      }
   }

   public TimeView(Context context, AttributeSet attrs, int defStyle) {
      super(context, attrs, defStyle);
      setTimeView();
   }

   private void setTimeView() {
      // has the format hour.minuits am/pm
      SimpleDateFormat dateFormat = new SimpleDateFormat("hh.mm aa");
      String time = dateFormat.format(Calendar.getInstance().getTime());
      
      if(this.titleText != null )
      setText(this.titleText+" "+time);
      else
         setText(time);
   }

   private void decorateText() {
      // when we set setColor attribute to true in the XML layout
      if(this.color == true){
         // set the characteristics and the color of the shadow
         setShadowLayer(4, 2, 2, Color.rgb(250, 00, 250));
         setBackgroundColor(Color.CYAN);
      } else {
         setBackgroundColor(Color.RED);
      }
   }
}

Ändern Sie Ihre Java-Datei für Hauptaktivitäten in den folgenden Code und führen Sie Ihre Anwendung aus.

package com.example.tutorialspoint7.myapplication;

import android.os.Bundle;
import android.widget.TextView;
import android.app.Activity;

public class MainActivity extends Activity {

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      TextView simpleText = (TextView) findViewById(R.id.simple);
      simpleText.setText("That is a simple TextView");
   }
}

Die laufende Anwendung sollte wie im folgenden Screenshot aussehen.