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


声明

部分内容来自网络




相关文章
|
5月前
|
前端开发 JavaScript Java
童年回忆——超级玛丽(内含源码inscode一键运行)
童年回忆——超级玛丽(内含源码inscode一键运行)
|
5月前
基于autojs7的亚丁号成语大家族辅助
基于autojs7的亚丁号成语大家族辅助
47 0
|
5月前
|
人工智能 安全 IDE
【AI帮我写代码,上班摸鱼不是梦】手摸手图解CodeWhisperer的安装使用
除了借助ChatGPT通过问答的方式生成代码,也可以通过IDEA插件在写代码是直接帮助我们生成代码。 目前,IDEA插件有CodeGeeX、CodeWhisperer、Copilot。其中,CodeGeeX和CodeWhisperer是完全免费的,Copilot是收费的,每月10美元。 下面我们来了解CodeWhisperer的安装和使用,如果你还想了解其他的可以在评论告诉我。
203 4
|
Go 索引
「连载」最最通俗易懂,并带小说情节的Go语言入门教程(连载四),没有之一,不接受反驳
「连载」最最通俗易懂,并带小说情节的Go语言入门教程(连载四),没有之一,不接受反驳
|
3月前
ChatGPT提问获取高质量答案的艺术PDF下载书籍推荐分享
**掌握ChatGPT高质量Prompt技巧的指南,教你艺术性提问以获取卓越答案。适用于各层次用户,提升内容创作效率。了解Prompt工程,作为对话模式触发器,有效引导ChatGPT生成人类般文本。点击获取PDF资源:[ChatGPT提问艺术](https://zhangfeidezhu.com/?p=334)**
49 0
ChatGPT提问获取高质量答案的艺术PDF下载书籍推荐分享
|
5月前
|
人工智能 JSON 数据格式
使用Kimi的一些体会
使用Kimi的一些体会
128 1
|
人工智能 前端开发 API
手把手带你用Python和文心一言搭建《AI看图写诗》网页项目
手把手带你用Python和文心一言搭建《AI看图写诗》网页项目
460 1
手把手带你用Python和文心一言搭建《AI看图写诗》网页项目
|
人工智能 自然语言处理 程序员
编程不头秃,Google「AI程序员」来了,聊天就能敲代码
编程不头秃,Google「AI程序员」来了,聊天就能敲代码
146 0
|
Kubernetes Cloud Native JavaScript
「连载」最最通俗易懂,并带小说情节的Go语言入门教程(连载三),没有之一,不接受反驳
「连载」最最通俗易懂,并带小说情节的Go语言入门教程(连载三),没有之一,不接受反驳
|
程序员 Go
最最通俗易懂,并带小说情节的Go语言入门教程,没有之一,不接受反驳
最最通俗易懂,并带小说情节的Go语言入门教程,没有之一,不接受反驳