悬浮按钮
按钮 悬浮
2023-09-14 08:59:11 时间
效果图
//将dp转换为px public static int dip2px(Context context, float dpValue) { final float scale = context.getResources().getDisplayMetrics().density; return (int) (dpValue * scale + 0.5f); } //浮动图片监听 private void initListener() { //弹出对话框 jianwen.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { View view = LayoutInflater.from(getActivity()).inflate(R.layout.quick_layout, null); bbs = (TextView) view.findViewById(R.id.bbs); dailyattendance = (TextView) view.findViewById(R.id.dailyattendance); Jump.jumpToWeb(getActivity(), bbs, bbs.getText().toString(), Contents.MINE_LUNTAN_URL, false); Jump.jumpToWeb(getActivity(), dailyattendance, dailyattendance.getText().toString(), Contents.MINE_REGISTRATION_URL, false); AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); builder.setView(view); AlertDialog dialog = builder.create(); Window window = dialog.getWindow(); WindowManager.LayoutParams attributes = window.getAttributes(); attributes.alpha = 0.6f; //设置对话框透明度 attributes.gravity = Gravity.BOTTOM; //设置对话框的位置 attributes.width = LinearLayout.LayoutParams.MATCH_PARENT; window.setAttributes(attributes); dialog.show(); } }); //移动浮动图片 jianwen.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { int widthPixels = getResources().getDisplayMetrics().widthPixels; //屏幕宽度 int heightPixels = getResources().getDisplayMetrics().heightPixels; //屏幕高度 int width = v.getWidth(); //图片宽带 int height = v.getHeight(); //图片高度 switch (event.getAction()) { case MotionEvent.ACTION_MOVE: //图片的绝对位置 float x = event.getRawX(); float y = event.getRawY(); //避免图片滑出屏幕 if (x > widthPixels - width) { x = widthPixels - width; } if (y > heightPixels - height - dip2px(getContext(), 75)) { y = heightPixels - height - dip2px(getContext(), 75); } v.setX(x); v.setY(y); break; } return false; //表示还可以监听其他事件 } }); }
相关文章
- JavaScript禁用浏览器后退按钮
- 【图文教程】不需代码!Figma里这样完成悬浮FAB按钮制作,半小时搞定!
- odoo 给列表视图添加按钮实现数据文件导入
- 【Flutter】Flutter 照片墙 ( Center 组件 | Wrap 组件 | ClipRRect 组件 | Stack 组件 | Positioned 组件 | 按钮组合组件 )
- django admin 列表禁用删除操作,编辑页面禁用删除按钮
- [android] 切换按钮-自定义控件详解手机开发
- 如何用jQuery禁用浏览器的前进后退按钮详解编程语言
- SELECTION-SCREEN 加按钮详解编程语言
- abap中选择屏幕上添加按钮,按钮上添加文字和图片,并添加响应事件详解编程语言
- Microsoft Edge网页小部件获得浮动按钮和搜索布局优化
- 按钮里的字可以换行吗
- 图片自动播放也可通过按钮控制显示
- jQuery实现多按钮单击变色
- DevExpress实现自定义GridControl中按钮文字内容的方法