Android的ImageSwitcher和TextSw-android學習之旅(三十四)

來源:互聯網
上載者:User

標籤:android

ImageSwitcher簡介

ImageSwitcher繼承了ViewSwitcher,所以在切換時候會有動畫,可以把它理解成一個動畫版本的ImageView。
他的showNext(),和showPrevious()方法分別顯示下一個和上一個。
為ImageSwitcher提供一個ViewFactory,該ViewFactory的makeView()產生的View必須是ImageView。
ImageSwicher可以用setimageResource()和色圖ImageDrawable()以及setImageUri()來設定圖片資源。

支援動畫的圖片的瀏覽器程式碼範例
package peng.liu.test;import android.app.Activity;import android.graphics.drawable.Drawable;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.AdapterView;import android.widget.BaseAdapter;import android.widget.FrameLayout;import android.widget.GridView;import android.widget.ImageSwitcher;import android.widget.ImageView;import android.widget.SimpleAdapter;import android.widget.TextView;import android.widget.ViewSwitcher;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;public class MainActivity extends Activity {    private int[] imageIds = new int[]{            R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,R.drawable.ic_launcher,            R.drawable.ic_launcher, R.drawable.ic_launcher, R.drawable.ic_launcher, R.drawable.ic_launcher, R.drawable.ic_launcher, R.drawable.ic_launcher, R.drawable.ic_launcher            };    ImageSwitcher imageSwitcher;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        imageSwitcher = (ImageSwitcher) findViewById(R.id.imageSwitcher);        List<Map<String,Object>> listItems = new ArrayList<Map<String,Object>>();        for (int i = 0;i<imageIds.length;i++){            Map<String,Object> item = new HashMap<String, Object>();            item.put("image",imageIds[i]);            listItems.add(item);        }        SimpleAdapter adapter = new SimpleAdapter(MainActivity.this,listItems,R.layout.cell,new String[]{"image"},new int[]{R.id.image02});        imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() {            @Override            public View makeView() {                ImageView image = new ImageView(MainActivity.this);                image.setScaleType(ImageView.ScaleType.FIT_CENTER);                image.setLayoutParams(new ImageSwitcher.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,ViewGroup.LayoutParams.WRAP_CONTENT));                return image;            }        });        GridView grid = (GridView) findViewById(R.id.grid);        grid.setOnItemClickListener(new AdapterView.OnItemClickListener() {            @Override            public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {                imageSwitcher.setImageResource(imageIds[i]);            }        });        grid.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {            @Override            public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {                imageSwitcher.setImageResource(imageIds[i]);            }            @Override            public void onNothingSelected(AdapterView<?> adapterView) {            }        });    };}
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"        xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"        android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"        android:paddingRight="@dimen/activity_horizontal_margin"        android:paddingTop="@dimen/activity_vertical_margin"        android:paddingBottom="@dimen/activity_vertical_margin"        tools:context=".MainActivity"        >        <GridView            android:layout_width="fill_parent"            android:layout_height="wrap_content"            android:horizontalSpacing="1pt"            android:verticalSpacing="2pt"            android:numColumns="4"            android:gravity="center"            android:id="@+id/grid"            />        <ImageSwitcher            android:layout_width="300dp"            android:layout_height="300dp"            android:id="@+id/imageSwitcher"            android:layout_gravity="center_horizontal"            android:inAnimation="@android:anim/fade_in"            android:outAnimation="@android:anim/fade_out"            />    </LinearLayout>
TextSwitcher簡介

TextSwitcher也是繼承於ViewSwitcher,不同設定餓ViewFactory的makeView()返回的是TextView組件,可以像Button那樣設定點擊事件,在xml檔案設定OnClick:

程式碼範例
package peng.liu.test;import android.app.Activity;import android.graphics.Color;import android.graphics.drawable.Drawable;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.AdapterView;import android.widget.BaseAdapter;import android.widget.FrameLayout;import android.widget.GridView;import android.widget.ImageSwitcher;import android.widget.ImageView;import android.widget.SimpleAdapter;import android.widget.TextSwitcher;import android.widget.TextView;import android.widget.ViewSwitcher;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;public class MainActivity extends Activity {    TextSwitcher textSwitcher;    private String[] strs = new String[]{            "java","python","xml","html"    };    int currentStr;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        textSwitcher = (TextSwitcher) findViewById(R.id.textSwitcher);        textSwitcher.setFactory(new ViewSwitcher.ViewFactory() {            @Override            public View makeView() {                TextView text = new TextView(MainActivity.this);                text.setTextSize(40);                text.setTextColor(Color.MAGENTA);                return text;            }        });        next(null);    }    public void next(View view){        textSwitcher.setText(strs[currentStr++%strs.length]);    }}
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"        xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"        android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"        android:paddingRight="@dimen/activity_horizontal_margin"        android:paddingTop="@dimen/activity_vertical_margin"        android:paddingBottom="@dimen/activity_vertical_margin"        tools:context=".MainActivity"    android:orientation="vertical"        >        <TextSwitcher            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:inAnimation="@anim/slide_in"            android:outAnimation="@anim/slide_out"            android:onClick="next"            android:id="@+id/textSwitcher"/>    </LinearLayout>

Android的ImageSwitcher和TextSw-android學習之旅(三十四)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.