当前位置: 首页 > article >正文

LVGL Dropdown和Calendar详解

LVGL Dropdown和Calendar详解

  • 一、Dropdown详解
      • 创建和初始化
      • 设置下拉框选项
      • 获取选项
        • 获取选中项文本:
        • 获取选中项索引:
        • 设置选中项:
      • 事件处理
      • 其他功能和样式设置
        • 设置下拉按钮样式:
        • 设置下拉框方向:
        • 设置最大高度:
        • 设置隐藏滚动条:
      • 样式自定义
      • 高级功能
        • 获取选项总数:
        • 设置选项字符串动态更新:
      • 多语言支持
      • 典型应用场景
  • 二、Calendar详解
    • 基本概念
    • 创建和初始化日历
      • 设置当前显示的日期
    • 标记日期
      • 定义标记日期数组
      • 设置标记日期
    • 获取选定日期
      • 添加事件回调
    • 样式与外观
      • 样式分区
        • 修改样式示例
    • 扩展功能
      • 事件切换月份
    • 高级功能
      • 获取显示月份和年份:
      • 设置日历尺寸:
      • 禁用点击选择:
    • 典型应用场景
  • 三、效果展示
  • 四、源码分享

一、Dropdown详解

LVGL(Light and Versatile Graphics Library)是一个开源的嵌入式图形库,其中 lv_dropdown 是下拉框部件(Drop-down List)的实现。它允许用户在多个选项中选择一个,非常适用于表单选择类应用场景。下面是关于 lv_dropdown 的详细解析。


创建和初始化

要创建一个下拉框,可以通过以下方法:

lv_obj_t * dropdown = lv_dropdown_create(lv_scr_act());  // 创建一个下拉框对象
lv_obj_set_pos(dropdown, 10, 10);                       // 设置下拉框位置
lv_obj_set_size(dropdown, 120, 30);                     // 设置下拉框的尺寸

设置下拉框选项

下拉框的选项可以通过 lv_dropdown_set_options() 来设置。选项定义为一个字符串,选项之间用换行符 \n 分隔。

lv_dropdown_set_options(dropdown, "Option 1\nOption 2\nOption 3\nOption 4");

动态追加或修改选项时,可以动态拼接字符串再更新。


获取选项

获取选中项文本:
const char * txt = lv_dropdown_get_selected_str(dropdown);
printf("Selected: %s\n", txt);
获取选中项索引:
uint16_t index = lv_dropdown_get_selected(dropdown);
printf("Selected index: %d\n", index);
设置选中项:
lv_dropdown_set_selected(dropdown, 2);  // 选中索引为2的选项(索引从0开始)

事件处理

下拉框通常需要响应用户的选择行为,可以通过事件回调来处理。示例代码:

void dropdown_event_cb(lv_event_t * e)
{lv_obj_t * dropdown = lv_event_get_target(e);if(lv_event_get_code(e) == LV_EVENT_VALUE_CHANGED) {const char * selected = lv_dropdown_get_selected_str(dropdown);printf("Dropdown selected: %s\n", selected);}
}lv_obj_add_event_cb(dropdown, dropdown_event_cb, LV_EVENT_VALUE_CHANGED, NULL);

在上述代码中,事件 LV_EVENT_VALUE_CHANGED 触发时可以获取到当前选中的项。


其他功能和样式设置

设置下拉按钮样式:

通过 lv_dropdown_set_text() 方法可以设置按钮上的显示文本:

lv_dropdown_set_text(dropdown, "Choose an option");
设置下拉框方向:

通过设置下拉框的方向,可以控制下拉框展开的方式(例如向下或向上):

lv_dropdown_set_dir(dropdown, LV_DIR_BOTTOM);  // 设置下拉展开方向为向下(默认)

其他方向可设置为 LV_DIR_TOP, LV_DIR_LEFT, LV_DIR_RIGHT,根据需求调整布局。

设置最大高度:

如果选项很多,超过最大高度时,下拉框将自动显示滚动条。

lv_dropdown_set_max_height(dropdown, 150);  // 设置下拉框的最大高度
设置隐藏滚动条:

可以通过样式来让滚动条不可见。

lv_obj_remove_style(dropdown, NULL, LV_PART_SCROLLBAR);

样式自定义

通过样式可以自定义下拉框外观(颜色、大小、字体等)。部分样式示例:

