欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

android懸浮窗,android懸浮窗源碼

android 系統(tǒng)級的懸浮窗實現(xiàn)

當(dāng)我們在使用的app的時候,如果需要實時觀測到某個功能的實時進(jìn)度并且不影響其他的操作的時候或者不影響使用其他應(yīng)用的時候,系統(tǒng)級的懸浮球是個非常不錯的選擇。

成都創(chuàng)新互聯(lián)公司是一家專業(yè)的成都網(wǎng)站建設(shè)公司,我們專注成都網(wǎng)站建設(shè)、成都做網(wǎng)站、網(wǎng)絡(luò)營銷、企業(yè)網(wǎng)站建設(shè),買友情鏈接廣告投放為企業(yè)客戶提供一站式建站解決方案,能帶給客戶新的互聯(lián)網(wǎng)理念。從網(wǎng)站結(jié)構(gòu)的規(guī)劃UI設(shè)計到用戶體驗提高,創(chuàng)新互聯(lián)力求做到盡善盡美。

public class QueueUpFloatService extends Service {

/**

* 啟動服務(wù)并傳值

*

* @param activity 啟動服務(wù)的activity

* @param modeBean 數(shù)據(jù)對象

*/

public static void launchService(Activity activity, ModeBean modeBean) {

try {

Intent intent =new Intent(activity, QueueUpFloatService.class);

? ? Bundle bundle =new Bundle();

? ? bundle.putSerializable(KEY_MODEL, modeBean);

? ? intent.putExtras(bundle);

? ? activity.startService(intent);

}catch (Exception e) {

e.printStackTrace();

}

}

@Override

public void onCreate() {

super.onCreate();

}

@Override

public IBinder onBind(Intent intent) {

return null;

}

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

return super.onStartCommand(intent, flags, startId);

}

@Override

public void onDestroy() {

super.onDestroy();

}

}

@Override

public void onCreate() {

super.onCreate();

//加一點簡單的動畫?

buttonScale = (ScaleAnimation) AnimationUtils.loadAnimation(this, R.anim.anim_float);

windowManager = (WindowManager) getSystemService(WINDOW_SERVICE);

layoutParams =new WindowManager.LayoutParams();

if (Build.VERSION.SDK_INT = Build.VERSION_CODES.O) {

layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;

}else {

layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;

}

layoutParams.format = PixelFormat.RGBA_8888;

layoutParams.gravity = Gravity.LEFT | Gravity.TOP;

layoutParams.flags = WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL | ????????????WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE;

layoutParams.width = ScreenUtils.dp2px(66);

layoutParams.height = ScreenUtils.dp2px(66);

layoutParams.x = ScreenUtils.getRealWidth() - ScreenUtils.dp2px(60);

layoutParams.y = ScreenUtils.deviceHeight() *2 /3;

}

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

ModeBean modeBean = (ModeBean) intent.getExtras().getSerializable(KEY_MODEL);

LayoutInflater layoutInflater = LayoutInflater.from(this);

floatView = layoutInflater.inflate(R.layout.view_float, null);

RelativeLayout rlFloatParent =floatView.findViewById(R.id.rl_float_parent);

rlFloatParent.startAnimation(buttonScale);

TextView tvIndex =floatView.findViewById(R.id.tv_queue_index);

tvIndex.setText(modeBean.title);

floatView.findViewById(R.id.iv_close_float).setOnClickListener(v - stopSelf());

//修改懸浮球的滑動實現(xiàn)

floatView.setOnTouchListener(new FloatingOnTouchListener());

windowManager.addView(floatView, layoutParams);

return super.onStartCommand(intent, flags, startId);

}

