Functions and usage of ViewFlipper

Source: Internet
Author: User

Functions and usage of ViewFlipper

The ViewFlipper component inherits ViewAnimator. It can call addView (View v) to add multiple components to ViewFlipper. After adding multiple components to ViewFlipper, ViewFlipper can use animation to control the switching effect between multiple components.

ViewAnimator is a base class that inherits FrameLayout. Therefore, multiple View components can be "superimposed". ViewAnimator is added to demonstrate animation effects during View switching.

ViewFlipper inherits ViewAnimation. The additional new features are as follows:

Eg. Image Library for automatic playback

Acitivity_main.xml

<relativelayout 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:paddingbottom="@dimen/activity_vertical_margin" android:paddingleft="@dimen/activity_horizontal_margin" android:paddingright="@dimen/activity_horizontal_margin" android:paddingtop="@dimen/activity_vertical_margin" tools:context="com.example.viewflippertest.MainActivity">     <!--{cke_protected}{C}%3C!%2D%2D%20%20ViewFlipper%E7%BB%84%E4%BB%B6%EF%BC%8C%E6%94%BE%E4%BA%86%E4%B8%89%E4%B8%AAImageView%E7%BB%84%E4%BB%B6%2D%2D%3E-->    <viewflipper android:id="@+id/viewFlipper1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignparentleft="true" android:layout_alignparenttop="true" android:layout_marginleft="80dp" android:layout_margintop="34dp" android:flipinterval="1000">        <imageview android:id="@+id/imageView1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/bomb10">        <imageview android:id="@+id/imageView2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/bomb11">        <imageview android:id="@+id/imageView3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/bomb12">    </imageview></imageview></imageview></viewflipper><button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignparentleft="true" android:layout_centervertical="true" android:layout_marginleft="32dp" android:onclick="prev" android:text="<"></button><button android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centervertical="true" android:layout_torightof="@+id/button1" android:onclick="auto" android:text="Auto"></button><button android:id="@+id/button3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignbaseline="@+id/button2" android:layout_alignbottom="@+id/button2" android:layout_torightof="@+id/button2" android:onclick="next" android:text=">"></button></relativelayout>
MainActvity. java
Package com. example. viewflippertest; import android. app. activity; import android. OS. bundle; import android. view. menu; import android. view. menuItem; import android. view. view; import android. widget. viewFlipper; public class MainActivity extends Activity {ViewFlipper cf; // ViewFlipper object @ Override protected void onCreate (Bundle savedInstanceState) {super. onCreate (savedInstanceState); setContentView (R. layout. activity_main); cf = (ViewFlipper) findViewById (R. id. viewFlipper1);} // response Button Function public void prev (View v) {cf. setInAnimation (this, R. anim. slide_in_right); cf. setOutAnimation (this, R. anim. slide_out_left); cf. showPrevious (); // stop switching cf. stopFlipping () ;}; // response Button Function public void auto (View v) {cf. setInAnimation (this, R. anim. slide_in_right); cf. setOutAnimation (this, R. anim. slide_out_left); cf. startFlipping () ;}; // response Button Function public void next (View v) {cf. setInAnimation (this, R. anim. slide_in_left); cf. setOutAnimation (this, R. anim. slide_out_right); cf. showNext (); // stop switching cf. stopFlipping () ;}; @ Override public boolean onCreateOptionsMenu (Menu menu) {// Inflate the menu; this adds items to the action bar if it is present. getMenuInflater (). inflate (R. menu. main, menu); return true ;}@ Override public boolean onOptionsItemSelected (MenuItem item) {// Handle action bar item clicks here. the action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest. xml. int id = item. getItemId (); if (id = R. id. action_settings) {return true;} return super. onOptionsItemSelected (item );}}
Slide_in_left.xml
<!--{cke_protected}{C}%3C!%2D%2D%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%2D%2D%3E--><set xmlns:android="http://schemas.android.com/apk/res/android">    <!--{cke_protected}{C}%3C!%2D%2D%20%E8%AE%BE%E7%BD%AE%E4%BB%8E%E5%B7%A6%E8%BE%B9%E6%8B%96%E8%BF%9B%E6%9D%A5%E7%9A%84%E5%8A%A8%E7%94%BB%0A%20%20%20%20android%3Aduration%E6%8C%87%E5%AE%9A%E5%8A%A8%E7%94%BB%E6%8C%81%E7%BB%AD%E6%97%B6%E9%97%B4%20%20%2D%2D%3E--><translate android:fromxdelta="-100%p" android:toxdelta="0" android:duration="@android:integer/config_mediumAnimTime"></translate></set>
Slide_in_right.xml
<!--{cke_protected}{C}%3C!%2D%2D%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%2D%2D%3E--><set xmlns:android="http://schemas.android.com/apk/res/android">    <!--{cke_protected}{C}%3C!%2D%2D%20%E8%AE%BE%E7%BD%AE%E4%BB%8E%E5%8F%B3%E8%BE%B9%E6%8B%96%E8%BF%9B%E6%9D%A5%E7%9A%84%E5%8A%A8%E7%94%BB%0A%20%20%20%20android%3Aduration%E6%8C%87%E5%AE%9A%E5%8A%A8%E7%94%BB%E6%8C%81%E7%BB%AD%E6%97%B6%E9%97%B4%20%20%2D%2D%3E--><translate android:fromxdelta="100%p" android:toxdelta="0" android:duration="@android:integer/config_mediumAnimTime"></translate></set>
Slide_out_left.xml
<!--{cke_protected}{C}%3C!%2D%2D%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%2D%2D%3E--><set xmlns:android="http://schemas.android.com/apk/res/android">    <!--{cke_protected}{C}%3C!%2D%2D%20%E8%AE%BE%E7%BD%AE%E4%BB%8E%E5%B7%A6%E8%BE%B9%E6%8B%96%E5%87%BA%E5%8E%BB%E7%9A%84%E5%8A%A8%E7%94%BB%20%0A%20%20%20%20android%3Aduration%E6%8C%87%E5%AE%9A%E5%8A%A8%E7%94%BB%E6%8C%81%E7%BB%AD%E6%97%B6%E9%97%B4%20%2D%2D%3E--><translate android:fromxdelta="0" android:toxdelta="-100%p" android:duration="@android:integer/config_mediumAnimTime"></translate></set>
Slide_out_right.xml
<!--{cke_protected}{C}%3C!%2D%2D%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%2D%2D%3E--><set xmlns:android="http://schemas.android.com/apk/res/android">    <!--{cke_protected}{C}%3C!%2D%2D%20%E8%AE%BE%E7%BD%AE%E4%BB%8E%E5%B7%A6%E8%BE%B9%E6%8B%96%E5%87%BA%E5%8E%BB%E7%9A%84%E5%8A%A8%E7%94%BB%20%0A%20%20%20%20android%3Aduration%E6%8C%87%E5%AE%9A%E5%8A%A8%E7%94%BB%E6%8C%81%E7%BB%AD%E6%97%B6%E9%97%B4%20%2D%2D%3E--><translate android:fromxdelta="0" android:toxdelta="100%p" android:duration="@android:integer/config_mediumAnimTime"></translate></set>

 

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

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.