// 创建样式
lv_style_t style;
lv_style_init(&style);
lv_style_set_bg_color(&style, lv_color_hex(0x123456));   // 设置背景颜色
lv_style_set_text_font(&style, &lv_font_montserrat_18); // 设置选项文本字体// 应用样式到下拉框
lv_obj_add_style(dropdown, &style, LV_PART_MAIN);       // 给主部分应用样式
lv_obj_add_style(dropdown, &style, LV_PART_SELECTED);   // 给选中部分应用样式

高级功能

获取选项总数:

可以通过 lv_dropdown_get_option_cnt() 获取选项数量:

uint16_t count = lv_dropdown_get_option_cnt(dropdown);
printf("Option count: %d\n", count);
设置选项字符串动态更新:

可以替换所有选项:

lv_dropdown_set_options(dropdown, "New Option 1\nNew Option 2");

也可以通过 lv_dropdown_add_option() 向当前选项列表追加新选项:

lv_dropdown_add_option(dropdown, "New Option");  // 追加一个选项

多语言支持

下拉框选项支持直接输入 Unicode 字符,可以显示多语言字体。如果使用多语言环境,则需要将所需字体绑定到 LVGL,并正确编码。


典型应用场景

  1. 表单选择:用户在多个选项中选择一个(例如国家、性别、语言等)。
  2. 嵌入式配置调整:如用户在设备中选择模式(例如“自动模式”“手动模式”)。
  3. 游戏或图形应用:下拉框用于选择道具、设置画笔大小等。

以上是 LVGL 中 lv_dropdown 的详解。根据实际项目需求,可以灵活利用下拉框部件并进行样式定制!

二、Calendar详解

LVGL(Light and Versatile Graphics Library)的 lv_calendar 是一个用于显示日期(或日历)的组件。它非常适用于需要时间数据交互的场景,比如用户选择日期、显示特定活动的时间表等。以下是对 lv_calendar 的详解,涵盖创建、使用、样式和事件处理。


基本概念

lv_calendar 是一个日历组件,显示一个月的日期,支持突出显示当天的日期,并标记多个关键日期。用户可以通过点击日期来选择它,也可以通过程序控制日期变化。


创建和初始化日历

创建一个日历,可以使用 lv_calendar_create() 函数。示例如下:

lv_obj_t * calendar = lv_calendar_create(lv_scr_act());  // 创建日历对象
lv_obj_set_size(calendar, 220, 220);                     // 设置尺寸
lv_obj_center(calendar);                                 // 放置在屏幕中心

设置当前显示的日期

通过 lv_calendar_set_today_date() 来设置今天的日期。通过 lv_calendar_set_showed_date() 来设置当前显示的月份和年份。

lv_calendar_set_today_date(calendar, 2023, 10, 20);  // 设置今天的日期为 2023年10月20日
lv_calendar_set_showed_date(calendar, 2023, 10);     // 显示 2023年10月

标记日期

日历支持标记(highlight)一些日期。标记的日期会以特殊样式显示出来。

定义标记日期数组

首先,需要定义一个数组用于存储标记日期:

static lv_calendar_date_t highlighted_days[3];
highlighted_days[0].year = 2023; highlighted_days[0].month = 10; highlighted_days[0].day = 15;
highlighted_days[1].year = 2023; highlighted_days[1].month = 10; highlighted_days[1].day = 18;
highlighted_days[2].year = 2023; highlighted_days[2].month = 10; highlighted_days[2].day = 25;

设置标记日期

通过 lv_calendar_set_highlighted_dates() 将标记日期数组传递给日历:

lv_calendar_set_highlighted_dates(calendar, highlighted_days, 3);  // 标记3个日期

获取选定日期

日历组件允许用户通过点击选择一个日期。可以通过事件回调捕获用户点击的行为并获取选定的日期。

添加事件回调

使用 LV_EVENT_VALUE_CHANGED 事件获取用户已选择的日期:

void calendar_event_handler(lv_event_t * e)
{lv_obj_t * calendar = lv_event_get_target(e);if(lv_event_get_code(e) == LV_EVENT_VALUE_CHANGED) {const lv_calendar_date_t * selected_date = lv_calendar_get_pressed_date(calendar);if(selected_date) {printf("Selected date: %d-%02d-%02d\n", selected_date->year, selected_date->month, selected_date->day);}}
}lv_obj_add_event_cb(calendar, calendar_event_handler, LV_EVENT_VALUE_CHANGED, NULL);

样式与外观

通过样式可以定制日历的每一个部分(背景、标题、日期样式等)。

样式分区

日历的样式分为以下几个部分:

  • LV_PART_MAIN: 主背景部分。
  • LV_PART_HEADER: 月份和年份显示的区域。
  • LV_PART_DATE: 日期单元格,包括普通日期、今天和标记日期。
  • LV_PART_SELECTED: 用户选择的日期单元格。
