autojs世界记忆大师都在用的方法

牙叔教程 简单易学

使用场景

记忆数字

世界记忆大师数字项目的训练分三个步骤:出图、联结和记忆。
每个编码都在脑子里呈现出清晰、完整、立体、生动、有感觉的图像,还可以是动态的。
不仅要看到它的样子,还要听到它的声音、闻到它的味道、感受它的触觉,用各种感官去理解编码、感受编码。

在记忆的时候,一定要做到以下几点:清晰,奇特,动态,连贯!

如果你的图象不清晰,在你记忆的过程中就像是看屏幕不清晰的电视,当你回忆这段情景的时候,因为屏幕的不清晰,很多细节都被你忽略了,所以容易忘记。越是离奇的事物越容易加深人们的印象。

效果展示

在这里插入图片描述

autojs版本

8.7.7-0

代码简介

  • 脚本提供了一个数据库, 里面有图片, 1-100
  • 界面有一个输入框, 用来输入数字
  • 输入数字后, 会自动显示数字对应的图片
  • 两个数字为一组, 比如12为一张图片, 34位一张图片, 会自动以2位为一组, 切割数字

代码讲解

1. 停止其他脚本
engines.all().map((ScriptEngine) => {
  if (engines.myEngine().toString() !== ScriptEngine.toString()) {
    ScriptEngine.forceStop();
  }
});
2. 导入类
importClass(Packages.androidx.recyclerview.widget.RecyclerView);
importClass(Packages.androidx.recyclerview.widget.LinearLayoutManager);
importClass(android.graphics.drawable.BitmapDrawable);
3. 界面布局
ui.layout(
  <vertical margin="9">
    <horizontal>
      <text text="手机号"></text>
      <input id="mobile" hint="只能输入数字" w="*" digit="1234567890"></input>
    </horizontal>
    <androidx.recyclerview.widget.RecyclerView id="dataList" h="*" w="*" />
  </vertical>
);
4. recycleView布局
let boxXml = (
  <vertical w="*" padding="8" marginTop="6">
    <img id="img"></img>
    <horizontal margin="20">
      <text id="name" w="*" gravity="center" textSize="25sp" textStyle="bold">
        名字
      </text>
    </horizontal>
  </vertical>
);
5. 设置recycleView的布局管理器
layoutManager = new LinearLayoutManager(context);
recyclerView.setLayoutManager(layoutManager);
6. 设置recycleView的adapter
let recycleAdapter = createGiftBoxAdapter(dataList);
recyclerView.setAdapter(recycleAdapter);
7. 设置输入框监听
ui.mobile.addTextChangedListener(
  new android.text.TextWatcher({
    afterTextChanged: function (content) {
      根据输入框中的内容修改dataList(content);
    },
  })
);
8. 退出时释放资源, 关闭数据库
events.on("exit", function () {
  db && db.close();
});



##### 9. 打开数据库

