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

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

牙叔教程 简单易学


使用场景


记忆数字


世界记忆大师数字项目的训练分三个步骤:出图、联结和记忆。

每个编码都在脑子里呈现出清晰、完整、立体、生动、有感觉的图像,还可以是动态的。

不仅要看到它的样子,还要听到它的声音、闻到它的味道、感受它的触觉,用各种感官去理解编码、感受编码。


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


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


效果展示

微信图片_20220625192956.jpg


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;
    },
  });
}


声明

部分内容来自网络




相关文章
|
机器学习/深度学习 传感器 算法
【虚警检测】基于CA-CFAR(单元平均恒虚警)、GO-CFAR(最大选择恒虚警)、SO-CFAR(最小选择恒虚警)算法的恒虚警检测附Matlab代码
【虚警检测】基于CA-CFAR(单元平均恒虚警)、GO-CFAR(最大选择恒虚警)、SO-CFAR(最小选择恒虚警)算法的恒虚警检测附Matlab代码
|
SQL 存储
SQL组内排序
为什么要用ORDER BY来做,因为是这样的,由于采用的多线程,各个线程触发时间十分相近,但是我们需要对每一个项目进行分组,所以在此处,我们做了一个唯一标识IDENTIFICATION,每个项目每次执行时记录的6条日志里都会存储这个唯一标识。
|
11月前
|
机器学习/深度学习 传感器 自动驾驶
深度学习在自动驾驶中的应用与挑战####
本文探讨了深度学习技术在自动驾驶领域的应用现状、面临的主要挑战及未来发展趋势。通过分析卷积神经网络(CNN)和循环神经网络(RNN)等关键算法在环境感知、决策规划中的作用,结合特斯拉Autopilot和Waymo的实际案例,揭示了深度学习如何推动自动驾驶技术向更高层次发展。文章还讨论了数据质量、模型泛化能力、安全性及伦理道德等问题,为行业研究者和开发者提供了宝贵的参考。 ####
|
12月前
|
Arthas 监控 数据可视化
JVM进阶调优系列(7)JVM调优监控必备命令、工具集合|实用干货
本文介绍了JVM调优监控命令及其应用,包括JDK自带工具如jps、jinfo、jstat、jstack、jmap、jhat等,以及第三方工具如Arthas、GCeasy、MAT、GCViewer等。通过这些工具,可以有效监控和优化JVM性能,解决内存泄漏、线程死锁等问题,提高系统稳定性。文章还提供了详细的命令示例和应用场景,帮助读者更好地理解和使用这些工具。
|
11月前
|
消息中间件 缓存 监控
在PHP中,实现多线程
在PHP中,实现多线程
335 6
|
机器学习/深度学习 人工智能 API
在人工智能和机器学习的领域中,语音识别(Speech Recognition,SR)是一个重要的研究方向。它旨在将人类的语音转换为计算机可读的文本。
在人工智能和机器学习的领域中,语音识别(Speech Recognition,SR)是一个重要的研究方向。它旨在将人类的语音转换为计算机可读的文本。
|
前端开发 JavaScript 应用服务中间件
Nginx 开启 gzip 压缩,让网站飞一会!
一起来了解下nginx的gzip压缩
517 3
|
SQL 数据可视化 关系型数据库
2022年最新最详细IDEA关联数据库方式、在IDEA中进行数据库的可视化操作(包含图解过程)
这篇文章详细介绍了如何在IntelliJ IDEA中关联MySQL数据库,包括打开Database侧边栏、选择数据库、输入连接信息、测试连接,并提供了解决连接问题的方案,以及在IDEA中进行数据库的可视化操作步骤。
2022年最新最详细IDEA关联数据库方式、在IDEA中进行数据库的可视化操作(包含图解过程)
|
存储 SQL 关系型数据库
【MySQL技术内幕】4.2-InnoDB行记录格式
【MySQL技术内幕】4.2-InnoDB行记录格式
180 0
|
Java Spring
Spring在多线程中bean的注入问题
Spring在多线程中bean的注入问题
356 0