修改样式示例
// 创建样式
lv_style_t style;
lv_style_init(&style);// 设置背景颜色
lv_style_set_bg_color(&style, lv_color_hex(0xFFFFFF));      // 白色背景
lv_style_set_text_color(&style, lv_color_hex(0x0000FF));    // 蓝色文本// 应用样式到所有日期单元格
lv_obj_add_style(calendar, &style, LV_PART_DATE);// 设置选中单元格的样式
lv_style_set_border_color(&style, lv_color_hex(0xFF0000));  // 红色边框
lv_obj_add_style(calendar, &style, LV_PART_SELECTED);

扩展功能

事件切换月份

如果需要监听日历的月份切换事件,可以监控 LV_EVENT_VALUE_CHANGED。例如,当用户切换月份时可以触发显示新的数据。

void month_switch_event_cb(lv_event_t * e)
{lv_obj_t * calendar = lv_event_get_target(e);uint16_t year;uint8_t month;lv_calendar_get_showed_date(calendar, &year, &month);printf("Currently showing: %d-%02d\n", year, month);
}lv_obj_add_event_cb(calendar, month_switch_event_cb, LV_EVENT_VALUE_CHANGED, NULL);

高级功能

获取显示月份和年份:

使用 lv_calendar_get_showed_date() 函数获取当前正在显示的月份和年份。

uint16_t displayed_year;
uint8_t displayed_month;
lv_calendar_get_showed_date(calendar, &displayed_year, &displayed_month);
printf("Year: %d, Month: %d\n", displayed_year, displayed_month);

设置日历尺寸:

通过 lv_obj_set_size() 可以调整日历的大小。日历会自动调整内容布局以适应新的大小。

lv_obj_set_size(calendar, 250, 250);  // 设置日历尺寸

禁用点击选择:

如果不希望用户选择日期,可以用样式或事件屏蔽点击。


典型应用场景

  • 日期选择器:用户通过日历选择某一天,类似于会议预约系统。
  • 活动标记:显示带标记的日期,例如当前月份的重要活动日期。
  • 实时时间显示:结合 RTC 或后台时间数据源,实时显示当前日期或时间。

总结起来,lv_calendar 是一个功能丰富且易用的组件。通过灵活的样式设置和事件管理,可以实现各种日历相关的交互界面。根据实际需求,可以进一步扩展实现复杂的时间功能。

三、效果展示

在这里插入图片描述

四、源码分享

.h

typedef struct
{lv_obj_t *screen;bool screen_del;lv_obj_t *screen_ddlist_1;lv_obj_t *screen_calendar_1;
}lv_ui;

.c

