Hexo 主题简单实现搜索功能

最近一直在折腾Hxeo的站点,发现自带的主题吗,没有搜索功能。决定自己改一个。

感谢 @bay1 大佬的文章,原文链接:https://segmentfault.com/a/1190000011917419

下面就是在hexo主题添加本地搜索功能的过程。

生成搜索索引文件

hexo-generator-searchdb插件可以生成一个xml格式的索引文件。之后再利用jQuery的ajax函数查询并处理生成的索引文件。

获取 hexo-generator-searchdb 插件

npm install hexo-generator-searchdb --save

修改 hexo 全局配置文件

在 hexo 全局配置文件_config.yml最后添加下面的配置。

Typecho 添加图片灯箱

ok,上一篇文章已经对img标签下手了。这次更彻底点,给图片添加上灯箱效果

2020-01-02_215330.png2020-01-02_215330.png

首先,引入相关js文件

<!--在header里添加这个-->
<link href="https://cdn.bootcss.com/fancybox/3.5.7/jquery.fancybox.min.css" rel="stylesheet">

<!--先加载jquery依赖-->
<script src="//cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
<!--fancybox的js,还是bootcdn-->
<script src="//cdn.bootcss.com/fancybox/3.5.7/jquery.fancybox.min.js"></script>

修改Typecho

首先找到HyperDown.php文件,在Typecho下的var目录里。

然后搜索img,一般在349行开始,修改img标签为

<a data-fancybox=\"gallery\" href=\"{$url}\"><img src=\"{$url}\" alt=\"{$escaped}\" title=\"{$escaped}\"></a>

HyperDown.php文件位置HyperDown.php文件位置

正则替换,与上面方案任选其一

ps:这会导致 <!--more--> 无法正常截断文章。
2020-01-05 更新,修正 <!--more--> 无法正常截断文章的问题。
2020-02-09 跟新,正则表达式增加对atl和title属性的匹配。

首先在你的主题文件找到这个

<?php $this->content(); ?>

用正则修改img标签

<?php
    $pattern = '/\<img.*?src\=\"(.*?)\".*?alt\=\"(.*?)\".*?title\=\"(.*?)\"[^>]*>/i';
    $replacement = '<a href="$1" data-fancybox="gallery" /><img src="$1" alt="$2" title="$3"></a>';
    $content = preg_replace($pattern, $replacement, $this->content);

    //需要支持截断的添加下面两行
    $array=explode('<!--more-->', $content);
    $content=$array[0];

    echo $content;
?>

ESP8266使用I2C连接OLDE屏幕

首先,上效果图

2019-12-29_122548.png2019-12-29_122548.png


你可能需要的前期准备


连线&安装OLED驱动库

1. 安装OLED驱动库

这次我们选择U8G2库,来驱动OLED屏幕。

项目地址 | wiki | 如何安装支持库

2. 连线

  • D1 --- SDA(数据)
  • D2 --- SCL(时钟)
  • 3V --- VCC
  • G --- GND

2089953529.png2089953529.png


代码

#include <Arduino.h>
#include <U8g2lib.h>
#include <SPI.h>
#include <Wire.h>


#define SDA 05 //ESP8266 D1 PIN 05
#define SCL 04 //ESP8266 D2 PIN 04

//SSD1306,128x64,全屏缓冲模式,模拟I2C,I2C,u8g2(旋转0度,时钟,数据,重置)
U8G2_SSD1306_128X64_NONAME_F_SW_I2C u8g2(U8G2_R0, /* clock=*/ SCL, /* data=*/ SDA, /* reset=*/ U8X8_PIN_NONE);


void setup(void) {
  u8g2.begin();
  u8g2.enableUTF8Print();// 为 Arduino print() 函数启用UTF8支持
}

void loop(void) {  
  u8g2.clearBuffer();//清除当前Buffer内的像素
  u8g2.setFont(u8g2_font_ncenB08_tr);// 英文字库
  u8g2.setCursor(0, 10);
  u8g2.print("Hello World!");// 英文 "Hello World" 
  u8g2.setFont(u8g2_font_unifont_t_chinese2);// 中文支持 chinese2: Lerning Level 1-6
  u8g2.setCursor(0, 35);
  u8g2.print("你好世界!");// 中文 "Hello World" 
  u8g2.setFont(u8g2_font_b10_t_japanese2);// 日文支持 japanese1: Lerning Level 1-6
  u8g2.setCursor(0, 55);
  u8g2.print("こんにちは世界!");// 日语 "Hello World" 
  u8g2.setFont(u8g2_font_unifont_t_symbols);
  u8g2.drawUTF8(75, 35, "☀ ☁ ☂");
  u8g2.sendBuffer();//发送Buffer内容到屏上
  delay(1000); 
}

小游戏之推箱子

这次是一个推箱子小游戏,因为 java 限制,不能直接获取按键响应,只能使用输入wasd的方式来控制移动。

基本上和走迷宫差不对,只不过逻辑上增加了对箱子位置的判断。

↓简陋的界面