private class FloatingOnTouchListenerimplements View.OnTouchListener {

private int x;

private int y;

private long downTime;

@SuppressLint("ClickableViewAccessibility")

@Override

public boolean onTouch(View view, MotionEvent event) {

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN:

downTime = System.currentTimeMillis();

? ? ? ? ? ? ????????x = (int) event.getRawX();

? ? ? ? ? ????????? y = (int) event.getRawY();

break;

? ? ? ????? case MotionEvent.ACTION_MOVE:

int nowX = (int) event.getRawX();

? ? ????????? ? ? ? int nowY = (int) event.getRawY();

? ? ? ????????? ? ? int movedX = nowX -x;

? ? ? ? ????????? ? int movedY = nowY -y;

? ? ? ? ????????? ? x = nowX;

? ? ? ? ? ????????? y = nowY;

? ? ? ? ? ????????? layoutParams.x =layoutParams.x + movedX;

? ? ? ? ? ? ????????layoutParams.y =layoutParams.y + movedY;

? ? ? ? ? ? ? ? ? ? windowManager.updateViewLayout(view, layoutParams);

break;

? ? ? ????? case MotionEvent.ACTION_UP:

/* *

* 這里根據(jù)手指按下和抬起的時間差來判斷點擊事件還是滑動事件

* */

? ? ? ? ????????? ? if ((System.currentTimeMillis() -downTime) 200) {

? ? ? ? ? ? ? ? ? ? ? ? ? ? //檢測應(yīng)用在前臺還是后臺

if (AppUtils.isAppIsInBackground()) {

AppUtils.moveToFront(CloseActivityUtils.activityList.get(CloseActivityUtils.activityList.size() -1).getClass());

? ? ? ? ? ? ? ????????????? } else {

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? //檢測棧頂是否為SecondActivity 不是就打開SecondActivity

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if (!CloseActivityUtils.activityList.get(CloseActivityUtils.activityList.size() -1)

? ? ? ? ? ? ? ? ? ? ? ? ? ? ????????????????.getClass().getSimpleName().contains("SecondActivity")) {

? ? ? ? ? ? ? ? ? ? ? ? ? ????????? SecondActivity.launchActivity(CloseActivityUtils.activityList.get(CloseActivityUtils.activityList.size() -1));

? ? ? ? ? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? ? }

}

break;

? ? ? ? default:

break;

? ? }

? ?return false;

}

}

@Override

public void onDestroy() {

super.onDestroy();

if (null ==floatView) {

return;

? ? ? ? ? ?}

windowManager.removeView(floatView);

? ? ? ? windowManager=null;

}

android懸浮窗及權(quán)限

懸浮窗權(quán)限是Android提供的權(quán)限中的特殊權(quán)限,要申請后再使用,否則會導(dǎo)致彈框不能顯示、程序崩潰等問題

有的文章說MIUI系統(tǒng)可設(shè)置為 WindowManager.LayoutParams.TYPE_TOAST 避開懸浮框權(quán)限的申請,我的實踐經(jīng)驗是不要這樣設(shè)置,否則利用參考文獻(xiàn)中的方法操作后dialog還是顯示不出來

Android 懸浮窗權(quán)限各機型各系統(tǒng)適配大全

Android懸浮窗及權(quán)限 by JustDo23

github項目

android8.0之懸浮窗和通知欄

懸浮窗:

使用場景:例如微信在視頻的時候,點擊Home鍵,視頻小窗口仍然會在屏幕上顯示;

? ? 注意事項:

1、一般需要在后臺進(jìn)行操作的時候才需要懸浮窗,這樣懸浮窗才有意義;

? ? ? ? ? ? 2、API Level = 23的時候,需要在AndroidManefest.xml文件中聲明權(quán)限SYSTEM_ALERT_WINDOW才能在其他應(yīng)用上繪制控件。

uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" /;除了這個權(quán)限外,我們還需要在系統(tǒng)設(shè)置里面對本應(yīng)用進(jìn)行設(shè)置懸浮窗權(quán)限。該權(quán)限在應(yīng)用中需要啟動Settings.ACTION_MANAGE_OVERLAY_PERMISSION來讓用戶手動設(shè)置權(quán)限:startActivityForResult(new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName())), REQUEST_CODE);