​```js
const TableName = "IMGDATA";
// 表名: IMGDATA
// 字段1 id 整数 主键 自增
// 字段2 name 字符串 不可为空
// 字段3 img BLOB bytes
let db = sqlite.open(
  "/sdcard/脚本/memoryData.db",
  { version: 1 },
  {
    onOpen: function (db) {
      db.execSQL(
        "CREATE TABLE IF NOT EXISTS " +
          TableName +
          "(" +
          "`id` INTEGER PRIMARY KEY AUTOINCREMENT, " +
          "`name` TEXT NOT NULL UNIQUE, " +
          "`img` BLOB" +
          ")"
      );
    },
  }
);
10. 查找数字对应的图片信息
function 查找数字对应的图片信息(num) {
  let dataList = getAllDataName();
  var len = dataList.length;
  for (var i = 0; i < len; i++) {
    let item = dataList[i];
    if (item.name.indexOf(num) === 0 && item.name.replace(/\D/g, "").length === num.length) {
      let data = db.rawQuery("SELECT * FROM " + TableName + " WHERE id = ?", [item.id]).single();
      return data;
    }
  }
  db.close();
  db = null;
  throw new Error("没有找到图片");
}
11. 根据输入框中的内容修改dataList
function 根据输入框中的内容修改dataList(content) {
  if (!content) {
    return false;
  }
  content = content.toString();
  let num = 2;
  let arr = reSetData(content, num);
  dataList.splice(0, dataList.length);
  var len = arr.length;
  for (var i = 0; i < len; i++) {
    let item = arr[i];
    dataList.push(formatData(item));
  }
  recycleAdapter.notifyDataSetChanged();
  ui.dataList.post(function () {
    ui.dataList.smoothScrollToPosition(dataList.length);
  });
}
12. 根据输入框中的内容修改dataList
function createGiftBoxAdapter(dataList) {
  return RecyclerView.Adapter({
    onCreateViewHolder: function (parent, viewType) {
      // 视图创建
      let view;
      let holder;
      view = ui.inflate(boxXml, parent, false);
      holder = JavaAdapter(RecyclerView.ViewHolder, {}, view);
      return holder;
    },
    onBindViewHolder: function (holder, position) {
      // 数据绑定
      let data = dataList[position];
      // holder.itemView.img.attr("src", "file://" + data.img);
      let img = images.fromBytes(data.img);
      let drawable = new BitmapDrawable(img.bitmap);
      holder.itemView.img.setImageDrawable(drawable);
      holder.itemView.name.setText(data.name);
    },
    getItemCount: function () {
      return dataList.length;
    },
  });
}

声明

部分内容来自网络

bilibili

牙叔教程

微信公众号 牙叔教程

在这里插入图片描述

QQ群

747748653
在这里插入图片描述

在这里插入图片描述

### AutoJS中实现整除的方法或函数 AutoJS 是基于 JavaScript 的脚本语言,因此可以使用 JavaScript 的语法来实现整除功能。在 JavaScript 中,可以通过取模运算符 `%` 来判断是否能整除,也可以通过数学运算实现真正的整除结果。 以下是实现整除的两种常见方法: #### 方法一:使用 `Math.floor` 和除法 通过将两个数相除,并使用 `Math.floor` 对结果进行向下取整,可以实现整除效果。 ```javascript function divideFloor(dividend, divisor) { if (divisor === 0) { throw new Error("Divisor cannot be zero"); } return Math.floor(dividend / divisor); } // 示例用法 console.log(divideFloor(10, 3)); // 输出:3 console.log(divideFloor(-10, 3)); // 输出:-4 ``` 这种方法适用于需要获取整除商的情况[^3]。 #### 方法二:使用 `Math.trunc` 和除法 与 `Math.floor` 不同,`Math.trunc` 会直接去掉小数部分,而不会考虑正负号。 ```javascript function divideTrunc(dividend, divisor) { if (divisor === 0) { throw new Error("Divisor cannot be zero"); } return Math.trunc(dividend / divisor); } // 示例用法 console.log(divideTrunc(10, 3)); // 输出:3 console.log(divideTrunc(-10, 3)); // 输出:-3 ``` 此方法适合需要忽略小数部分但保留符号的场景[^3]。 #### 方法三:使用取模运算判断是否能整除 如果只需要判断一个数是否能被另一个数整除,可以使用取模运算符 `%`。 ```javascript function isDivisible(dividend, divisor) { if (divisor === 0) { throw new Error("Divisor cannot be zero"); } return dividend % divisor === 0; } // 示例用法 console.log(isDivisible(10, 2)); // 输出:true console.log(isDivisible(7, 3)); // 输出:false ``` 这种方法仅用于验证整除性,而不返回具体的商值[^3]。 ### 注意事项 - 在实现整除时,需确保除数不为零,否则会抛出错误。 - 根据需求选择合适的整除方法,例如是否需要考虑负数、是否需要返回商值等。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牙叔教程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值