Android開發(fā)模仿qq視頻通話懸浮按鈕(實例代碼)
模仿qq視頻通話的懸浮按鈕的實例代碼,如下所示;
public class FloatingWindowService extends Service{
private static final String TAG="OnTouchListener";
private static View mView = null;
private static WindowManager mWindowManager = null;
private static Context mContext = null;
public static Boolean isShown = false;
public WindowManager.LayoutParams params = null;
private int pixel;
private int TheOffset;
@Override
public void onCreate() {
super.onCreate();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
pixel = intent.getIntExtra("pixel",1);
showPopupWindow(this);
return super.onStartCommand(intent, flags, startId);
}
/**
* 顯示彈出框
*
* @param context
*
*/
private void showPopupWindow(final Context context) {
if (isShown) {
return;
}
isShown = true;
// 獲取應(yīng)用的Context
mContext = context.getApplicationContext();
// 獲取WindowManager
mWindowManager = (WindowManager) mContext.getSystemService(Context.WINDOW_SERVICE);
params = new WindowManager.LayoutParams();
mView = setUpView(context);
// 類型
params.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT;
int flags=WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;
params.flags = flags;
params.format = PixelFormat.TRANSLUCENT;
params.width = WindowManager.LayoutParams.WRAP_CONTENT;
params.height = WindowManager.LayoutParams.WRAP_CONTENT;
params.gravity = Gravity.CENTER;
mWindowManager.addView(mView, params);
}
/**
* 隱藏彈出框
*/
private static void hidePopupWindow() {
if (isShown && null != mView) {
mWindowManager.removeView(mView);
isShown = false;
}
}
private int x=0;
private int y=0;
private int startX=0;
private int startY=0;
private View setUpView(final Context context) {
View view = LayoutInflater.from(context).inflate(R.layout.popupwindow,
null);
TextView tv= (TextView) view.findViewById(R.id.title);
int w = View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED);
int h = View.MeasureSpec.makeMeasureSpec(0,View.MeasureSpec.UNSPECIFIED);
tv.measure(w, h);
TheOffset=(pixel-tv.getMeasuredWidth())/2-50;
tv.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent =new Intent(context,MainActivity.class);
context.startActivity(intent);
// Toast.makeText(context,"點(diǎn)擊事件",Toast.LENGTH_LONG).show();
}
});
tv.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()){
case MotionEvent.ACTION_MOVE:
int newX= (int) (event.getRawX()-x);
int newY= (int) (event.getRawY()-y);
params.x=newX+startX;
params.y=newY+startY;
mWindowManager.updateViewLayout(mView,params);
break;
case MotionEvent.ACTION_DOWN:
x= (int) event.getRawX();
y= (int) event.getRawY();
break;
case MotionEvent.ACTION_UP:
if(params.x>=0){
params.x=TheOffset;
mWindowManager.updateViewLayout(mView,params);
}
if(params.x<=-0){
params.x=-TheOffset;
mWindowManager.updateViewLayout(mView,params);
}
Log.i(TAG,params.x+"");
Log.i(TAG,params.y+"");
//判斷 從按住到抬起時候的移動距離, 如果如果移動距離大于20 那么就攔截事件,否則就不攔截事件,主要是處理點(diǎn)擊事件的沖突
if(Math.abs(startX-params.x)>20 ||Math.abs(startY-params.y)>20 ){
//記錄上一次的偏移量
startX=params.x;
startY=params.y;
return true;
}else {
startX=params.x;
startY=params.y;
return false;
}
}
return false;
}
});
return view;
}
@Nullable
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onDestroy() {
super.onDestroy();
if (mView != null) {
isShown=false;
mWindowManager.removeView(mView);
}
}
}
Main
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findViewById(R.id.open).setOnClickListener(this);
findViewById(R.id.close).setOnClickListener(this);
}
-點(diǎn)擊開啟 關(guān)閉懸浮按鈕
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.open:
//判斷是否擁有懸浮權(quán)限
//op 的值是 0 ~ 47,其中0代表粗略定位權(quán)限,1代表精確定位權(quán)限,24代表懸浮窗權(quán)限。(具體可以看看Android源碼在android.app下就有個AppOpsManager類)
if(utils.checkOp(this,24)==0) {
Intent intent=new Intent(MainActivity.this, FloatingWindowService.class);
intent.putExtra("pixel",utils.pixel(this)[0]);
startService(intent);
}else {
//引導(dǎo)用戶進(jìn)入懸浮權(quán)限設(shè)置界面
Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION,
Uri.parse("package:" + getPackageName()));
startActivityForResult(intent, 200);
}
break;
case R.id.close:
stopService(new Intent(MainActivity.this,FloatingWindowService.class));
break;
}
}
判斷權(quán)限 -獲取屏幕的寬高
public class utils {
public static int checkOp(Context context, int op){
final int version = Build.VERSION.SDK_INT;
if (version >= 19){
Object object = context.getSystemService("appops");
Class c = object.getClass();
try {
Class[] cArg = new Class[3];
cArg[0] = int.class;
cArg[1] = int.class;
cArg[2] = String.class;
Method lMethod = c.getDeclaredMethod("checkOp", cArg);
return (Integer) lMethod.invoke(object, op, Binder.getCallingUid(), context.getPackageName());
} catch(NoSuchMethodException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (InvocationTargetException e) {
e.printStackTrace();
}
}
return -1;
}
/**
* 獲取屏幕的寬高
* @param context
* @return
*/
public static int[] pixel(Activity context){
DisplayMetrics dm = new DisplayMetrics();
context.getWindowManager().getDefaultDisplay().getMetrics(dm);
return new int[]{dm.widthPixels,dm.heightPixels};
}
}
--popupwindow填充布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:id="@+id/popup_window"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@android:color/white"
android:orientation="vertical" >
<TextView
android:background="@mipmap/ic_launcher"
android:id="@+id/title"
android:layout_width="50dp"
android:layout_height="50dp"/>
</LinearLayout>
</LinearLayout>
以上所述是小編給大家介紹的Android開發(fā)模仿qq視頻通話懸浮按鈕(實例代碼),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Android實現(xiàn)pdf在線預(yù)覽或本地預(yù)覽的方法
下面小編就為大家分享一篇Android實現(xiàn)pdf在線預(yù)覽或本地預(yù)覽的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
Android實現(xiàn)調(diào)用攝像頭進(jìn)行拍照功能
這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)調(diào)用攝像頭進(jìn)行拍照功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04
Android如何基于坐標(biāo)對View進(jìn)行模擬點(diǎn)擊事件詳解
這篇文章主要給大家介紹了關(guān)于Android如何基于坐標(biāo)對View進(jìn)行模擬點(diǎn)擊事件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03
TextView長按復(fù)制的實現(xiàn)方法(總結(jié))
下面小編就為大家?guī)硪黄猅extView長按復(fù)制的實現(xiàn)方法(總結(jié))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
Android實現(xiàn)在線預(yù)覽office文檔的示例詳解
在移動端展示在線 Office 文檔(如 Word、Excel、PPT)是一項常見需求,這篇文章為大家重點(diǎn)介紹了兩種方案的實現(xiàn)方法,希望對大家有一定的幫助2025-04-04
Android車載多媒體開發(fā)MediaSession框架示例詳解
這篇文章主要為大家介紹了Android車載多媒體開發(fā)MediaSession框架示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
Android登陸界面實現(xiàn)清除輸入框內(nèi)容和震動效果
這篇文章主要介紹了Android登陸界面實現(xiàn)清除輸入框內(nèi)容和震動效果,感興趣的小伙伴們可以參考一下2015-12-12