#include "lvgl.h"
#include <stdio.h>
#include "gui_guider.h"
#include "events_init.h"
#include "widgets_init.h"
#include "custom.h"lv_calendar_date_t screen_calendar_1_today;
lv_calendar_date_t screen_calendar_1_highlihted_days[1];
void setup_scr_screen(lv_ui *ui)
{//Write codes screenui->screen = lv_obj_create(NULL);lv_obj_set_size(ui->screen, 800, 480);lv_obj_set_scrollbar_mode(ui->screen, LV_SCROLLBAR_MODE_OFF);//Write style for screen, Part: LV_PART_MAIN, State: LV_STATE_DEFAULT.lv_obj_set_style_bg_opa(ui->screen, 255, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_bg_color(ui->screen, lv_color_hex(0x21d0e3), LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_bg_grad_dir(ui->screen, LV_GRAD_DIR_NONE, LV_PART_MAIN|LV_STATE_DEFAULT);//Write codes screen_ddlist_1ui->screen_ddlist_1 = lv_dropdown_create(ui->screen);lv_dropdown_set_options(ui->screen_ddlist_1, "list1\nlist2\nlist3\nlist4");lv_obj_set_pos(ui->screen_ddlist_1, 499, 109);lv_obj_set_size(ui->screen_ddlist_1, 217, 29);//Write style for screen_ddlist_1, Part: LV_PART_MAIN, State: LV_STATE_DEFAULT.lv_obj_set_style_text_color(ui->screen_ddlist_1, lv_color_hex(0x0D3055), LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_text_font(ui->screen_ddlist_1, &lv_font_montserratMedium_12, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_text_opa(ui->screen_ddlist_1, 255, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_border_width(ui->screen_ddlist_1, 1, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_border_opa(ui->screen_ddlist_1, 255, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_border_color(ui->screen_ddlist_1, lv_color_hex(0xe1e6ee), LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_border_side(ui->screen_ddlist_1, LV_BORDER_SIDE_FULL, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_pad_top(ui->screen_ddlist_1, 8, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_pad_left(ui->screen_ddlist_1, 6, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_pad_right(ui->screen_ddlist_1, 6, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_radius(ui->screen_ddlist_1, 3, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_bg_opa(ui->screen_ddlist_1, 255, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_bg_color(ui->screen_ddlist_1, lv_color_hex(0xffffff), LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_bg_grad_dir(ui->screen_ddlist_1, LV_GRAD_DIR_NONE, LV_PART_MAIN|LV_STATE_DEFAULT);lv_obj_set_style_shadow_width(ui->screen_ddlist_1, 0, LV_PART_MAIN|LV_STATE_DEFAULT);//Write style state: LV_STATE_CHECKED for &style_screen_ddlist_1_extra_list_selected_checkedstatic lv_style_t style_screen_ddlist_1_extra_list_selected_checked;ui_init_style(&style_screen_ddlist_1_extra_list_selected_checked);lv_style_set_border_width(&style_screen_ddlist_1_extra_list_selected_checked, 1);lv_style_set_border_opa(&style_screen_ddlist_1_extra_list_selected_checked, 255);lv_style_set_border_color(&style_screen_ddlist_1_extra_list_selected_checked, lv_color_hex(0xe1e6ee));lv_style_set_border_side(&style_screen_ddlist_1_extra_list_selected_checked, LV_BORDER_SIDE_FULL);lv_style_set_radius(&style_screen_ddlist_1_extra_list_selected_checked, 3);lv_style_set_bg_opa(&style_screen_ddlist_1_extra_list_selected_checked, 255);lv_style_set_bg_color(&style_screen_ddlist_1_extra_list_selected_checked, lv_color_hex(0x00a1b5));lv_style_set_bg_grad_dir(&style_screen_ddlist_1_extra_list_selected_checked, LV_GRAD_DIR_NONE);lv_obj_add_style(lv_dropdown_get_list(ui->screen_ddlist_1), &style_screen_ddlist_1_extra_list_selected_checked, LV_PART_SELECTED|LV_STATE_CHECKED);//Write style state: LV_STATE_DEFAULT for &style_screen_ddlist_1_extra_list_main_defaultstatic lv_style_t style_screen_ddlist_1_extra_list_main_default;ui_init_style(&style_screen_ddlist_1_extra_list_main_default);lv_style_set_max_height(&style_screen_ddlist_1_extra_list_main_default, 90);lv_style_set_text_color(&style_screen_ddlist_1_extra_list_main_default, lv_color_hex(0x0D3055));lv_style_set_text_font(&style_screen_ddlist_1_extra_list_main_default, &lv_font_montserratMedium_12);lv_style_set_text_opa(&style_screen_ddlist_1_extra_list_main_default, 255);lv_style_set_border_width(&style_screen_ddlist_1_extra_list_main_default, 1);lv_style_set_border_opa(&style_screen_ddlist_1_extra_list_main_default, 255);lv_style_set_border_color(&style_screen_ddlist_1_extra_list_main_default, lv_color_hex(0xe1e6ee));lv_style_set_border_side(&style_screen_ddlist_1_extra_list_main_default, LV_BORDER_SIDE_FULL);lv_style_set_radius(&style_screen_ddlist_1_extra_list_main_default, 3);lv_style_set_bg_opa(&style_screen_ddlist_1_extra_list_main_default, 255);lv_style_set_bg_color(&style_screen_ddlist_1_extra_list_main_default, lv_color_hex(0xffffff));lv_style_set_bg_grad_dir(&style_screen_ddlist_1_extra_list_main_default, LV_GRAD_DIR_NONE);lv_obj_add_style(lv_dropdown_get_list(ui->screen_ddlist_1), &style_screen_ddlist_1_extra_list_main_default, LV_PART_MAIN|LV_STATE_DEFAULT);//Write style state: LV_STATE_DEFAULT for &style_screen_ddlist_1_extra_list_scrollbar_defaultstatic lv_style_t style_screen_ddlist_1_extra_list_scrollbar_default;ui_init_style(&style_screen_ddlist_1_extra_list_scrollbar_default);lv_style_set_radius(&style_screen_ddlist_1_extra_list_scrollbar_default, 3);lv_style_set_bg_opa(&style_screen_ddlist_1_extra_list_scrollbar_default, 255);lv_style_set_bg_color(&style_screen_ddlist_1_extra_list_scrollbar_default, lv_color_hex(0x00ff00));lv_style_set_bg_grad_dir(&style_screen_ddlist_1_extra_list_scrollbar_default, LV_GRAD_DIR_NONE);lv_obj_add_style(lv_dropdown_get_list(ui->screen_ddlist_1), &style_screen_ddlist_1_extra_list_scrollbar_default, LV_PART_SCROLLBAR|LV_STATE_DEFAULT);//Write codes screen_calendar_1ui->screen_calendar_1 = lv_calendar_create(ui->screen);screen_calendar_1_today.year = 2025;screen_calendar_1_today.month = 4;screen_calendar_1_today.day = 1;lv_calendar_set_today_date(ui->screen_calendar_1, screen_calendar_1_today.year, screen_calendar_1_today.month, screen_calendar_1_today.day);lv_calendar_set_showed_date(ui->screen_calendar_1, screen_calendar_1_today.year, screen_calendar_1_today.month);screen_calendar_1_highlihted_days[0].year = 2025;screen_calendar_1_highlihted_days[0].month = 4;screen_calendar_1_highlihted_days[0].day = 2;lv_calendar_set_highlighted_dates(ui->screen_calendar_1, screen_calendar_1_highlihted_days, 1);lv_obj_t *screen_calendar_1_header = lv_calendar_header_arrow_create(ui->screen_calendar_1);lv_calendar_t *screen_calendar_1 = (lv_calendar_t *)ui->screen_calendar_1;lv_obj_add_event_cb(screen_calendar_1->btnm, screen_calendar_1_draw_part_begin_event_cb, LV_EVENT_DRAW_PART_BEGIN, NULL);lv_obj_add_event_cb(ui->screen_calendar_1, screen_calendar_1_event_handler, LV_EVENT_ALL, NULL);lv_obj_set_pos(ui->screen_calendar_1, 99, 96);lv_obj_set_size(ui->screen_calendar_1, 280, 210);//Write style state: LV_STATE_DEFAULT for &style_screen_calendar_1_main_main_defaultstatic lv_style_t style_screen_calendar_1_main_main_default;ui_init_style(&style_screen_calendar_1_main_main_default);lv_style_set_border_width(&style_screen_calendar_1_main_main_default, 1);lv_style_set_border_opa(&style_screen_calendar_1_main_main_default, 255);lv_style_set_border_color(&style_screen_calendar_1_main_main_default, lv_color_hex(0xc0c0c0));lv_style_set_border_side(&style_screen_calendar_1_main_main_default, LV_BORDER_SIDE_FULL);lv_style_set_bg_opa(&style_screen_calendar_1_main_main_default, 255);lv_style_set_bg_color(&style_screen_calendar_1_main_main_default, lv_color_hex(0xffffff));lv_style_set_bg_grad_dir(&style_screen_calendar_1_main_main_default, LV_GRAD_DIR_NONE);lv_style_set_shadow_width(&style_screen_calendar_1_main_main_default, 0);lv_style_set_radius(&style_screen_calendar_1_main_main_default, 0);lv_obj_add_style(ui->screen_calendar_1, &style_screen_calendar_1_main_main_default, LV_PART_MAIN|LV_STATE_DEFAULT);//Write style state: LV_STATE_DEFAULT for &style_screen_calendar_1_extra_header_main_defaultstatic lv_style_t style_screen_calendar_1_extra_header_main_default;ui_init_style(&style_screen_calendar_1_extra_header_main_default);lv_style_set_text_color(&style_screen_calendar_1_extra_header_main_default, lv_color_hex(0xffffff));lv_style_set_text_font(&style_screen_calendar_1_extra_header_main_default, &lv_font_montserratMedium_12);lv_style_set_text_opa(&style_screen_calendar_1_extra_header_main_default, 255);lv_style_set_bg_opa(&style_screen_calendar_1_extra_header_main_default, 255);lv_style_set_bg_color(&style_screen_calendar_1_extra_header_main_default, lv_color_hex(0x2195f6));lv_style_set_bg_grad_dir(&style_screen_calendar_1_extra_header_main_default, LV_GRAD_DIR_NONE);lv_obj_add_style(screen_calendar_1_header, &style_screen_calendar_1_extra_header_main_default, LV_PART_MAIN|LV_STATE_DEFAULT);//Write style state: LV_STATE_DEFAULT for &style_screen_calendar_1_main_items_defaultstatic lv_style_t style_screen_calendar_1_main_items_default;ui_init_style(&style_screen_calendar_1_main_items_default);lv_style_set_bg_opa(&style_screen_calendar_1_main_items_default, 0);lv_style_set_border_width(&style_screen_calendar_1_main_items_default, 1);lv_style_set_border_opa(&style_screen_calendar_1_main_items_default, 255);lv_style_set_border_color(&style_screen_calendar_1_main_items_default, lv_color_hex(0xc0c0c0));lv_style_set_border_side(&style_screen_calendar_1_main_items_default, LV_BORDER_SIDE_FULL);lv_style_set_text_color(&style_screen_calendar_1_main_items_default, lv_color_hex(0x0D3055));lv_style_set_text_font(&style_screen_calendar_1_main_items_default, &lv_font_montserratMedium_12);lv_style_set_text_opa(&style_screen_calendar_1_main_items_default, 255);lv_obj_add_style(lv_calendar_get_btnmatrix(ui->screen_calendar_1), &style_screen_calendar_1_main_items_default, LV_PART_ITEMS|LV_STATE_DEFAULT);//The custom code of screen.//Update current screen layout.lv_obj_update_layout(ui->screen);}

相关文章:

LVGL Dropdown和Calendar详解

LVGL Dropdown和Calendar详解 一、Dropdown详解创建和初始化设置下拉框选项获取选项获取选中项文本&#xff1a;获取选中项索引&#xff1a;设置选中项&#xff1a; 事件处理其他功能和样式设置设置下拉按钮样式&#xff1a;设置下拉框方向&#xff1a;设置最大高度&#xff1a…...

AISEO (GEO )中的知识图谱

一、知识图谱在AI SEO中的概念与结构 1. 知识图谱是什么&#xff1f; 定义&#xff1a;知识图谱&#xff08;Knowledge Graph&#xff09;是一种以图结构组织的语义网络&#xff0c;由实体&#xff08;Entity&#xff09;、**关系&#xff08;Relation&#xff09;和属性&…...

Vulnhub-zico2靶机打靶记录

本篇文章旨在为网络安全渗透测试靶机教学。通过阅读本文&#xff0c;读者将能够对渗透Vulnhub系列zico2靶机有一定的了解 一、信息收集阶段 靶机下载地址&#xff1a;https://download.vulnhub.com/zico/zico2.ova 因为靶机为本地部署虚拟机网段&#xff0c;查看dhcp地址池设…...

(041)05-01-自考数据结构(20331)树与二叉树大题总结

实际考试中,计算题约占40%,推理题约占30%,算法设计题约占30%。建议重点练习遍历序列相关的递归分治解法, 知识拓扑 知识点介绍 一、计算题类型与解法 1. 结点数量计算 题型示例: 已知一棵完全二叉树的第6层有8个叶子结点,求该二叉树最多有多少个结点? 解法步骤: 完…...

Python----机器学习(KNN:使用数学方法实现KNN)

一、原理 以下是K最近邻&#xff08;K-Nearest Neighbors&#xff0c;简称KNN&#xff09;算法的基本流程&#xff0c;用于对给定点进行分类预测。 1. 获得要预测的点 point_predict 。 2. 计算训练点集 point_set_train 中各点到要预测的点 表 l ist_L2_distance 。 3. 对 poi…...

网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.2 ret2libc

上一篇&#xff1a;网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.1 ret2text和ret2shellcode 下一篇&#xff1a;网络攻防快速入门笔记pwn | 02 栈溢出题型 | 2.3 ret2syscall 欢迎关注~ ret2libc 一、 什么是ret2libc&#xff08;一&#xff09;ret2lib的概念&#xff08;…...

Edge浏览器快速开启IE模式

一些老旧的网站&#xff0c;仅支持Internet Explorer&#xff08;IE&#xff09;浏览器访问。 然而&#xff0c;出于安全性的考虑&#xff0c;可能会遇到限制IE浏览器使用的情况。 Microsoft Edge浏览器提供了兼容性配置&#xff0c;可以通过IE模式访问这些网站。 以下是两种…...

技术长期主义:用本分思维重构JavaScript逆向知识体系(一)Babel、AST、ES6+、ES5、浏览器环境、Node.js环境的关系和处理流程

基础不牢&#xff0c;地动山摇&#xff0c;逆向越久&#xff0c;越发现基础的重要性&#xff0c;本系列&#xff0c;回顾js逆向基础&#xff0c;让自己的知识体系更加系统化。 以下是 Babel、AST、ES6、ES5、浏览器环境、Node.js环境 的关系和流程的详细说明及图表&#xff1a;…...

Oracle 数据库系统全面详解

Oracle 数据库是全球领先的关系型数据库管理系统(RDBMS)&#xff0c;由 Oracle 公司开发。它为企业级应用提供了高性能、高可用性、安全性和可扩展性的数据管理解决方案。 目录 一、Oracle 数据库体系结构 1. 物理存储结构 主要组件&#xff1a; 存储层次&#xff1a; 2. …...

LeetCode 解题思路 29(Hot 100)

解题思路&#xff1a; 映射关系建立&#xff1a;创建一个哈希表存储数字到字母的映射。递归参数&#xff1a; 给定字符串 digits、结果集 result、当前路径 path、当前位置 start。递归过程&#xff1a; 当当前位置 start 等于 digits 长度时&#xff0c;说明已经遍历完 digi…...

使用Python解析PPT文件并生成JSON结构详解

引言 PowerPoint&#xff08;PPT&#xff09;文件的自动化处理是办公自动化和数据提取的常见需求。本文将介绍如何通过Python的python-pptx库&#xff0c;将PPT文件的样式、结构、文本内容等信息解析为标准化的JSON格式&#xff0c;为后续的自动化处理、数据迁移或样式复用提供…...

LabVIEW永磁同步电机性能测试系统

开发了一种基于LabVIEW的永磁同步电机&#xff08;PMSM&#xff09;性能测试系统的设计及应用。该系统针对新能源汽车使用的电机进行稳态性能测试&#xff0c;解决了传统测试方法成本高、效率低的问题&#xff0c;实现了测试自动化&#xff0c;提高了数据的准确性和客观性。 ​…...

MTK Camera 照片切视频Systrace拆解分析

和你一起终身学习&#xff0c;这里是程序员Android 经典好文推荐&#xff0c;通过阅读本文&#xff0c;您将收获以下知识点: 一、Systrace 拆解概览二、Systrace 阶段拆解详解 一、Systrace 拆解概览 MTK Camera 照片切换视频trace 拆解(非切换摄像头类) 照片切换视频模块trace…...

某合约任意提取BNB漏洞

1背景描述 合约是一个在满足特定条件时在区块链上执行代码的程序&#xff0c;各方以数字签署合同的方式准许并维护它的其运行。这些代码可以是向朋友汇款、买卖 NFT 虚拟商品等一系列复杂的内容。 存在漏洞的目标合约是一个结合Meme文化病毒式传播与去中心化金融&#xff08;D…...

Linux_3.2

今天继续学习shell语法 shell类似一个面向过程的语言,要区分好面向过程和面向对象的语言的区别。 循环语句 for循环 for i in a 2 cc doecho $i done #输出a 2 ccfor file in `ls` doecho $file done #输出ls命令的输出for i in $(seq 1 10) doecho $i done #输出1-10,seq…...

插件实现:分别通过winform和WPF界面输入操作CAD——CAD c#二次开发

效果如下图所示&#xff1a; 主程序 using Autodesk.AutoCAD.ApplicationServices; using Autodesk.AutoCAD.DatabaseServices; using Autodesk.AutoCAD.EditorInput; using Autodesk.AutoCAD.Geometry; using Autodesk.AutoCAD.Runtime; using System; using System.Windows…...

【学Rust写CAD】20 平铺模式结构体(spread.rs)

这个 Spread。rs文件定义了渐变超出定义区域时的扩展方式&#xff0c;通常用于处理渐变在边界之外的行为。 源码 //color/spread.rs #[derive(Debug, Clone, Copy)] pub struct Pad; // 空结构体&#xff0c;表示 Pad 模式#[derive(Debug, Clone, Copy)] pub struct Reflect…...

maya调整全局关节显示大小

请按以下步骤操作&#xff1a; 在 Maya 主菜单栏中&#xff0c;找到 Display (显示) 菜单。 在 Display 菜单下&#xff0c;找到 Animation (动画) 子菜单。 在 Animation 子菜单中&#xff0c;点击 Joint Size... (关节大小...)。 这时会弹出一个小窗口或者直接在界面上出现…...

白酒迈入3.0时代,珍酒李渡如何穿越周期高质增长?

当下&#xff0c;白酒行业仍处深度调整期&#xff0c;过往通过渠道拓展、硬广宣传等推动规模扩张、提升市场份额的模式&#xff0c;愈发难以为继。 行业迫切需要构建高质增长新模式&#xff0c;完成增长动能转换。中国酒业协会理事长宋书玉提出&#xff0c;白酒消费亟需进入品…...

HTTP代理:网页加速的隐形引擎

目录 引言&#xff1a;网页加载速度为何至关重要&#xff1f; 一、HTTP代理的核心加速原理 二、四大加速黑科技详解 三、实战场景性能对比 四、代理加速的隐藏代价 五、未来发展趋势 结语&#xff1a;智能代理的选型指南 引言&#xff1a;网页加载速度为何至关重要&#…...

人工智能-LangGraph+ChatUI+DeepSeek API搭建本地智能助手

人工智能-LangGraphChatUIDeepSeek API搭建本地智能助手 0 环境说明1 LangGraph2 Agent Chat UI 0 环境说明 环境项环境说明操作系统Windows11 专业版硬件信息联想拯救者Y9000PcondaAnancondaPython版本3.12NodeJs18.20.0 # 使用conda创建python环境 conda create -n langgra…...

3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件,无需一个个打开max,材质贴图在

3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件&#xff0c;无需一个个打开max&#xff0c;材质贴图在 3dmax批量转glb/gltf/fbx/osgb/stl/3ds/dae/obj/skp格式导出转换插件&#xff0c;无需一个个打开max&#xff0c;材质贴图在...

虚幻5入门

常用操作 运行时&#xff0c;调试相机&#xff0c;按~键&#xff0c;输入ToggleDebugCamera 。进入自由视角 常用节点 gate节点&#xff1a;用于控制该流程通不通&#xff0c;执不执行。Flip Flop节点&#xff1a;反转执行&#xff0c;一次A&#xff0c;一次B。Set Timer by…...

【解决】Edge浏览器硬件加速问题:无法滚动与卡顿的应对方法

Edge浏览器开启硬件加速后无法滚动屏幕&#xff0c;关闭后虽然可以滚动但出现卡顿&#xff0c;可能是由多种原因导致的。以下是一些可能的解决方法&#xff1a; 1. 检查显卡驱动 更新显卡驱动&#xff1a;确保显卡驱动是最新版本。过时的驱动可能会导致硬件加速功能不稳定。回…...

慧通测控:汽车RGB氛围灯功能测试介绍

在汽车内饰不断进化的当下&#xff0c;汽车 RGB 氛围灯已从曾经的小众配置&#xff0c;逐渐成为众多车主提升驾乘体验的热门选择。它宛如车内的 “魔法精灵”&#xff0c;凭借丰富的功能&#xff0c;为单调的车厢披上一层梦幻而温馨的色彩。今天&#xff0c;让我们深入探究汽车…...

QML Book 学习基础6(定位/布局元素)

目录 定位元素 Column Row Grid Flow 布局元素 1.元素填充它的⽗元素。 2.对齐 定位元素 Column Column &#xff08;列&#xff09;元素将它的⼦对象通过顶部对⻬的列⽅式进⾏排列。 spacing 属性⽤来设置每个元素之间的间隔⼤⼩ Row Row &#xff08;⾏&#xff09;元…...

【SpringCloud】LoadBalance-负载均衡

4. 负载均衡-LoadBalance 4.1 为什么需要负载均衡&#xff1f; 不知道各位心中有没有女神&#xff0c;通常来说一个女神就会有多个舔狗&#xff0c;那这些舔狗呢&#xff0c;就会心甘情愿的帮女神干活&#xff0c;假设女神小美现在有三个舔狗&#xff0c;小美喜欢让这三个舔狗…...

自然语言处理(26:(终章Attention 2.)带Attention的seq2seq的实现)

系列文章目录 终章 1&#xff1a;Attention的结构 终章 2&#xff1a;带Attention的seq2seq的实现 终章 3&#xff1a;Attention的评价 终章 4&#xff1a;关于Attention的其他话题 终章 5&#xff1a;Attention的应用 目录 系列文章目录 前言 一、编码器的实现 二、解…...

Sentinel实战(二)、流控规则之流控阈值类型、流控模式

spring cloud Alibaba-sentinel-流控 流控规则前置环境一、基于阈值类型(QPS/线程数)维度,设置流控规则demo1、流控规则:设置QPS流控规则设置含义测试,观察流控规则设定后的效果demo2、流控规则-设置线程数流控规则设置含义测试,观察流控规则设定后的效果二、基于流控模…...

AI与.NET技术实操系列(四):使用 Semantic Kernel 和 DeepSeek 构建AI应用

1. 引言 在人工智能技术飞速发展的今天&#xff0c;大型语言模型&#xff08;Large Language Models, LLMs&#xff09;已成为智能应用开发的核心驱动力。从智能客服到自动化内容生成&#xff0c;LLMs的应用正在深刻改变我们的工作和生活方式。 对于.NET开发者而言&#xff0c;…...