autojs之新手引导

简介: 作者: 牙叔使用场景:引导新用户, 学习软件的使用方法

作者: 牙叔

使用场景:


引导新用户, 学习软件的使用方法


效果展示:


仅为演示功能, 未做美化

微信图片_20220624140939.gif


实现步骤


  1. 等待页面布局加载完毕
ui.guide.click(function () {
  log("开启新手引导");
  setTimeout(function () {
    新手引导();
  }, 500);
});


  1. 截图
function screenCapture(activity) {
  log("screenCapture");
  // 获取windows中最顶层的view
  view = activity.getWindow().getDecorView();
  view.buildDrawingCache();
  // 获取状态栏高度
  rect = new Rect();
  view.getWindowVisibleDisplayFrame(rect);
  statusBarHeights = rect.top;
  display = activity.getWindowManager().getDefaultDisplay();
  // 获取屏幕宽和高
  widths = display.getWidth();
  heights = display.getHeight();
  // 允许当前窗口保存缓存信息
  view.setDrawingCacheEnabled(true);
  // 去掉状态栏
  let bmp = Bitmap.createBitmap(view.getDrawingCache(), 0, statusBarHeights, widths, heights - statusBarHeights);
  // 销毁缓存信息
  view.destroyDrawingCache();
  return bmp;
}


  1. 添加一个popWindow, 里面只有一个<img>
 let contentView = ui.inflate(
    <vertical>
      <img id="img" layout_width="match_parent" layout_height="match_parent"></img>
    </vertical>,
    null,
    false
  );
  let mPopWindow = new PopupWindow(
    contentView,
    ViewGroup.LayoutParams.MATCH_PARENT,
    ViewGroup.LayoutParams.WRAP_CONTENT,
    true
  );


  1. 画一层遮罩
canvas.drawARGB(200, 125, 125, 125);


  1. 指定按钮处画边框
paint.setStyle(Paint.Style.STROKE); //空心矩形框
paint.setStrokeWidth(20);
paint.setColor(colors.parseColor("#0000ff"));
canvas.drawRect(data.left, data.top, data.right, data.bottom, paint);


  1. 指定按钮从图片中裁剪出来
let clip = images.clip(img, data.left, data.top, data.right - data.left, data.bottom - data.top);
let smallBitmap = clip.getBitmap();


  1. 画指定按钮
canvas.drawBitmap(smallBitmap, data.left, data.top, paint);


  1. 添加文字
paint.setTextAlign(Paint.Align.CENTER);
paint.setTextSize(70);
paint.setStyle(Paint.Style.FILL);
paint.setColor(colors.parseColor("#f000ff"));
canvas.drawText(data.introduction, data.left + parseInt((data.right - data.left) / 2), data.bottom + 100, paint);


  1. img控件加载图片
imgView.attr("src", "file://" + compositeImgpath);




相关文章
|
2月前
|
XML 小程序 前端开发
小程序制作教程
小程序制作教程
71 3
小程序制作教程
|
6月前
|
缓存 测试技术 Shell
详细解读Android开发命令行完全攻略
详细解读Android开发命令行完全攻略
47 0
|
7月前
|
运维 搜索推荐
新手引导
新手引导;功能旨在协助用户轻松接入AIRec服务,通过4大模块和11个子环节的step-by-step教程,实现智能推荐应用的快速搭建。它提供数据上传、策略配置、上线功能及效果评估的详细指导,并根据用户进度提出操作建议。用户可随时开启或关闭此功能。
54 1
|
Shell 网络安全 开发工具
SourceTree安装(小白特别详细教程)
SourceTree安装(小白特别详细教程)
366 0
|
API C#
HandyControl新手引导
HandyControl新手引导
333 0
HandyControl新手引导
|
图形学 数据安全/隐私保护
还在用Unity开发游戏?那你就out了,试试用Unity做一个答题系统吧
大家都支持Unity是用来做游戏开发,比如说做2D游戏、3D游戏,或者工业虚拟仿真软件的开发。 其他Unity可以做的有很多,比如答题系统。 本篇就介绍答题系统的开发 这个答题系统,可以从文本文档中提取题目和分数,然后绑定到UI上,在答题的过程中,自动判断分数,自动判断正确率。 目的是实现一个可快速导入到项目中使用的小模块。
|
数据安全/隐私保护
新手训练营-引导手册
新手训练营-引导手册
|
Java 开发工具 C++
电脑技巧:推荐一款非常棒的截图软件X-Snip
X-Snip是一款可以解决不同类型用户在不同场景下使用截图工具时所面临的问题,并且适配了所有的Windows版本系统,整个软件只有一个exe文件,不涉及任何依赖项。
电脑技巧:推荐一款非常棒的截图软件X-Snip
|
缓存 安全 算法
CleanMyMac X4.30完整版功能介绍
CleanMyMac自身拥有一个安全数据可,它是一个项目列表,拥有一定的规格,可以确定软件能够正确选择和清理Mac垃圾文件,更加安全,可靠!随着10周年纪念版的推出,CleanMyMac已经完成了向全面清理,优化和管理工具的转变。它的算法和功能变得更加智能,但外观仍然像您预期的那样简单。
260 0
我用过的这5款小工具,你用了其中几款?
有时候一些小工具,能给你带来一些意想不到的效果,我们来看看下面这5款工具,你又用过其中几款呢?
90 0