這次分享的是一個很常見的效果,凡是涉及到購物的app或者旅遊類以及訂餐類的app都有看到過這種效果,兩個list view聯動顯示,添加購物車時的一個拋物線動畫實現,以及圖標或者item右上角的數字顯示。下面是我空閒時候寫的一個demo,界面比較陋,但是基本效果都實現了。
不多說,看效果圖:
只對添加按鈕做了監聽,刪除沒去寫(沒什麼必要)。
講一些主要的代碼,想下載源碼的可以去這裏下載(https://github.com/bobge/LinkedListView.git):
左邊的listview的item右上角的數字是通過xml方式來顯示的:
shape_data.xml
<?xml version="1.0" encoding="UTF-8"?>
<shape
xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval"
android:useLevel="false" >
<solid android:color="#f00000" />
<padding
android:left="2dp"
android:top="1dp"
android:right="2dp"
android:bottom="1dp" />
<solid
android:color="#f00000" />
<size android:width="15dp"
android:height="15dp" />
</shape>
android:background="@drawable/shape_data"
購物車下面那個數字顯示我換了一種實現方式:調用BadgeView這個自定義類就能夠實現,用法很簡單,大家可以搜索一下這個類。
兩個listview的聯動也很簡單:
listView1.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
list2.clear();
list2.addAll(list.get(position).getList());
goodsAdapter.notifyDataSetChanged();
}
});
只要在左邊list view的監聽中給右邊list view的適配器notifyDataSetChanged就可以了。主要看看我的數據源格式應該就明白了。
拋物線動畫效果的實現,這部分網上有很多demo實現,其實原理很簡單,首先獲取點擊的那個位置的座標:
int[] startLocation = new int[2];// 一個整型數組,用來存儲按鈕的在屏幕的X、Y座標
v.getLocationInWindow(startLocation);// 這是獲取購買按鈕的在屏幕的X、Y座標(這也是動畫開始的座標)
通過同樣的方法計算結束位置(即購物車的位置座標),然後計算x,y軸上的平移距離,用AnimationSet添加translateAnimationX和translateAnimationY就ok了,具體的可以去下載源碼看看。