編輯:關於android開發
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical" android:background="#ffffff" android:padding="20dp" > <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:clickable="true" android:gravity="center" android:textColor="@android:color/holo_orange_dark" android:text="確定" /> <TextView android:layout_marginTop="20dp" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginBottom="10dp" android:clickable="true" android:gravity="center" android:text="取消" /> </LinearLayout>
public class MyPopupWindow extends PopupWindow {
在styles.xml自定義樣式,動畫
<style name="MyPopupWindow"> <item name="android:windowEnterAnimation">@anim/pop_in</item> <item name="android:windowExitAnimation">@anim/pop_out</item> </style>
pop_in
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <!-- 平移 <translate android:duration="5000" android:fromXDelta="100%" android:toXDelta="0"/> --> <scale android:fromXScale="0" android:fromYScale="0" android:pivotX="50%" android:pivotY="50%" android:toXScale="0.8" android:toYScale="0.5" android:duration="200"/> <!-- fromXScale fromYScale 起始時X,Y座標, pivotX pivotY 動畫起始位置,相對於屏幕的百分比,兩個都為50%表示動畫從屏幕中間開始 toXScale toYScale 動畫最終縮放的倍數, 1.0為正常大小,大於1.0放大 duration 動畫持續時間 --> <!--透明度--> <alpha android:duration="200" android:fromAlpha="0.0" android:toAlpha="1.0"/> </set>
pop_out
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <!-- <translate android:duration="5000" android:fromXDelta="0" android:toXDelta="100%"/>--> <scale android:fromXScale="0.8" android:fromYScale="0.5" android:pivotX="50%" android:pivotY="50%" android:toXScale="0" android:toYScale="0" android:duration="200"/> <alpha android:duration="200" android:fromAlpha="1.0" android:toAlpha="0.0"/> </set>
super(context); this.mContext=context; //打氣筒 mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); //打氣 mContentView = mInflater.inflate(R.layout.layout_dialog,null); //設置View setContentView(mContentView); //設置寬與高 setWidth(WindowManager.LayoutParams.MATCH_PARENT); setHeight(WindowManager.LayoutParams.WRAP_CONTENT); /** * 設置進出動畫 */ setAnimationStyle(R.style.MyPopupWindow); /** * 設置背景只有設置了這個才可以點擊外邊和BACK消失 */ setBackgroundDrawable(new ColorDrawable()); /** * 設置可以獲取集點 */ setFocusable(true); /** * 設置點擊外邊可以消失 */ setOutsideTouchable(true); /** *設置可以觸摸 */ setTouchable(true); /** * 設置點擊外部可以消失 */ setTouchInterceptor(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { /** * 判斷是不是點擊了外部 */ if(event.getAction()==MotionEvent.ACTION_OUTSIDE){ return true; } //不是點擊外部 return false; } });
public void displayDialog(View view){ MyPopupWindow myPopupWindow = new MyPopupWindow(this); myPopupWindow.showAsDropDown(mBtnDispaly,0,0); lightOff(); /** * 消失時屏幕變亮 */ myPopupWindow.setOnDismissListener(new PopupWindow.OnDismissListener() { @Override public void onDismiss() { WindowManager.LayoutParams layoutParams = getWindow().getAttributes(); layoutParams.alpha=1.0f; getWindow().setAttributes(layoutParams); } }); } /** * 顯示時屏幕變暗 */ private void lightOff() { WindowManager.LayoutParams layoutParams = getWindow().getAttributes(); layoutParams.alpha=0.3f; getWindow().setAttributes(layoutParams); }
package liu.basedemo.view; import android.content.Context; import android.graphics.drawable.ColorDrawable; import android.view.LayoutInflater; import android.view.MotionEvent; import android.view.View; import android.view.WindowManager; import android.widget.PopupWindow; import liu.basedemo.R; /** * 學習PopupWindow * Created by 劉楠 on 2016/8/1 0001.17:42 */ public class MyPopupWindow extends PopupWindow { Context mContext; private LayoutInflater mInflater; private View mContentView; public MyPopupWindow(Context context) { super(context); this.mContext=context; //打氣筒 mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); //打氣 mContentView = mInflater.inflate(R.layout.layout_dialog,null); //設置View setContentView(mContentView); //設置寬與高 setWidth(WindowManager.LayoutParams.MATCH_PARENT); setHeight(WindowManager.LayoutParams.WRAP_CONTENT); /** * 設置進出動畫 */ setAnimationStyle(R.style.MyPopupWindow); /** * 設置背景只有設置了這個才可以點擊外邊和BACK消失 */ setBackgroundDrawable(new ColorDrawable()); /** * 設置可以獲取集點 */ setFocusable(true); /** * 設置點擊外邊可以消失 */ setOutsideTouchable(true); /** *設置可以觸摸 */ setTouchable(true); /** * 設置點擊外部可以消失 */ setTouchInterceptor(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { /** * 判斷是不是點擊了外部 */ if(event.getAction()==MotionEvent.ACTION_OUTSIDE){ return true; } //不是點擊外部 return false; } }); /** * 初始化View與監聽器 */ initView(); initListener(); } private void initView() { } private void initListener() { } }
自定義ZXing二維碼掃描界面並解決取景框拉伸等問題,zxing拉伸先看效果 掃描內容是下面這張,二維碼是用zxing庫生成的 由於改了好
Android中自定義視圖View之---進階篇(Canvas的使用) 一、前言 那麼今天,我們繼續來看一篇關於Android中的UI篇,如何自定義視圖View的進階篇,
算法—8.有序數組中的二分查找,算法數組二分 1.具體算法 /** * 算法3.2 二分查找(基於有序數組) * Created by huazhou on 201
Binder中的asInterface解析,binderasinterface在使用AIDL通信的時候,在Stub類中都會生成一個asInterface函數,以《Andr