注册 登录
发贴工具
查看: 60|回复: 0
打印 上一主题 下一主题

[24小时收录超级好的网站] 安卓通过floatUI创建悬浮窗H5界面

[复制链接]

2380

主题

2428

帖子

1万

积分

积分
14492
跳转到指定楼层
楼主
安卓通过floatUI创建悬浮窗H5界面
安卓通过floatUI创建悬浮窗H5界面 群发软件发帖工具 安卓通过floatUI创建悬浮窗H5界面 群发软件发帖工具 安卓通过floatUI创建悬浮窗H5界面 群发软件发帖工具

  1. //通过floatUI创建悬浮窗H5界面
  2. //适用于ES5系统安卓 JavaScript引擎Rhino
  3. //基于AIWROK软件安卓开发框架
  4. //支持悬浮窗自由定位和拖拽功能

  5. function 应用配置悬浮窗() {
  6.     this.screenHeight = 1920; // 默认值  
  7.     this.screenWidth = 1080;  // 默认值
  8.     this.isExpanded = false;   // 展开状态
  9. }

  10. // 创建悬浮窗实例
  11. var 悬浮窗 = new 应用配置悬浮窗();

  12. // 创建悬浮窗方法
  13. 应用配置悬浮窗.prototype.create = function() {
  14.     try {
  15.         printl("===== 开始创建悬浮窗H5界面 =====");
  16.         
  17.         // 创建 floatUI 实例
  18.         var fui = new floatUI();
  19.         
  20.         // 获取屏幕尺寸
  21.         try {
  22.             var metrics = context.getResources().getDisplayMetrics();
  23.             this.screenHeight = metrics.heightPixels;
  24.             this.screenWidth = metrics.widthPixels;
  25.             printl("✅ 获取屏幕尺寸: " + this.screenWidth + "x" + this.screenHeight);
  26.         } catch(e) {
  27.             printl("⚠️ 获取屏幕尺寸失败,使用默认值: " + e);
  28.         }
  29.         
  30.         // 加载悬浮窗XML布局
  31.         fui.loadXML(`
  32.         <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  33.             android:layout_width="wrap_content"
  34.             android:layout_height="wrap_content"
  35.             android:background="#DD000000"
  36.             android:orientation="vertical"
  37.             android:padding="8dp"
  38.             android:elevation="10dp">
  39.             
  40.             <!-- 主按钮(始终显示) -->
  41.             <Button
  42.                 android:id="btn_main"
  43.                 android:layout_width="120dp"
  44.                 android:layout_height="40dp"
  45.                 android:text="&#128241; 应用配置"
  46.                 android:textColor="#FFFFFF"
  47.                 android:background="#4A90E2"
  48.                 android:textSize="14sp"/>
  49.                
  50.             <!-- 功能按钮区(可展开/收起) -->
  51.             <LinearLayout
  52.                 android:id="content_layout"
  53.                 android:layout_width="120dp"
  54.                 android:layout_height="wrap_content"
  55.                 android:orientation="vertical"
  56.                 android:layout_marginTop="5dp"
  57.                 android:visibility="gone">
  58.                
  59.                 <Button
  60.                     android:id="btn_mode_check"
  61.                     android:layout_width="match_parent"
  62.                     android:layout_height="35dp"
  63.                     android:text="&#128269; 模式检测"
  64.                     android:textColor="#FFFFFF"
  65.                     android:background="#28A745"
  66.                     android:layout_marginBottom="3dp"
  67.                     android:textSize="12sp"/>
  68.                     
  69.                 <Button
  70.                     android:id="btn_system_info"
  71.                     android:layout_width="match_parent"
  72.                     android:layout_height="35dp"
  73.                     android:text="&#128202; 系统状态"
  74.                     android:textColor="#FFFFFF"
  75.                     android:background="#17A2B8"
  76.                     android:layout_marginBottom="3dp"
  77.                     android:textSize="12sp"/>
  78.                     
  79.                 <Button
  80.                     android:id="btn_help"
  81.                     android:layout_width="match_parent"
  82.                     android:layout_height="35dp"
  83.                     android:text="❓ 帮助信息"
  84.                     android:textColor="#FFFFFF"
  85.                     android:background="#FFC107"
  86.                     android:layout_marginBottom="3dp"
  87.                     android:textSize="12sp"/>
  88.                     
  89.                 <Button
  90.                     android:id="btn_close"
  91.                     android:layout_width="match_parent"
  92.                     android:layout_height="35dp"
  93.                     android:text="❌ 关闭界面"
  94.                     android:textColor="#FFFFFF"
  95.                     android:background="#DC3545"
  96.                     android:textSize="12sp"/>
  97.             </LinearLayout>
  98.         </LinearLayout>
  99.         `);
  100.         
  101.         // 保存floatUI实例
  102.         this.ui = fui;
  103.         
  104.         // 设置初始位置(根据用户悬浮窗偏好,放在屏幕中央)
  105.         var centerX = (this.screenWidth - 120) / 2;  // 水平居中
  106.         var centerY = (this.screenHeight - 100) / 2; // 垂直居中
  107.         this.setPos(centerX, centerY);
  108.         
  109.         // 获取UI元素
  110.         this.btn_main = fui.findViewById("btn_main");
  111.         this.content_layout = fui.findViewById("content_layout");
  112.         this.btn_mode_check = fui.findViewById("btn_mode_check");
  113.         this.btn_system_info = fui.findViewById("btn_system_info");
  114.         this.btn_help = fui.findViewById("btn_help");
  115.         this.btn_close = fui.findViewById("btn_close");
  116.         
  117.         // 初始化按钮事件
  118.         this.initButtons();
  119.         
  120.         printl("✅ 悬浮窗H5界面创建成功");
  121.         
  122.         // 移除自动展开,避免线程错误
  123.         // 用户可以手动点击主按钮来展开功能
  124.         printl("&#128161; 请点击主按钮展开功能菜单");
  125.         toast.show("&#128161; 悬浮窗已就绪,点击主按钮展开功能");
  126.         
  127.     } catch (err) {
  128.         printl("❌ 悬浮窗创建失败: " + err);
  129.     }
  130. };

  131. // 初始化按钮事件
  132. 应用配置悬浮窗.prototype.initButtons = function() {
  133.     var self = this;
  134.    
  135.     // 主按钮点击事件(展开/收起)
  136.     this.btn_main.setOnClickListener(function() {
  137.         self.toggleExpand();
  138.     });
  139.    
  140.     // 模式检测按钮
  141.     this.btn_mode_check.setOnClickListener(function() {
  142.         printl("&#128269; 开始模式检测...");
  143.         toast.show("&#128269; 模式检测开始...");
  144.         
  145.         // 使用定时器逐步执行,避免UI线程问题
  146.         setTimeout(function() {
  147.             try {
  148.                 // HID检测
  149.                 var hidStatus = hid.isConnected();
  150.                 if (hidStatus) {
  151.                     printl("✅ HID硬件模式已启用");
  152.                     toast.show("✅ HID硬件模式已启用");
  153.                 } else {
  154.                     printl("⚠️ 使用无障碍模式");
  155.                     toast.show("⚠️ 使用无障碍模式");
  156.                 }
  157.                
  158.                 // 网络检测(延迟执行)
  159.                 setTimeout(function() {
  160.                     try {
  161.                         var networkStatus = network.isConnected();
  162.                         if (networkStatus) {
  163.                             printl("✅ 网络连接正常");
  164.                             toast.show("✅ 网络连接正常");
  165.                         } else {
  166.                             printl("❌ 网络连接异常");
  167.                             toast.show("❌ 网络连接异常");
  168.                         }
  169.                         
  170.                         // 最终结果
  171.                         setTimeout(function() {
  172.                             printl("✅ 模式检测完成");
  173.                             toast.show("✅ 模式检测完成");
  174.                         }, 1000);
  175.                     } catch (netErr) {
  176.                         printl("❌ 网络检测失败: " + netErr);
  177.                         toast.show("❌ 网络检测失败");
  178.                     }
  179.                 }, 1500);
  180.                
  181.             } catch (err) {
  182.                 printl("❌ 模式检测失败: " + err);
  183.                 toast.show("❌ 模式检测失败");
  184.             }
  185.         }, 1000);
  186.     });
  187.    
  188.     // 系统状态按钮
  189.     this.btn_system_info.setOnClickListener(function() {
  190.         printl("&#128202; 系统状态查看");
  191.         
  192.         var statusInfo = "&#128202; 系统状态信息\n";
  193.         statusInfo += "✅ 悬浮窗正常运行\n";
  194.         statusInfo += "✅ 交互功能正常\n";
  195.         statusInfo += "✅ 屏幕尺寸: " + self.screenWidth + "x" + self.screenHeight + "\n";
  196.         statusInfo += "✅ 当前位置: 屏幕中央";
  197.         
  198.         toast.show(statusInfo);
  199.         printl(statusInfo);
  200.     });
  201.    
  202.     // 帮助信息按钮
  203.     this.btn_help.setOnClickListener(function() {
  204.         var helpInfo = "❓ 帮助信息\n";
  205.         helpInfo += "• 点击主按钮可展开/收起功能\n";
  206.         helpInfo += "• 支持拖拽移动到任意位置\n";
  207.         helpInfo += "• 支持多分辨率自适应\n";
  208.         helpInfo += "• 点击关闭可退出悬浮窗";
  209.         
  210.         toast.show(helpInfo);
  211.         printl(helpInfo);
  212.     });
  213.    
  214.     // 关闭按钮
  215.     this.btn_close.setOnClickListener(function() {
  216.         printl("❌ 关闭悬浮窗");
  217.         toast.show("&#128075; 再见!悬浮窗即将关闭");
  218.         
  219.         // 使用定时器延迟关闭,避免UI线程问题
  220.         setTimeout(function() {
  221.             self.close();
  222.         }, 800);
  223.     });
  224. };

  225. // 展开/收起切换
  226. 应用配置悬浮窗.prototype.toggleExpand = function() {
  227.     if (this.isExpanded) {
  228.         // 收起
  229.         this.content_layout.setVisibility(View.GONE);
  230.         this.isExpanded = false;
  231.         printl("&#128316; 悬浮窗已收起");
  232.     } else {
  233.         // 展开
  234.         this.content_layout.setVisibility(View.VISIBLE);
  235.         this.isExpanded = true;
  236.         printl("&#128317; 悬浮窗已展开");
  237.     }
  238. };

  239. // 设置悬浮窗位置(支持自由定位)
  240. 应用配置悬浮窗.prototype.setPos = function(x, y) {
  241.     this.ui.setPosition(x, y);
  242.     printl("&#128205; 悬浮窗位置设置为: (" + x + ", " + y + ")");
  243. };

  244. // 关闭悬浮窗
  245. 应用配置悬浮窗.prototype.close = function() {
  246.     this.ui.close();
  247.     printl("✅ 悬浮窗已关闭");
  248. };

  249. // 启动悬浮窗
  250. try {
  251.     悬浮窗.create();
  252.     printl("===== 悬浮窗H5界面启动成功 =====");
  253. } catch (err) {
  254.     printl("❌ 悬浮窗启动失败: " + err);
  255. }
