看了bilibili的客戶端搜索按鈕,很喜歡大愛!自己也想做個類似的(相似度 10% 哈哈)
popWin的出現退出動畫也可以自己設定,用過其方法setAnimationStyle(R.style.xxx)設置Style文件進而設置顯示退出動畫
<!-- popwindow進入和退出動畫 --> <style name="popwin_anim_style"> <item name="android:windowEnterAnimation">@anim/menushow</item> <item name="android:windowExitAnimation">@anim/menuhide</item> </style>
對應的show和hide文件,這里看以發現只是很簡單的translate變換動畫
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="-800" android:toXDelta="0" android:fromYDelta="0" android:toYDelta="0" android:duration="500" /> </set>
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:fromXDelta="0" android:toXDelta="-700" android:fromYDelta="0" android:toYDelta="0" android:duration="300" /> </set>
我們在新建一個popupwindow之后 關鍵就在這里 顯示的時候規定顯示的位置
//這里是獲取需要顯示popwin的view的位置,然后使popwin顯示在其上方 int[] location = new int[2]; rv_menusearch.getLocationOnScreen(location); popsearch.showAtLocation(rv_menusearch, Gravity.NO_GRAVITY, location[0], location[1] - popsearch.getHeight());
等到研究出類似bilibili動畫的時候再改好了