B2B网络软件

标题: AIWROK安卓脚本对象高级实用示例 [打印本页]

作者: YYPOST群发软件    时间: 前天 06:45
标题: AIWROK安卓脚本对象高级实用示例
AIWROK安卓脚本对象高级实用示例
AIWROK安卓脚本对象高级实用示例 B2B网络软件

AIWROK安卓脚本对象高级实用示例 B2B网络软件
  1. //交流QQ群: 711841924 (群一) / 528816639 (安卓内测群)

  2. // AIWROK软件 - JavaScript对象高级应用实例
  3. // 基于面向对象思想设计的自动化任务管理系统
  4. // 演示如何在AIWROK中使用对象、属性和方法构建复杂应用

  5. /**
  6. * =============================================================================
  7. * AIWROK 自动化任务管理器 - 完整示例
  8. * =============================================================================
  9. * 本示例展示如何使用JavaScript对象封装复杂的自动化逻辑
  10. * 包含:任务管理、配置管理、日志系统、状态监控等模块
  11. *
  12. * 兼容性:Rhino 引擎 (ES5)
  13. * 平台:AIWROK 安卓自动化软件
  14. * =============================================================================
  15. */

  16. // =============================================================================
  17. // 第一部分:配置管理对象 (ConfigManager)
  18. // =============================================================================

  19. /**
  20. * 配置管理器对象
  21. * 封装AIWROK的config读写功能,提供更便捷的接口
  22. */
  23. var ConfigManager = {
  24.     // 属性:配置文件路径
  25.     configPath: '/sdcard/aiwrok_task_config.ini',
  26.    
  27.     // 属性:缓存的配置数据
  28.     cache: {},
  29.    
  30.     // 方法:初始化配置
  31.     init: function() {
  32.         printl('配置管理器初始化...');
  33.         this.cache = {};
  34.         return true;
  35.     },
  36.    
  37.     // 方法:读取配置(带缓存)
  38.     get: function(key, defaultValue) {
  39.         // 先检查缓存
  40.         if (this.cache.hasOwnProperty(key)) {
  41.             return this.cache[key];
  42.         }
  43.         
  44.         // 从文件读取
  45.         try {
  46.             var value = config.getConfig(this.configPath, key, defaultValue);
  47.             this.cache[key] = value; // 存入缓存
  48.             return value;
  49.         } catch (e) {
  50.             printl('读取配置失败 [' + key + ']: ' + e);
  51.             return defaultValue;
  52.         }
  53.     },
  54.    
  55.     // 方法:写入配置
  56.     set: function(key, value) {
  57.         try {
  58.             config.setConfig(this.configPath, key, value.toString());
  59.             this.cache[key] = value.toString(); // 更新缓存
  60.             return true;
  61.         } catch (e) {
  62.             printl('写入配置失败 [' + key + ']: ' + e);
  63.             return false;
  64.         }
  65.     },
  66.    
  67.     // 方法:批量读取配置
  68.     loadAll: function(keys) {
  69.         var result = {};
  70.         for (var i = 0; i < keys.length; i++) {
  71.             var key = keys[i];
  72.             result[key] = this.get(key, '');
  73.         }
  74.         return result;
  75.     },
  76.    
  77.     // 方法:批量写入配置
  78.     saveAll: function(configObj) {
  79.         var success = true;
  80.         for (var key in configObj) {
  81.             if (configObj.hasOwnProperty(key)) {
  82.                 if (!this.set(key, configObj[key])) {
  83.                     success = false;
  84.                 }
  85.             }
  86.         }
  87.         return success;
  88.     },
  89.    
  90.     // 方法:清除缓存
  91.     clearCache: function() {
  92.         this.cache = {};
  93.         printl('配置缓存已清除');
  94.     }
  95. };

  96. // =============================================================================
  97. // 第二部分:日志管理对象 (Logger)
  98. // =============================================================================

  99. /**
  100. * 日志管理器对象
  101. * 提供统一的日志输出接口,支持不同级别和格式
  102. */
  103. var Logger = {
  104.     // 属性:日志级别常量
  105.     LEVEL_DEBUG: 0,
  106.     LEVEL_INFO: 1,
  107.     LEVEL_WARN: 2,
  108.     LEVEL_ERROR: 3,
  109.    
  110.     // 属性:当前日志级别
  111.     currentLevel: 1, // 默认INFO级别
  112.    
  113.     // 属性:是否启用时间戳
  114.     enableTimestamp: true,
  115.    
  116.     // 属性:日志历史记录
  117.     history: [],
  118.    
  119.     // 属性:最大历史记录数
  120.     maxHistory: 100,
  121.    
  122.     // 方法:设置日志级别
  123.     setLevel: function(level) {
  124.         this.currentLevel = level;
  125.         printl('日志级别设置为: ' + level);
  126.     },
  127.    
  128.     // 方法:DEBUG级别日志
  129.     debug: function(message) {
  130.         if (this.currentLevel <= this.LEVEL_DEBUG) {
  131.             this.log('DEBUG', message);
  132.         }
  133.     },
  134.    
  135.     // 方法:INFO级别日志
  136.     info: function(message) {
  137.         if (this.currentLevel <= this.LEVEL_INFO) {
  138.             this.log('INFO', message);
  139.         }
  140.     },
  141.    
  142.     // 方法:WARN级别日志
  143.     warn: function(message) {
  144.         if (this.currentLevel <= this.LEVEL_WARN) {
  145.             this.log('WARN', message);
  146.         }
  147.     },
  148.    
  149.     // 方法:ERROR级别日志
  150.     error: function(message) {
  151.         if (this.currentLevel <= this.LEVEL_ERROR) {
  152.             this.log('ERR', message);
  153.         }
  154.     },
  155.    
  156.     // 内部方法:统一日志输出
  157.     log: function(level, message) {
  158.         var timestamp = '';
  159.         if (this.enableTimestamp) {
  160.             var now = new Date();
  161.             timestamp = '[' + this.formatDate(now) + '] ';
  162.         }
  163.         
  164.         var logMessage = timestamp + '[' + level + '] ' + message;
  165.         printl(logMessage);
  166.         
  167.         // 保存到历史记录
  168.         this.history.push({
  169.             time: new Date(),
  170.             level: level,
  171.             message: message
  172.         });
  173.         
  174.         // 限制历史记录数量
  175.         if (this.history.length > this.maxHistory) {
  176.             this.history.shift();
  177.         }
  178.     },
  179.    
  180.     // 方法:格式化日期
  181.     formatDate: function(date) {
  182.         var year = date.getFullYear();
  183.         var month = ('0' + (date.getMonth() + 1)).slice(-2);
  184.         var day = ('0' + date.getDate()).slice(-2);
  185.         var hours = ('0' + date.getHours()).slice(-2);
  186.         var minutes = ('0' + date.getMinutes()).slice(-2);
  187.         var seconds = ('0' + date.getSeconds()).slice(-2);
  188.         return year + '-' + month + '-' + day + ' ' + hours + ':' + minutes + ':' + seconds;
  189.     },
  190.    
  191.     // 方法:获取最近的日志
  192.     getRecentLogs: function(count) {
  193.         count = count || 10;
  194.         var start = Math.max(0, this.history.length - count);
  195.         return this.history.slice(start);
  196.     },
  197.    
  198.     // 方法:清空日志历史
  199.     clearHistory: function() {
  200.         this.history = [];
  201.         printl('日志历史已清空');
  202.     }
  203. };

  204. // =============================================================================
  205. // 第三部分:任务对象 (Task)
  206. // =============================================================================

  207. /**
  208. * 任务对象构造函数
  209. * 表示一个可执行的自动化任务
  210. */
  211. function Task(name, description) {
  212.     // 属性:任务基本信息
  213.     this.name = name || '未命名任务';
  214.     this.description = description || '';
  215.     this.status = 'pending'; // pending, running, completed, failed, paused
  216.     this.startTime = null;
  217.     this.endTime = null;
  218.     this.duration = 0;
  219.     this.retryCount = 0;
  220.     this.maxRetry = 3;
  221.    
  222.     // 属性:任务执行函数
  223.     this.executeFunc = null;
  224.    
  225.     // 属性:任务回调
  226.     this.onComplete = null;
  227.     this.onError = null;
  228. }

  229. // 方法:设置执行函数
  230. Task.prototype.setExecuteFunction = function(func) {
  231.     this.executeFunc = func;
  232.     return this; // 支持链式调用
  233. };

  234. // 方法:设置最大重试次数
  235. Task.prototype.setMaxRetry = function(count) {
  236.     this.maxRetry = count;
  237.     return this;
  238. };

  239. // 方法:设置完成回调
  240. Task.prototype.setOnComplete = function(callback) {
  241.     this.onComplete = callback;
  242.     return this;
  243. };

  244. // 方法:设置错误回调
  245. Task.prototype.setOnError = function(callback) {
  246.     this.onError = callback;
  247.     return this;
  248. };

  249. // 方法:执行任务
  250. Task.prototype.run = function() {
  251.     if (!this.executeFunc) {
  252.         Logger.error('任务 [' + this.name + '] 没有设置执行函数');
  253.         return false;
  254.     }
  255.    
  256.     if (this.status === 'running') {
  257.         Logger.warn('任务 [' + this.name + '] 正在运行中');
  258.         return false;
  259.     }
  260.    
  261.     try {
  262.         // 更新状态
  263.         this.status = 'running';
  264.         this.startTime = new Date();
  265.         Logger.info('任务 [' + this.name + '] 开始执行');
  266.         
  267.         // 执行任务函数
  268.         var result = this.executeFunc();
  269.         
  270.         // 更新状态
  271.         this.endTime = new Date();
  272.         this.duration = this.endTime - this.startTime;
  273.         this.status = 'completed';
  274.         
  275.         Logger.info('任务 [' + this.name + '] 执行完成,耗时: ' + this.duration + 'ms');
  276.         
  277.         // 调用完成回调
  278.         if (this.onComplete) {
  279.             this.onComplete(result);
  280.         }
  281.         
  282.         return true;
  283.     } catch (e) {
  284.         this.status = 'failed';
  285.         this.endTime = new Date();
  286.         this.duration = this.endTime - this.startTime;
  287.         
  288.         Logger.error('任务 [' + this.name + '] 执行失败: ' + e);
  289.         
  290.         // 重试逻辑
  291.         if (this.retryCount < this.maxRetry) {
  292.             this.retryCount++;
  293.             Logger.warn('任务 [' + this.name + '] 第' + this.retryCount + '次重试');
  294.             sleep.millisecond(1000); // 等待1秒后重试
  295.             return this.run();
  296.         }
  297.         
  298.         // 调用错误回调
  299.         if (this.onError) {
  300.             this.onError(e);
  301.         }
  302.         
  303.         return false;
  304.     }
  305. };

  306. // 方法:暂停任务
  307. Task.prototype.pause = function() {
  308.     if (this.status === 'running') {
  309.         this.status = 'paused';
  310.         Logger.info('任务 [' + this.name + '] 已暂停');
  311.         return true;
  312.     }
  313.     return false;
  314. };

  315. // 方法:恢复任务
  316. Task.prototype.resume = function() {
  317.     if (this.status === 'paused') {
  318.         this.status = 'running';
  319.         Logger.info('任务 [' + this.name + '] 已恢复');
  320.         return true;
  321.     }
  322.     return false;
  323. };

  324. // 方法:重置任务
  325. Task.prototype.reset = function() {
  326.     this.status = 'pending';
  327.     this.startTime = null;
  328.     this.endTime = null;
  329.     this.duration = 0;
  330.     this.retryCount = 0;
  331.     Logger.info('任务 [' + this.name + '] 已重置');
  332. };

  333. // 方法:获取任务信息
  334. Task.prototype.getInfo = function() {
  335.     return {
  336.         name: this.name,
  337.         description: this.description,
  338.         status: this.status,
  339.         startTime: this.startTime ? this.startTime.toLocaleString() : null,
  340.         endTime: this.endTime ? this.endTime.toLocaleString() : null,
  341.         duration: this.duration,
  342.         retryCount: this.retryCount,
  343.         maxRetry: this.maxRetry
  344.     };
  345. };

  346. // 方法:打印任务信息
  347. Task.prototype.printInfo = function() {
  348.     var info = this.getInfo();
  349.     printl('===== 任务信息 =====');
  350.     printl('名称: ' + info.name);
  351.     printl('描述: ' + info.description);
  352.     printl('状态: ' + this.getStatusText(info.status));
  353.     printl('开始时间: ' + (info.startTime || '未开始'));
  354.     printl('结束时间: ' + (info.endTime || '未结束'));
  355.     printl('耗时: ' + info.duration + 'ms');
  356.     printl('重试次数: ' + info.retryCount + '/' + info.maxRetry);
  357.     printl('===================');
  358. };

  359. // 辅助方法:状态文本转换
  360. Task.prototype.getStatusText = function(status) {
  361.     var statusMap = {
  362.         'pending': '等待中',
  363.         'running': '运行中',
  364.         'completed': '已完成',
  365.         'failed': '失败',
  366.         'paused': '已暂停'
  367.     };
  368.     return statusMap[status] || status;
  369. };

  370. // =============================================================================
  371. // 第四部分:任务管理器对象 (TaskManager)
  372. // =============================================================================

  373. /**
  374. * 任务管理器对象
  375. * 管理多个任务的执行、调度和监控
  376. */
  377. var TaskManager = {
  378.     // 属性:任务列表
  379.     tasks: [],
  380.    
  381.     // 属性:当前运行的任务索引
  382.     currentTaskIndex: -1,
  383.    
  384.     // 属性:是否自动执行下一个任务
  385.     autoExecuteNext: true,
  386.    
  387.     // 方法:添加任务
  388.     addTask: function(task) {
  389.         if (!(task instanceof Task)) {
  390.             Logger.error('添加的任务不是Task对象');
  391.             return false;
  392.         }
  393.         this.tasks.push(task);
  394.         Logger.info('已添加任务: ' + task.name);
  395.         return true;
  396.     },
  397.    
  398.     // 方法:移除任务
  399.     removeTask: function(taskName) {
  400.         for (var i = 0; i < this.tasks.length; i++) {
  401.             if (this.tasks[i].name === taskName) {
  402.                 this.tasks.splice(i, 1);
  403.                 Logger.info('已移除任务: ' + taskName);
  404.                 return true;
  405.             }
  406.         }
  407.         Logger.warn('未找到任务: ' + taskName);
  408.         return false;
  409.     },
  410.    
  411.     // 方法:获取任务
  412.     getTask: function(taskName) {
  413.         for (var i = 0; i < this.tasks.length; i++) {
  414.             if (this.tasks[i].name === taskName) {
  415.                 return this.tasks[i];
  416.             }
  417.         }
  418.         return null;
  419.     },
  420.    
  421.     // 方法:执行指定任务
  422.     executeTask: function(taskName) {
  423.         var task = this.getTask(taskName);
  424.         if (!task) {
  425.             Logger.error('未找到任务: ' + taskName);
  426.             return false;
  427.         }
  428.         
  429.         this.currentTaskIndex = this.tasks.indexOf(task);
  430.         return task.run();
  431.     },
  432.    
  433.     // 方法:按顺序执行所有任务
  434.     executeAll: function() {
  435.         Logger.info('开始执行所有任务,共' + this.tasks.length + '个');
  436.         
  437.         var successCount = 0;
  438.         var failCount = 0;
  439.         
  440.         for (var i = 0; i < this.tasks.length; i++) {
  441.             this.currentTaskIndex = i;
  442.             var task = this.tasks[i];
  443.             
  444.             Logger.info('执行任务 [' + (i + 1) + '/' + this.tasks.length + ']: ' + task.name);
  445.             
  446.             if (task.run()) {
  447.                 successCount++;
  448.             } else {
  449.                 failCount++;
  450.             }
  451.             
  452.             // 如果不是自动执行下一个,则停止
  453.             if (!this.autoExecuteNext) {
  454.                 break;
  455.             }
  456.         }
  457.         
  458.         Logger.info('所有任务执行完成 - 成功: ' + successCount + ', 失败: ' + failCount);
  459.         return {
  460.             success: successCount,
  461.             fail: failCount,
  462.             total: this.tasks.length
  463.         };
  464.     },
  465.    
  466.     // 方法:并行执行任务(模拟)
  467.     executeParallel: function(taskNames) {
  468.         Logger.info('开始并行执行任务: ' + taskNames.join(', '));
  469.         
  470.         var results = {};
  471.         for (var i = 0; i < taskNames.length; i++) {
  472.             var taskName = taskNames[i];
  473.             var task = this.getTask(taskName);
  474.             
  475.             if (task) {
  476.                 Logger.info('启动任务: ' + taskName);
  477.                 // 注意:在真实场景中,这里应该使用多线程
  478.                 // 由于Rhino的限制,这里只是顺序执行
  479.                 results[taskName] = task.run();
  480.             } else {
  481.                 Logger.error('未找到任务: ' + taskName);
  482.                 results[taskName] = false;
  483.             }
  484.         }
  485.         
  486.         return results;
  487.     },
  488.    
  489.     // 方法:获取所有任务状态
  490.     getAllStatus: function() {
  491.         var statusList = [];
  492.         for (var i = 0; i < this.tasks.length; i++) {
  493.             statusList.push(this.tasks[i].getInfo());
  494.         }
  495.         return statusList;
  496.     },
  497.    
  498.     // 方法:打印所有任务状态
  499.     printAllStatus: function() {
  500.         printl('========== 任务管理器状态 ==========');
  501.         printl('任务总数: ' + this.tasks.length);
  502.         printl('当前任务索引: ' + this.currentTaskIndex);
  503.         printl('自动执行: ' + (this.autoExecuteNext ? '开启' : '关闭'));
  504.         printl('');
  505.         
  506.         for (var i = 0; i < this.tasks.length; i++) {
  507.             var task = this.tasks[i];
  508.             var info = task.getInfo();
  509.             printl('[' + (i + 1) + '] ' + info.name + ' - ' + task.getStatusText(info.status));
  510.         }
  511.         printl('====================================');
  512.     },
  513.    
  514.     // 方法:重置所有任务
  515.     resetAll: function() {
  516.         for (var i = 0; i < this.tasks.length; i++) {
  517.             this.tasks[i].reset();
  518.         }
  519.         this.currentTaskIndex = -1;
  520.         Logger.info('所有任务已重置');
  521.     },
  522.    
  523.     // 方法:统计任务状态
  524.     getStatistics: function() {
  525.         var stats = {
  526.             total: this.tasks.length,
  527.             pending: 0,
  528.             running: 0,
  529.             completed: 0,
  530.             failed: 0,
  531.             paused: 0
  532.         };
  533.         
  534.         for (var i = 0; i < this.tasks.length; i++) {
  535.             var status = this.tasks[i].status;
  536.             if (stats.hasOwnProperty(status)) {
  537.                 stats[status]++;
  538.             }
  539.         }
  540.         
  541.         return stats;
  542.     }
  543. };

  544. // =============================================================================
  545. // 第五部分:设备信息对象 (DeviceInfo)
  546. // =============================================================================

  547. /**
  548. * 设备信息对象
  549. * 封装AIWROK的设备信息查询功能
  550. */
  551. var DeviceInfo = {
  552.     // 属性:缓存的设备信息
  553.     cachedInfo: null,
  554.    
  555.     // 方法:获取设备信息
  556.     getInfo: function() {
  557.         if (this.cachedInfo) {
  558.             return this.cachedInfo;
  559.         }
  560.         
  561.         try {
  562.             var info = {};
  563.             
  564.             // 尝试获取屏幕信息
  565.             try {
  566.                 info.screenWidth = screen.getScreenWidth();
  567.                 info.screenHeight = screen.getScreenHeight();
  568.             } catch (e) {
  569.                 info.screenWidth = '未知';
  570.                 info.screenHeight = '未知';
  571.             }
  572.             
  573.             // 尝试获取电池信息
  574.             try {
  575.                 info.batteryLevel = device.getBattery();
  576.                 info.isCharging = device.isCharging();
  577.             } catch (e) {
  578.                 info.batteryLevel = '未知';
  579.                 info.isCharging = false;
  580.             }
  581.             
  582.             // 尝试获取网络信息
  583.             try {
  584.                 info.networkType = device.getNetworkType();
  585.                 info.wifiSSID = device.getWifiSSID();
  586.             } catch (e) {
  587.                 info.networkType = '未知';
  588.                 info.wifiSSID = '未知';
  589.             }
  590.             
  591.             // 尝试获取设备信息
  592.             try {
  593.                 info.deviceModel = device.getModel();
  594.                 info.androidVersion = device.getVersion();
  595.             } catch (e) {
  596.                 info.deviceModel = '未知';
  597.                 info.androidVersion = '未知';
  598.             }
  599.             
  600.             // 尝试获取内存信息
  601.             try {
  602.                 info.memoryInfo = app.getMemory();
  603.                 info.memoryPercent = app.getMemoryPercent();
  604.             } catch (e) {
  605.                 info.memoryInfo = { Total: '未知', Available: '未知' };
  606.                 info.memoryPercent = '未知';
  607.             }
  608.             
  609.             // 尝试获取应用信息
  610.             try {
  611.                 info.topPackage = app.getTopPackName();
  612.                 info.topAppName = app.getAppName(app.getTopPackName());
  613.             } catch (e) {
  614.                 info.topPackage = '未知';
  615.                 info.topAppName = '未知';
  616.             }
  617.             
  618.             // 时间信息(总是可用)
  619.             info.timestamp = new Date().getTime();
  620.             info.currentTime = new Date().toLocaleString();
  621.             
  622.             this.cachedInfo = info;
  623.             return info;
  624.         } catch (e) {
  625.             Logger.error('获取设备信息失败: ' + e);
  626.             return null;
  627.         }
  628.     },
  629.    
  630.     // 方法:刷新设备信息
  631.     refresh: function() {
  632.         this.cachedInfo = null;
  633.         return this.getInfo();
  634.     },
  635.    
  636.     // 方法:打印设备信息
  637.     printInfo: function() {
  638.         var info = this.getInfo();
  639.         if (!info) {
  640.             printl('无法获取设备信息');
  641.             return;
  642.         }
  643.         
  644.         printl('========== 设备信息 ==========');
  645.         printl('屏幕分辨率: ' + info.screenWidth + 'x' + info.screenHeight);
  646.         printl('电池电量: ' + info.batteryLevel + '%');
  647.         printl('充电状态: ' + (info.isCharging ? '充电中' : '未充电'));
  648.         printl('网络类型: ' + info.networkType);
  649.         printl('WiFi名称: ' + info.wifiSSID);
  650.         printl('设备型号: ' + info.deviceModel);
  651.         printl('安卓版本: ' + info.androidVersion);
  652.         printl('总内存: ' + info.memoryInfo.Total);
  653.         printl('可用内存: ' + info.memoryInfo.Available);
  654.         printl('内存使用率: ' + info.memoryPercent + '%');
  655.         printl('前台应用: ' + info.topAppName + ' (' + info.topPackage + ')');
  656.         printl('当前时间: ' + info.currentTime);
  657.         printl('==============================');
  658.     }
  659. };

  660. // =============================================================================
  661. // 第六部分:实际应用示例
  662. // =============================================================================

  663. /**
  664. * 示例1:创建并执行简单任务
  665. */
  666. function example1_SimpleTask() {
  667.     printl('========== 示例1:简单任务 ==========');
  668.    
  669.     // 创建任务
  670.     var task = new Task('测试任务', '这是一个简单的测试任务');
  671.    
  672.     // 设置执行函数
  673.     task.setExecuteFunction(function() {
  674.         Logger.info('正在执行测试任务...');
  675.         sleep.second(2); // 模拟耗时操作
  676.         Logger.info('测试任务执行完毕');
  677.         return { success: true, message: '测试通过' };
  678.     });
  679.    
  680.     // 设置回调
  681.     task.setOnComplete(function(result) {
  682.         Logger.info('任务完成回调: ' + JSON.stringify(result));
  683.     });
  684.    
  685.     task.setOnError(function(error) {
  686.         Logger.error('任务错误回调: ' + error);
  687.     });
  688.    
  689.     // 执行任务
  690.     task.run();
  691.    
  692.     // 打印任务信息
  693.     task.printInfo();
  694. }

  695. /**
  696. * 示例2:使用任务管理器管理多个任务
  697. */
  698. function example2_TaskManager() {
  699.     printl('');
  700.     printl('========== 示例2:任务管理器 ==========');
  701.    
  702.     // 创建多个任务
  703.     var task1 = new Task('数据备份', '备份重要数据');
  704.     task1.setExecuteFunction(function() {
  705.         Logger.info('正在备份数据...');
  706.         sleep.millisecond(1500);
  707.         Logger.info('数据备份完成');
  708.         return true;
  709.     });
  710.    
  711.     var task2 = new Task('清理缓存', '清理应用缓存');
  712.     task2.setExecuteFunction(function() {
  713.         Logger.info('正在清理缓存...');
  714.         sleep.second(1);
  715.         Logger.info('缓存清理完成');
  716.         return true;
  717.     });
  718.    
  719.     var task3 = new Task('同步数据', '同步云端数据');
  720.     task3.setExecuteFunction(function() {
  721.         Logger.info('正在同步数据...');
  722.         sleep.second(2);
  723.         Logger.info('数据同步完成');
  724.         return true;
  725.     });
  726.    
  727.     // 添加到任务管理器
  728.     TaskManager.addTask(task1);
  729.     TaskManager.addTask(task2);
  730.     TaskManager.addTask(task3);
  731.    
  732.     // 打印任务状态
  733.     TaskManager.printAllStatus();
  734.    
  735.     // 执行所有任务
  736.     var result = TaskManager.executeAll();
  737.     printl('执行结果: ' + JSON.stringify(result));
  738.    
  739.     // 打印最终状态
  740.     TaskManager.printAllStatus();
  741.    
  742.     // 获取统计信息
  743.     var stats = TaskManager.getStatistics();
  744.     printl('统计信息: ' + JSON.stringify(stats));
  745. }

  746. /**
  747. * 示例3:使用配置管理器
  748. */
  749. function example3_ConfigManager() {
  750.     printl('');
  751.     printl('========== 示例3:配置管理器 ==========');
  752.    
  753.     // 初始化配置管理器
  754.     ConfigManager.init();
  755.    
  756.     // 写入配置
  757.     ConfigManager.set('app_name', 'AIWROK Demo');
  758.     ConfigManager.set('version', '1.0.0');
  759.     ConfigManager.set('debug_mode', 'true');
  760.     ConfigManager.set('max_retry', '3');
  761.    
  762.     // 读取配置
  763.     var appName = ConfigManager.get('app_name', 'Unknown');
  764.     var version = ConfigManager.get('version', '0.0.0');
  765.     var debugMode = ConfigManager.get('debug_mode', 'false');
  766.    
  767.     printl('应用名称: ' + appName);
  768.     printl('版本号: ' + version);
  769.     printl('调试模式: ' + debugMode);
  770.    
  771.     // 批量读取
  772.     var allConfig = ConfigManager.loadAll(['app_name', 'version', 'debug_mode', 'max_retry']);
  773.     printl('批量读取结果: ' + JSON.stringify(allConfig));
  774.    
  775.     // 批量写入
  776.     var newConfig = {
  777.         'theme': 'dark',
  778.         'language': 'zh-CN',
  779.         'auto_update': 'true'
  780.     };
  781.     ConfigManager.saveAll(newConfig);
  782.     printl('批量写入完成');
  783. }

  784. /**
  785. * 示例4:使用日志管理器
  786. */
  787. function example4_Logger() {
  788.     printl('');
  789.     printl('========== 示例4:日志管理器 ==========');
  790.    
  791.     // 设置日志级别
  792.     Logger.setLevel(Logger.LEVEL_DEBUG);
  793.    
  794.     // 输出不同级别的日志
  795.     Logger.debug('这是一条调试信息');
  796.     Logger.info('这是一条普通信息');
  797.     Logger.warn('这是一条警告信息');
  798.     Logger.error('这是一条错误信息');
  799.    
  800.     // 获取最近的日志
  801.     var recentLogs = Logger.getRecentLogs(5);
  802.     printl('最近5条日志:');
  803.     for (var i = 0; i < recentLogs.length; i++) {
  804.         var log = recentLogs[i];
  805.         printl('  [' + log.level + '] ' + log.message);
  806.     }
  807. }

  808. /**
  809. * 示例5:获取设备信息
  810. */
  811. function example5_DeviceInfo() {
  812.     printl('');
  813.     printl('========== 示例5:设备信息 ==========');
  814.    
  815.     // 打印设备信息
  816.     DeviceInfo.printInfo();
  817.    
  818.     // 获取原始信息对象
  819.     var info = DeviceInfo.getInfo();
  820.     if (info) {
  821.         printl('屏幕宽度: ' + info.screenWidth);
  822.         printl('屏幕高度: ' + info.screenHeight);
  823.         printl('电池电量: ' + info.batteryLevel + '%');
  824.     }
  825. }

  826. /**
  827. * 示例6:综合应用 - 自动化工作流
  828. */
  829. function example6_AutomationWorkflow() {
  830.     printl('');
  831.     printl('========== 示例6:自动化工作流 ==========');
  832.    
  833.     Logger.info('启动自动化工作流...');
  834.    
  835.     // 步骤1:检查设备状态
  836.     Logger.info('步骤1:检查设备状态');
  837.     var deviceInfo = DeviceInfo.getInfo();
  838.     if (deviceInfo && deviceInfo.batteryLevel < 20) {
  839.         Logger.warn('电池电量低于20%,建议充电');
  840.     }
  841.    
  842.     // 步骤2:加载配置
  843.     Logger.info('步骤2:加载配置');
  844.     ConfigManager.init();
  845.     var config = ConfigManager.loadAll(['app_name', 'version', 'debug_mode']);
  846.     Logger.info('配置加载完成: ' + JSON.stringify(config));
  847.    
  848.     // 步骤3:创建并执行任务
  849.     Logger.info('步骤3:创建并执行任务');
  850.    
  851.     var workflowTask = new Task('自动化工作流', '完整的自动化工作流程');
  852.     workflowTask.setExecuteFunction(function() {
  853.         Logger.info('执行工作流任务...');
  854.         
  855.         // 模拟多个步骤
  856.         Logger.info('  - 步骤1:数据准备');
  857.         sleep.millisecond(500);
  858.         
  859.         Logger.info('  - 步骤2:数据处理');
  860.         sleep.second(1);
  861.         
  862.         Logger.info('  - 步骤3:数据保存');
  863.         sleep.millisecond(500);
  864.         
  865.         Logger.info('工作流任务完成');
  866.         return { success: true, steps: 3 };
  867.     });
  868.    
  869.     workflowTask.setOnComplete(function(result) {
  870.         Logger.info('工作流完成,结果: ' + JSON.stringify(result));
  871.     });
  872.    
  873.     workflowTask.run();
  874.    
  875.     // 步骤4:保存执行记录
  876.     Logger.info('步骤4:保存执行记录');
  877.     ConfigManager.set('last_run_time', new Date().toLocaleString());
  878.     ConfigManager.set('last_run_status', 'success');
  879.    
  880.     Logger.info('自动化工作流执行完毕');
  881. }

  882. // =============================================================================
  883. // 第七部分:主函数 - 运行所有示例
  884. // =============================================================================

  885. /**
  886. * 主函数:运行所有示例
  887. */
  888. function main() {
  889.     printl('========================================');
  890.     printl('  AIWROK JavaScript对象高级应用实例');
  891.     printl('========================================');
  892.     printl('');
  893.    
  894.     // 运行所有示例
  895.     example1_SimpleTask();
  896.     sleep.second(2); // 示例间延时
  897.    
  898.     example2_TaskManager();
  899.     sleep.second(2); // 示例间延时
  900.    
  901.     example3_ConfigManager();
  902.     sleep.second(2); // 示例间延时
  903.    
  904.     example4_Logger();
  905.     sleep.second(2); // 示例间延时
  906.    
  907.     example5_DeviceInfo();
  908.     sleep.second(2); // 示例间延时
  909.    
  910.     example6_AutomationWorkflow();
  911.    
  912.     printl('');
  913.     printl('========================================');
  914.     printl('  所有示例执行完成!');
  915.     printl('========================================');
  916. }

  917. // 执行主函数
  918. main();
复制代码


AIWROK安卓脚本对象高级实用示例 B2B网络软件










欢迎光临 B2B网络软件 (http://bbs.niubt.cn/) Powered by Discuz! X3.2