'Android Image zooming animation
I'm doing an android application which has image zooming animation control with start & stop buttons.(i.e)I've two buttons with an image.when i click start,the image should do zooming animation.when i click stop,it should stop animation.,and again if i click start,it should resume zooming from the stopped position.How could i do that? Below is my working sample code:
ImageView imageView; ScaleAnimation zoom; Animation animset; float gg;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    zoom = new ScaleAnimation(0, 1, 0, 1);
    zoom.setDuration(3000);
    imageView = (ImageView) findViewById(R.id.imageView1);
    imageView.startAnimation(zoom);
    ((Button) findViewById(R.id.start)).setOnClickListener(this);
    ((Button) findViewById(R.id.stop)).setOnClickListener(this);
}
@Override
public void onClick(View v) {
    switch (v.getId()) {
    case R.id.start:
        zoom.setDuration((long) gg);
        zoom.start();
        break;
    case R.id.stop:
        gg = zoom.getDuration();
        break;
    }
}
} Thanks.
Solution 1:[1]
Try this:
ZoomInActivity.java
    public class ZoomInActivity extends Activity implements AnimationListener {
    
        ImageView imgPoster;
        Button btnStart;
    
        // Animation
        Animation animZoomIn;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            // TODO Auto-generated method stub
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_zoom_in);
    
            imgPoster = (ImageView) findViewById(R.id.imgLogo);
            btnStart = (Button) findViewById(R.id.btnStart);
    
            // load the animation
            animZoomIn = AnimationUtils.loadAnimation(getApplicationContext(),
                    R.anim.zoom_in);
            
            // set animation listener
            animZoomIn.setAnimationListener(this);
    
            // button click event
            btnStart.setOnClickListener(new View.OnClickListener() {
    
                @Override
                public void onClick(View v) {
                    // start the animation
                    imgPoster.startAnimation(animZoomIn);
                }
            });
    
        }
    
        @Override
        public void onAnimationEnd(Animation animation) {
            // Take any action after completing the animation
    
            // check for zoom in animation
            if (animation == animZoomIn) {          
            }
    
        }
    
        @Override
        public void onAnimationRepeat(Animation animation) {
            // TODO Auto-generated method stub
    
        }
    
        @Override
        public void onAnimationStart(Animation animation) {
            // TODO Auto-generated method stub
    
        }
    
    }
activity_zoom_in.xml
    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#000000"
        android:gravity="center">
        
        <ImageView android:id="@+id/imgLogo"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/man_of_steel"
            android:layout_centerInParent="true"/>
        
        <Button android:id="@+id/btnStart"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Start Animation"
            android:layout_marginTop="30dp"
            android:layout_alignParentBottom="true"
            android:layout_centerHorizontal="true"
            android:layout_marginBottom="20dp"/>
        
    </RelativeLayout>
Make anim folder in res and create zoom_in.xml
zoom_in.xml
    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:fillAfter="true" >
    
        <scale
            xmlns:android="http://schemas.android.com/apk/res/android"
            android:duration="1000"
            android:fromXScale="1"
            android:fromYScale="1"
            android:pivotX="50%"
            android:pivotY="50%"
            android:toXScale="3"
            android:toYScale="3" >
        </scale>
    
    </set>
    					Solution 2:[2]
Easy and Simple
- Create folder res/anim
 - Put animation descriptions into res/anim folder
 Set animation to image using below code
ImageView image=(ImageView)findViewById(R.id.imageId); image.setAnimation(AnimationUtils.loadAnimation(this,R.anim.zoom_in_anim));
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source | 
|---|---|
| Solution 1 | smmehrab | 
| Solution 2 | Guru raj | 