复制代码



unto安卓专用吐司toast倒计时到指定时间并显示剩余时间nextAIWROK软件安卓工具箱悬浮窗
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关导读了
    采集亚马逊正版群发工具有没有?
    Apr.20旅行X心语今天来说说YYPOST新功能的一个灵活用法,采集亚马逊商品信息,并且获得排名的软件,亚马逊现在越来越多客户做,淘宝的水是越来越清了,以前做电商的客户,现在都转战到外国,最赚钱的要数一些客户往亚马逊里堆了吧,拿我这个YYPOST的客户,最多的是采集,分析排名,刷价格,刷数量,改价,刷访问量等等技术

    企业发展B2B网站有什么东东软件可以发呢
    标题企业发展网B2B软件,现在虽然B2B网站收录不错,可愁的是心急的人们,他们太想一口吃撑胖子了,发帖宣传虽然不能像佛系那样淡定,但也不能像跑火车那般急躁对待,自己内容不收录,完全是自己操作内容问题,可以参考一下别人的内容是怎么弄的,然后自己要试着转变,而且收录这个内容,常常会变化的,不是一种规则就吃到老

    搜房天下房聊软件哪一个好呢
    本帖最后由 发帖软件 于 2019-5-22 16:15 编辑 2搜房天下群发房聊信息软件,开始本来打算做58同城的,但发一个就要一次点触验证码,这就让人没有感觉到存在的价值了吧,都是卖二手房和新房的搜房天下倒是可以发即时聊天信息,也没有发现他这个网站有啥子限制,登陆一个搜房天下账号,然后采集回来分类列表的网址,然后就一

    大家坛有没有好用的群发工具下载呢
    当你的笑容给我礼貌的招呼,大家坛全自动发帖软件,宣传推广是一场持久战,总是有一些人把软件用了一天,或是几个小时,就觉得自己付出太多了,那加进来的粉丝,或是流量,应该是和宣传多少成正比的,其实没有这么便宜的事,就像很多阅读量超过一百万的视频,或是电影,真正会在屏幕打赏的人不会超过三千,真正大额打赏给主

    群发正版软件中国塑料网
    中国塑料网群发软件YYPOST脚本下载地址,这个网站会有一个很奇怪的问题就是你在首页登陆无半个验证码,但在登陆网址登陆就会有一个验证码,所以我们灵活一些,在首页登陆就不用输入验证码了哈。网站秒收录比较高,但发的都是五金和建筑行业,先前有很多人都是发土建工程的大公司操作的,现在这个网站专为那个行业诞生的吧。

    OpenStreetMap网站正版2019年发帖工具下载
    本帖最后由 发帖软件 于 2019-5-21 11:13 编辑 OpenStreetMap网站全自动群发,OpenStreetMapOpenStreetMap(简称OSM,中文是公开地图)是一个网上地图协作计划,目标是创造一个内容自由且能让所有人编辑的世界地图。有的人编辑地图然后等收录,有的人发日志等收录,我们这里也是利用地图日志做为宣传的目标,简单的脚本理

    搜房天下全自动收短信全自动识别验证码注册账号软件
    房天下自动注册机,这个脚本是前几天发房聊的脚本廷伸品种,这个脚本能做到自动注册账号,自动保存账号,自动发房聊的效果,不过今天我们主要说一说怎么注册账号写脚本吧,这个搜房天天下的账号,可以发提问,可以发房聊,发论坛,发博客,还有发个人中心页都是有秒收的效果的,这样就省去了去买号,去乱花钱的效果了吧,而

    企业邮箱安卓端有什么APP软件可以发的呢
    请输入标题企业邮箱安卓发发送邮箱脚本,这个脚本是利用企业邮箱进行群发的,全程是一种模拟手工操作的过程,所以封号是很少的,而且企业邮箱群发到普通QQ邮箱不容易进垃圾箱中的,所以这个脚本也是这样的原理,不过最好是利用一些多开器,登陆多点的QQ邮箱账号会比较流畅一些,然后用软件一个一个的切换APP进行群发邮件会

    头条留评论软件有没有好用的呢?
    今天整一个今日头条留言软件,对于留言YYPOST是优势是比较大的存在,因为他往往专注一些下拉定位的优点,像今日头条这样,还是需要一些特殊下拉定位的,因为他新闻有长有短,有图有视频的,所以综合起来定位是比较难的,如果用POST也不是很轻松可以破解他的加密参数。这个脚本也是有一个不好的地方就是换号会比较麻烦,您电

    单网页生成神器
    最近新技术,网页生成机占领了整个网络的半壁江山,效果很疯狂,虽然不知道能持续多久,作为开发软件的领头者,一直在找收录的方法,一直在努力创新着,一直被人模仿,却从没有被超越过,这个网页生成机,已经出来有一段时间了,一直没有拿出来分享,醉过醉过,它是利用的一些小小收录漏洞整的,您最好用一些老站域名,进行

关闭
快速回复 返回列表 返回顶部
本站自动发贴软件,是现在最流行的做脚本软件,这种发贴工具,不但发贴收录快,而且抢占好的先机,完全自由编辑,实现针对性群发模拟操作,软件可以顶贴,也可以发贴,可以兼容支持Discuz、PHPWind、Dvbbs三大主流论坛,有手机验证码收件,邮件收发的功能,支持验证码识别,注册问题识别,多线程任务,自动上传头像,自动激活注册邮件,兼容防注册插件,本站软件原创正版,更新效率最快的原创软件。 『网络推广软件』『自动发帖软件』『 自动发帖