• AndroidActivity跳转动画,让你的APP瞬间绚丽起来


    我们都知道绚丽的APP总会给用户耳目一新的感觉,为了抓住用户更大网络公司使出浑身解数让自己的产品更绚丽,而绚丽最简单的效果就是Activity跳转效果,不仅能够让用户看起来舒服,并且实现起来也特别简单,好,以下就让我们实现这些效果,告别原生态的跳转效果吧!

    首先新建一个Android项目,起名叫作AndroidSwitch。实在不知道起什么名字了,就有道了一个这种名字,首先让我们先看一下XML代码非常easy,就一个LIstview 代码例如以下所看到的:

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
    
        <ListView
            android:id="@+id/listView1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
        </ListView>
    
    </LinearLayout>
    这个XML中的ListView主要负责盛装一些效果的点击事件,显示效果的文字我会放在Values,一起同项目给你们!跳转效果.跳转效果,最重要的当然是动画了,.没有动画谈何效果,所以我们在res文件新建一个anim文件用于放各种动画,动画挺多的,我就举一个简单的XML.就不一一举例了,我会把项目给你们的,能够自己去看!例如以下所看到的:

    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android" >
    
        <translate
            android:duration="2000"
            android:fromXDelta="0"
            android:toXDelta="-100%p" />
    
    </set>
    是不是非常easy呀,好,居然动画也编辑完了,我们就须要在哪调用它.对了,我们还须要一个跳转SecondActivity,在这个SecondActivity里面我仅仅放了一个Button用于返回,这样不用按Back键那么麻烦了,它的作用仅仅是为了显示第一个Activity跳转的效果,让我看.例如以下所看到的:

    package com.zqy.androidswitch;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    
    public class SecondActivity extends Activity{
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.act_second);
    		final Button button=(Button) findViewById(R.id.button1);
    		button.setOnClickListener(new OnClickListener() {
    			
    			@Override
    			public void onClick(View v) {
    				finish();
    			}
    		});
    	}
    }
    
    好,基本完毕一半了,我须要写实现的代码了,这属于核心了,让我们看看核心代码是怎么实现的吧:例如以下所看到的:
    package com.zqy.androidswitch;
    
    import java.util.ArrayList;
    import java.util.List;
    
    
    import android.os.Bundle;
    import android.app.Activity;
    import android.content.Intent;
    import android.view.View;
    import android.widget.AdapterView;
    import android.widget.ArrayAdapter;
    import android.widget.ListView;
    import android.widget.AdapterView.OnItemClickListener;
    
    public class MainActivity extends Activity {
    
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.activity_main);
    		final ListView listView = (ListView) findViewById(R.id.listView1);
    		String[] ls = getResources().getStringArray(R.array.anim_type);
    		List<String> list = new ArrayList<String>();
    		for (int i = 0; i < ls.length; i++) {
    			list.add(ls[i]);
    		}
    		ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1, list);
    		adapter.setDropDownViewResource(android.R.layout.simple_list_item_1);
    		listView.setAdapter(adapter);
    		listView.setOnItemClickListener(new OnItemClickListener() {
    
    			@Override
    			public void onItemClick(AdapterView<?> parent, View view,
    					int position, long id) {
    				Intent intent = new Intent(MainActivity.this, SecondActivity.class);
    				startActivity(intent);
    				switch (position) {
    				case 0:
    					overridePendingTransition(R.anim.fade, R.anim.hold);
    					break;
    				case 1:
    					overridePendingTransition(R.anim.my_scale_action,
    							R.anim.my_alpha_action);
    					break;
    				case 2:
    					overridePendingTransition(R.anim.scale_rotate,
    							R.anim.my_alpha_action);
    					break;
    				case 3:
    					overridePendingTransition(R.anim.scale_translate_rotate,
    							R.anim.my_alpha_action);
    					break;
    				case 4:
    					overridePendingTransition(R.anim.scale_translate,
    							R.anim.my_alpha_action);
    					break;
    				case 5:
    					overridePendingTransition(R.anim.hyperspace_in,
    							R.anim.hyperspace_out);
    					break;
    				case 6:
    					overridePendingTransition(R.anim.push_left_in,
    							R.anim.push_left_out);
    					break;
    				case 7:
    					overridePendingTransition(R.anim.push_up_in,
    							R.anim.push_up_out);
    					break;
    				case 8:
    					overridePendingTransition(R.anim.slide_left,
    							R.anim.slide_right);
    					break;
    				case 9:
    					overridePendingTransition(R.anim.wave_scale,
    							R.anim.my_alpha_action);
    					break;
    				case 10:
    					overridePendingTransition(R.anim.zoom_enter,
    							R.anim.zoom_exit);
    					break;
    				case 11:
    					overridePendingTransition(R.anim.slide_up_in,
    							R.anim.slide_down_out);
    					break;
    
    				default:
    					break;
    				}
    
    			}
    		});
    
    		}
    	}
    
    
    用Listview盛装各种效果的点击事件,我们点击LIstview在依据点击位置去运行什么样的动画.不知道手机怎么做出gif图片,我就把主页面显示出来吧,大家一会能够下载Demo.


    好了,基本实现完了.是不是非常easy.有了这些动画,就会让你的APP多了一道绚丽的风景线,能够直接拿到项目里面用哦!最后来一句,.大神勿喷,适合新手!

    源代码下载,请点击这里













  • 相关阅读:
    PL/pgSQL的RETURN QUERY例子
    PL/pgSQL的 RETURN NEXT例子
    PL/pgSQL学习笔记之二
    基于React的PC网站前端架构分析
    DialogFragment创建默认dialog
    一个RecycleView的强大adapter
    企业者的福音之8266接入阿里智能,点亮一盏灯。
    基于webmagic的种子网站爬取
    自上而下渐显图片的CSS3实现
    用SwiftGen管理UIImage等的String-based接口
  • 原文地址:https://www.cnblogs.com/yjbjingcha/p/7079067.html
Copyright © 2020-2023  润新知