Compare commits
6 Commits
3709d3d284
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| b8700ac88b | |||
| 3c54795451 | |||
| 6d8133489b | |||
| 040b9be6b9 | |||
| fd68396b30 | |||
| 23116b7e3d |
Vendored
+1
-4
@@ -1,7 +1,4 @@
|
||||
{
|
||||
// 使用 IntelliSense 了解相关属性。
|
||||
// 悬停以查看现有属性的描述。
|
||||
// 欲了解更多信息,请访问: https://go.microsoft.com/fwlink/?linkid=830387
|
||||
"version": "0.2.0",
|
||||
"configurations": [
|
||||
{
|
||||
@@ -10,7 +7,7 @@
|
||||
"request": "launch",
|
||||
"program": "${workspaceFolder}/build/HW_Lib",
|
||||
"args": [],
|
||||
"stopAtEntry": true,
|
||||
"stopAtEntry": false,
|
||||
"cwd": "${workspaceFolder}/build",
|
||||
"preLaunchTask": "CMake Build",
|
||||
"environment": [],
|
||||
|
||||
+1
-1
@@ -39,7 +39,7 @@ add_executable(HW_Lib main.c ${SOURCES})
|
||||
add_subdirectory(lib)
|
||||
|
||||
target_link_libraries(HW_Lib HW_LIB_List HW_LIB_Task HW_LIB_Printf HW_LIB_Utils HW_LIB_Iic
|
||||
HW_LIB_Spi HW_LIB_Key HW_LIB_Oled HW_LIB_Font HW_LIB_Tft lvgl::lvgl lvgl::examples lvgl::demos
|
||||
HW_LIB_Spi HW_LIB_Key HW_LIB_Oled HW_LIB_Font HW_LIB_Tft lvgl::lvgl HW_LIB_Lui
|
||||
)
|
||||
|
||||
add_custom_command(TARGET HW_Lib POST_BUILD
|
||||
|
||||
+1
-1
Submodule SDL3 updated: 10734d9422...89c6bc5f50
@@ -8,4 +8,6 @@
|
||||
extern int Test_List(void *pVoid);
|
||||
|
||||
extern int Test_Queue(void *pVoid1);
|
||||
|
||||
extern int Test_Hash(void* pVoid);
|
||||
#endif //HW_LIB_T_LIST_H
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
|
||||
#include "list.h"
|
||||
#include "queue.h"
|
||||
#include "hash_table.h"
|
||||
|
||||
typedef struct test {
|
||||
int val1;
|
||||
@@ -100,6 +101,7 @@ int Test_List(void *pVoid) {
|
||||
// 测试销毁操作
|
||||
printf("-----destroy----\n");
|
||||
list_destroy(&list, NULL); // 销毁链表
|
||||
return 0;
|
||||
}
|
||||
|
||||
int Test_Queue(void *pVoid) {
|
||||
@@ -141,4 +143,16 @@ int Test_Queue(void *pVoid) {
|
||||
printf("Pop value from front: %d\n", *popVal);
|
||||
}
|
||||
delQueue_List(deque);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int Test_Hash(void* pVoid) {
|
||||
Hash_Table_t* ht = ht_new();
|
||||
ht_insert(ht, "name", "lydxh");
|
||||
ht_insert(ht, "age", "18");
|
||||
printf("Name:%s\nAge:%s", ht_search(ht, "name"), ht_search(ht, "age"));
|
||||
ht_delete(ht, "name");
|
||||
ht_delete(ht, "age");
|
||||
ht_del_hash_table(ht);
|
||||
return 0;
|
||||
}
|
||||
|
||||
+1
-1
@@ -41,7 +41,7 @@ int Test_lvgl(void *pVoid) {
|
||||
// lv_port_indev_init();
|
||||
|
||||
// lv_example_get_started_1();
|
||||
lv_demo_widgets();
|
||||
// lv_demo_widgets();
|
||||
// printf("\nTEST Widgets\n");
|
||||
|
||||
while (1) {
|
||||
|
||||
+2
-2
@@ -105,7 +105,7 @@ OLED_T oled = {
|
||||
.height = 64,
|
||||
.width = 128,
|
||||
.state = IDLE,
|
||||
.buf = oledbuf,
|
||||
.buf = oledbuf[0],
|
||||
.cmd = Cmd,
|
||||
.data = Data,
|
||||
.call = Refresh_Call,
|
||||
@@ -117,7 +117,7 @@ int Test_OLED(void* pVoid) {
|
||||
OLED_Init(&oled);
|
||||
OLED_CLS(&oled);
|
||||
|
||||
OLED_ShowCHString(&oled, 1, 24, "星海科技机械师");
|
||||
OLED_ShowCHString(&oled, 1, 1, "星海科技机械师");
|
||||
|
||||
OLED_DrawRect(&oled, 0, 0, 127, 63);
|
||||
|
||||
|
||||
@@ -11,6 +11,7 @@ set(LIBRARIES
|
||||
HW_LIB_Oled oled oled/inc
|
||||
HW_LIB_Tft tft tft/inc
|
||||
HW_LIB_Flash flash flash/inc
|
||||
HW_LIB_Lui lui lui/inc
|
||||
)
|
||||
|
||||
# 循环浏览库列表以创建它们
|
||||
|
||||
+1
-1
@@ -6,7 +6,7 @@ extern "C" {
|
||||
|
||||
#include <stdint.h>
|
||||
#include <string.h>
|
||||
|
||||
#include <stdbool.h>
|
||||
#define KEY_TICKS_INTERVAL 5 // 定时器间隔时间,单位为毫秒
|
||||
#define DEBOUNCE_TICKS 0 // 按键去抖动计数阈值,最大为7(0 ~ 7)
|
||||
#define SHORT_TICKS (300 / KEY_TICKS_INTERVAL) // 短按阈值,单位为定时器间隔的倍数
|
||||
|
||||
@@ -0,0 +1,183 @@
|
||||
#include "hash_table.h"
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <math.h>
|
||||
|
||||
static Hash_Item_t HT_DELETED_ITEM = {NULL, NULL};
|
||||
|
||||
static Hash_Item_t* ht_new_item(const char* k, const char* v) {
|
||||
Hash_Item_t* i = (Hash_Item_t*)malloc(sizeof(Hash_Item_t));
|
||||
i->key = strdup(k);
|
||||
i->value = strdup(v);
|
||||
return i;
|
||||
}
|
||||
|
||||
static int ht_hash(const char* s, const int a, const int m) {
|
||||
long hash = 0;
|
||||
const int len_s = strlen(s);
|
||||
for (int i = 0; i < len_s; i++) {
|
||||
hash += (long)pow(a, len_s - (i+1)) * s[i];
|
||||
hash = hash % m;
|
||||
}
|
||||
return (int)hash;
|
||||
}
|
||||
|
||||
static int ht_get_hash(
|
||||
const char* s, const int num_buckets, const int attempt
|
||||
) {
|
||||
const int hash_a = ht_hash(s, HT_PRIME_1, num_buckets);
|
||||
const int hash_b = ht_hash(s, HT_PRIME_2, num_buckets);
|
||||
return (hash_a + (attempt * (hash_b + 1))) % num_buckets;
|
||||
}
|
||||
static void ht_del_item(Hash_Item_t* i) {
|
||||
free(i->key);
|
||||
free(i->value);
|
||||
free(i);
|
||||
}
|
||||
|
||||
void ht_del_hash_table(Hash_Table_t* ht) {
|
||||
for (int i = 0; i < ht->size; i++) {
|
||||
Hash_Item_t* item = ht->items[i];
|
||||
if (item != NULL) {
|
||||
ht_del_item(item);
|
||||
}
|
||||
}
|
||||
free(ht->items);
|
||||
free(ht);
|
||||
}
|
||||
|
||||
int is_prime(const int x) {
|
||||
if (x < 2) { return -1; }
|
||||
if (x < 4) { return 1; }
|
||||
if ((x % 2) == 0) { return 0; }
|
||||
for (int i = 3; i <= floor(sqrt((double) x)); i += 2) {
|
||||
if ((x % i) == 0) {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int next_prime(int x) {
|
||||
while (is_prime(x) != 1) {
|
||||
x++;
|
||||
}
|
||||
return x;
|
||||
}
|
||||
|
||||
static Hash_Table_t* ht_new_sized(const int base_size) {
|
||||
Hash_Table_t* ht = (Hash_Table_t*)malloc(sizeof(Hash_Table_t));
|
||||
ht->base_size = base_size;
|
||||
|
||||
ht->size = next_prime(ht->base_size);
|
||||
|
||||
ht->count = 0;
|
||||
ht->items = (Hash_Item_t**) calloc((size_t)ht->size, sizeof(Hash_Item_t*));
|
||||
return ht;
|
||||
}
|
||||
|
||||
Hash_Table_t* ht_new() {
|
||||
return ht_new_sized(HT_INITIAL_BASE_SIZE);
|
||||
}
|
||||
|
||||
static void ht_resize(Hash_Table_t* ht, const int base_size) {
|
||||
if (base_size < HT_INITIAL_BASE_SIZE) {
|
||||
return;
|
||||
}
|
||||
Hash_Table_t* new_ht = ht_new_sized(base_size);
|
||||
for (int i = 0; i < ht->size; i++) {
|
||||
Hash_Item_t* item = ht->items[i];
|
||||
if (item != NULL && item != &HT_DELETED_ITEM) {
|
||||
ht_insert(new_ht, item->key, item->value);
|
||||
}
|
||||
}
|
||||
|
||||
ht->base_size = new_ht->base_size;
|
||||
ht->count = new_ht->count;
|
||||
|
||||
// To delete new_ht, we give it ht's size and items
|
||||
const int tmp_size = ht->size;
|
||||
ht->size = new_ht->size;
|
||||
new_ht->size = tmp_size;
|
||||
|
||||
Hash_Item_t** tmp_items = ht->items;
|
||||
ht->items = new_ht->items;
|
||||
new_ht->items = tmp_items;
|
||||
|
||||
ht_del_hash_table(new_ht);
|
||||
}
|
||||
|
||||
static void ht_resize_up(Hash_Table_t* ht) {
|
||||
const int new_size = ht->base_size * 2;
|
||||
ht_resize(ht, new_size);
|
||||
}
|
||||
|
||||
|
||||
static void ht_resize_down(Hash_Table_t* ht) {
|
||||
const int new_size = ht->base_size / 2;
|
||||
ht_resize(ht, new_size);
|
||||
}
|
||||
|
||||
void ht_insert(Hash_Table_t* ht, const char* key, const char* value) {
|
||||
const int load = ht->count * 100 / ht->size;
|
||||
if (load > 70) {
|
||||
ht_resize_up(ht);
|
||||
}
|
||||
Hash_Item_t* item = ht_new_item(key, value);
|
||||
int index = ht_get_hash(item->key, ht->size, 0);
|
||||
Hash_Item_t* cur_item = ht->items[index];
|
||||
int i = 1;
|
||||
while (cur_item != NULL) {
|
||||
if (cur_item != &HT_DELETED_ITEM) {
|
||||
if (strcmp(cur_item->key, key) == 0) {
|
||||
ht_del_item(cur_item);
|
||||
ht->items[index] = item;
|
||||
return;
|
||||
}
|
||||
}
|
||||
index = ht_get_hash(item->key, ht->size, i);
|
||||
cur_item = ht->items[index];
|
||||
i++;
|
||||
}
|
||||
ht->items[index] = item;
|
||||
ht->count++;
|
||||
}
|
||||
|
||||
char* ht_search(Hash_Table_t* ht, const char* key) {
|
||||
int index = ht_get_hash(key, ht->size, 0);
|
||||
Hash_Item_t* item = ht->items[index];
|
||||
int i = 1;
|
||||
while (item != NULL) {
|
||||
if (item != &HT_DELETED_ITEM) {
|
||||
if (strcmp(item->key, key) == 0) {
|
||||
return item->value;
|
||||
}
|
||||
}
|
||||
index = ht_get_hash(key, ht->size, i);
|
||||
item = ht->items[index];
|
||||
i++;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void ht_delete(Hash_Table_t* ht, const char* key) {
|
||||
const int load = ht->count * 100 / ht->size;
|
||||
if (load < 10) {
|
||||
ht_resize_down(ht);
|
||||
}
|
||||
int index = ht_get_hash(key, ht->size, 0);
|
||||
Hash_Item_t* item = ht->items[index];
|
||||
int i = 1;
|
||||
while (item != NULL) {
|
||||
if (item != &HT_DELETED_ITEM) {
|
||||
if (strcmp(item->key, key) == 0) {
|
||||
ht_del_item(item);
|
||||
ht->items[index] = &HT_DELETED_ITEM;
|
||||
}
|
||||
}
|
||||
index = ht_get_hash(key, ht->size, i);
|
||||
item = ht->items[index];
|
||||
i++;
|
||||
}
|
||||
ht->count--;
|
||||
}
|
||||
@@ -0,0 +1,36 @@
|
||||
#pragma once
|
||||
#ifndef HW_LIB_HASH_TABLE_H
|
||||
#define HW_LIB_HASH_TABLE_H
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define HT_PRIME_1 151
|
||||
#define HT_PRIME_2 163
|
||||
#define HT_INITIAL_BASE_SIZE 53
|
||||
|
||||
|
||||
typedef struct Hash_Item
|
||||
{
|
||||
char* key;
|
||||
char* value;
|
||||
} Hash_Item_t;
|
||||
|
||||
typedef struct Hash_Table
|
||||
{
|
||||
int base_size;
|
||||
int size;
|
||||
int count;
|
||||
Hash_Item_t** items;
|
||||
} Hash_Table_t;
|
||||
|
||||
Hash_Table_t* ht_new();
|
||||
void ht_del_hash_table(Hash_Table_t* ht);
|
||||
void ht_insert(Hash_Table_t* ht, const char* key, const char* value);
|
||||
char* ht_search(Hash_Table_t* ht, const char* key);
|
||||
void ht_delete(Hash_Table_t* h, const char* key);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
#endif //HW_LIB_HASH_TABLE_H
|
||||
File diff suppressed because it is too large
Load Diff
+6376
File diff suppressed because it is too large
Load Diff
+1
-1
@@ -4,7 +4,7 @@
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include "stdbool.h"
|
||||
#include "stdint.h"
|
||||
|
||||
|
||||
|
||||
@@ -3,6 +3,7 @@
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
#include "stdbool.h"
|
||||
typedef char OptId;
|
||||
|
||||
typedef struct Option {
|
||||
|
||||
@@ -5,7 +5,6 @@
|
||||
#include <ctime>
|
||||
#include <stdint.h>
|
||||
#include <cstdlib>
|
||||
#include <syncstream>
|
||||
#include "tool.h"
|
||||
|
||||
float Mapping(float val, float I_Min, float I_Max, float O_Min, float O_Max) {
|
||||
|
||||
@@ -12,7 +12,7 @@
|
||||
#include "t_tft.h"
|
||||
#include "tool.h"
|
||||
#include "sim_test.h"
|
||||
|
||||
#include "t_lui.h"
|
||||
#include <windows.h>
|
||||
#include <stdint.h>
|
||||
#include <SDL3/SDL.h>
|
||||
@@ -160,9 +160,11 @@ int main(int argc, char *argv[]) {
|
||||
// Test_Run("List", Test_List,NULL);
|
||||
// Test_RunTime("Key", Test_Key);
|
||||
// Test_RunTime("Queue", Test_Queue);
|
||||
// Test_RunTime("Hash", Test_Hash);
|
||||
// Test_RunTime("Task", Test_task);
|
||||
Test_RunTime("OLED", Test_OLED);
|
||||
// Test_RunTime("OLED", Test_OLED);
|
||||
// Test_RunTime("LVGL", Test_lvgl);
|
||||
// Test_RunTime("TFT", Test_tft);
|
||||
Test_RunTime("LUI", Test_lui);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -4,7 +4,6 @@
|
||||
|
||||
#include <ctime>
|
||||
#include <cstdio>
|
||||
#include <syncstream>
|
||||
#include "sim_test.h"
|
||||
|
||||
void Test_RunTime(char *name, int (*pFunction)(void *)) {
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
#include "sim_display.h"
|
||||
#include "graphics.h"
|
||||
#include <conio.h>
|
||||
|
||||
|
||||
#define GET_BIT(x, bit) ((x & (1 << bit)) >> bit)
|
||||
|
||||
@@ -20,6 +19,10 @@ uint32_t RGB565_to_ARGB8888(uint16_t rgb565, bool isBGR) {
|
||||
}
|
||||
}
|
||||
#ifndef USER_SDL3
|
||||
|
||||
#include "graphics.h"
|
||||
#include <conio.h>
|
||||
|
||||
static uint32_t pixelColor, backgroundColor;
|
||||
static int scaleFactor, w, h;
|
||||
uint8_t border;
|
||||
|
||||
@@ -12,8 +12,6 @@
|
||||
*********************/
|
||||
#include "lv_port_indev.h"
|
||||
#include "lvgl.h"
|
||||
#include "graphics.h"
|
||||
#include <easyx.h>
|
||||
/*********************
|
||||
* DEFINES
|
||||
*********************/
|
||||
@@ -253,8 +251,8 @@ static void mouse_read(lv_indev_drv_t * indev_drv, lv_indev_data_t * data)
|
||||
static bool mouse_is_pressed(void)
|
||||
{
|
||||
/*Your code comes here*/
|
||||
ExMessage msg;peekmessage(&msg, EM_MOUSE);
|
||||
if(msg.message==WM_LBUTTONDOWN) return true;
|
||||
// ExMessage msg;peekmessage(&msg, EM_MOUSE);
|
||||
// if(msg.message==WM_LBUTTONDOWN) return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
@@ -262,13 +260,13 @@ static bool mouse_is_pressed(void)
|
||||
static void mouse_get_xy(lv_coord_t * x, lv_coord_t * y)
|
||||
{
|
||||
/*Your code comes here*/
|
||||
ExMessage msg;
|
||||
if(peekmessage(&msg, EM_MOUSE))
|
||||
{
|
||||
(*x) = msg.x;
|
||||
(*y) = msg.y;
|
||||
printf("\nX:%d,Y:%d",*x,*y);
|
||||
}
|
||||
// ExMessage msg;
|
||||
// if(peekmessage(&msg, EM_MOUSE))
|
||||
// {
|
||||
// (*x) = msg.x;
|
||||
// (*y) = msg.y;
|
||||
// printf("\nX:%d,Y:%d",*x,*y);
|
||||
// }
|
||||
}
|
||||
|
||||
/*------------------
|
||||
|
||||
@@ -1,6 +1,4 @@
|
||||
#include "sim_oled.h"
|
||||
#include "graphics.h"
|
||||
#include <conio.h>
|
||||
|
||||
static SIM_Display_t oled_display;
|
||||
void SIM_OLED_INIT(int width, int height, uint32_t pixcolor, uint32_t backcolor, int scale, uint8_t b) {
|
||||
|
||||
Reference in New Issue
Block a user