? ? ? ? ? ? 3、LayoutParam設(shè)置:LayoutParam里的type變量。這個變量是用來指定窗口類型的。在設(shè)置這個變量時,需要注意一個坑,那就是需要對不同版本的Android系統(tǒng)進(jìn)行適配。

if (Build.VERSION.SDK_INT = Build.VERSION_CODES.O) {

layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;

} else {

layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;

};在Android 8.0之前,懸浮窗口設(shè)置可以為TYPE_PHONE,這種類型是用于提供用戶交互操作的非應(yīng)用窗口。

而Android 8.0對系統(tǒng)和API行為做了修改,包括使用SYSTEM_ALERT_WINDOW權(quán)限的應(yīng)用無法再使用一下窗口類型來在其他應(yīng)用和窗口上方顯示提醒窗口:

- TYPE_PHONE

- TYPE_PRIORITY_PHONE

- TYPE_SYSTEM_ALERT

- TYPE_SYSTEM_OVERLAY

- TYPE_SYSTEM_ERROR

如果需要實現(xiàn)在其他應(yīng)用和窗口上方顯示提醒窗口,那么必須該為TYPE_APPLICATION_OVERLAY的新類型;

如果在Android 8.0以上版本仍然使用TYPE_PHONE類型的懸浮窗口,則會出現(xiàn)如下異常信息:

android.view.WindowManager$BadTokenException: Unable to add window android.view.ViewRootImpl$W@f8ec928 -- permission denied for window type 2002;

具體實現(xiàn):

? ? 1、Activity:

public void startFloatingService(View view) {????????

...

if (!Settings.canDrawOverlays(this)) {

? ? Toast.makeText(this, "當(dāng)前無權(quán)限,請授權(quán)", Toast.LENGTH_SHORT);

? ? startActivityForResult(new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName())), 0);

} else {

? ? startService(new Intent(MainActivity.this, FloatingService.class));

}

}

@Override

protected void onActivityResult(int requestCode, int resultCode, Intent data) {

if (requestCode == 0) {

? ? if (!Settings.canDrawOverlays(this)) {

? ? ? ? Toast.makeText(this, "授權(quán)失敗", Toast.LENGTH_SHORT).show();

? ? } else {

? ? ? ? Toast.makeText(this, "授權(quán)成功", Toast.LENGTH_SHORT).show();

? ? ? ? startService(new Intent(MainActivity.this, FloatingService.class));

? ? }

}

}

2、service:

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

showFloatingWindow();

return super.onStartCommand(intent, flags, startId);

}

private void showFloatingWindow() {

if (Settings.canDrawOverlays(this)) {

? ? // 獲取WindowManager服務(wù)

? ? WindowManager windowManager = (WindowManager) getSystemService(WINDOW_SERVICE);

? ? // 新建懸浮窗控件

? ? Button button = new Button(getApplicationContext());

? ? button.setText("Floating Window");

? ? button.setBackgroundColor(Color.BLUE);

? ? // 設(shè)置LayoutParam

? ? WindowManager.LayoutParams layoutParams = new WindowManager.LayoutParams();

? ? if (Build.VERSION.SDK_INT = Build.VERSION_CODES.O) {

? ? ? ? layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;

? ? } else {

? ? ? ? layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;

? ? }

? ? layoutParams.format = PixelFormat.RGBA_8888;

? ? layoutParams.width = 500;

? ? layoutParams.height = 100;

? ? layoutParams.x = 300;

? ? layoutParams.y = 300;

? ? // 將懸浮窗控件添加到WindowManager

? ? windowManager.addView(button, layoutParams);

}

}

? ? 效果展示:

???

標(biāo)題名稱:android懸浮窗,android懸浮窗源碼
網(wǎng)頁路徑:http://chinadenli.net/article32/dsggdsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣電子商務(wù)建站公司外貿(mào)建站靜態(tài)網(wǎng)站ChatGPT

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)