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

LVGL Styles

LVGL Styles

  • Get started
    • 按钮添加标签
    • 按钮添加风格
    • 滑动条值显示
  • Styles
    • Size styles
    • Background styles
    • Border styles
    • Outline styles
    • Shadow styles
    • Image styles
    • Arc styles
    • Text styles
    • Line styles

Get started

按钮添加标签

/*** @brief 按钮事件回调函数* @param e 
*/
void btn_event_cb(lv_event_t* e)
{lv_event_code_t code = lv_event_get_code(e);lv_obj_t* btn = lv_event_get_current_target(e);if (LV_EVENT_CLICKED == code) {static uint8_t cnt = 0;cnt++;lv_obj_t* label = lv_obj_get_child(btn, 0);lv_label_set_text_fmt(label, "Button:%d", cnt);}
}/*** @brief Get started demo* @param  
*/
void lv_demo_get_started(void)
{lv_obj_t * btn = lv_btn_create(lv_scr_act());lv_obj_set_size(btn, 100, 50);lv_obj_set_pos(btn, 150, 100);lv_obj_add_event_cb(btn, btn_event_cb, LV_EVENT_ALL, NULL);lv_obj_t* label = lv_label_create(btn);lv_label_set_text(label, "Button:");lv_obj_center(label);
}

在这里插入图片描述

按钮添加风格

static lv_style_t style_btn;
static lv_style_t style_btn_pressed;
static lv_style_t style_btn_red;static lv_color_t darken(const lv_color_filter_dsc_t* dsc, lv_color_t color, lv_opa_t opa)
{LV_UNUSED(dsc);return lv_color_darken(color, opa);
}static void style_init(void)
{// 创建一个简单按钮风格lv_style_init(&style_btn);lv_style_set_radius(&style_btn, 10);lv_style_set_bg_opa(&style_btn, LV_OPA_COVER);lv_style_set_bg_color(&style_btn, lv_palette_lighten(LV_PALETTE_GREY, 3));lv_style_set_bg_grad_color(&style_btn, lv_palette_main(LV_PALETTE_GREY));lv_style_set_bg_grad_dir(&style_btn, LV_GRAD_DIR_VER);lv_style_set_border_color(&style_btn, lv_color_black());lv_style_set_border_opa(&style_btn, LV_OPA_20);lv_style_set_border_width(&style_btn, 2);lv_style_set_text_color(&style_btn, lv_color_black());// 创建按下状态风格static lv_color_filter_dsc_t color_filter;lv_color_filter_dsc_init(&color_filter, darken);lv_style_init(&style_btn_pressed);lv_style_set_color_filter_dsc(&style_btn_pressed, &color_filter);lv_style_set_color_filter_opa(&style_btn_pressed, LV_OPA_20);// 创建红色风格,仅改变一些颜色lv_style_init(&style_btn_red);lv_style_set_bg_color(&style_btn_red, lv_palette_main(LV_PALETTE_RED));lv_style_set_bg_grad_color(&style_btn_red, lv_palette_lighten(LV_PALETTE_RED, 3));
}void lv_demo_get_started2(void)
{/* Initialize the style */style_init();lv_obj_t* btn = lv_btn_create(lv_scr_act());lv_obj_remove_style_all(btn);lv_obj_set_size(btn, 120, 50);lv_obj_set_pos(btn, 10, 10);lv_obj_add_style(btn, &style_btn, 0); // LV_STATE_DEFAULTlv_obj_add_style(btn, &style_btn_pressed, LV_STATE_PRESSED);/* Add a label to the button */lv_obj_t* label = lv_label_create(btn);lv_label_set_text(label, "Button");lv_obj_center(label);/* Create another button and use the red style too */lv_obj_t* btn2 = lv_btn_create(lv_scr_act());lv_obj_remove_style_all(btn2);  /* Remove the styles coming from the theme */lv_obj_set_size(btn2, 120, 50);lv_obj_set_pos(btn2, 10, 80);lv_obj_add_style(btn2, &style_btn, 0);lv_obj_add_style(btn2, &style_btn_red, 0);lv_obj_add_style(btn2, &style_btn_pressed, LV_STATE_PRESSED);lv_obj_set_style_radius(btn2, LV_RADIUS_CIRCLE, 0);label = lv_label_create(btn2);lv_label_set_text(label, "Button 2");lv_obj_center(label);}

在这里插入图片描述

滑动条值显示


static lv_obj_t* label;
static void slider_event_cb(lv_event_t* e)
{lv_obj_t* slider = lv_event_get_target(e);/* Refresh the text */lv_label_set_text_fmt(label, "%d", lv_slider_get_value(slider));lv_obj_align_to(label, slider, LV_ALIGN_OUT_TOP_MID, 0, -15);
}void lv_demo_get_started3(void)
{/* Create a slider in the center of the display */lv_obj_t* slider = lv_slider_create(lv_scr_act());lv_obj_set_width(slider, 200);  /*  Set the width */lv_obj_center(slider);  /* Align to the center of the parent (screen) */lv_obj_add_event_cb(slider, slider_event_cb, LV_EVENT_VALUE_CHANGED, NULL);label = lv_label_create(lv_scr_act());lv_label_set_text(label, "0");lv_obj_align_to(label, slider, LV_ALIGN_OUT_TOP_MID, 0, -15); /* Align top of the slider */
}

在这里插入图片描述

Styles

Size styles

void lv_demo_style_1(void)
{static lv_style_t style;lv_style_init(&style);lv_style_set_radius(&style, 5);/* Make a gradient */lv_style_set_width(&style, 150);lv_style_set_height(&style, LV_SIZE_CONTENT);lv_style_set_pad_ver(&style, 20);lv_style_set_pad_left(&style, 5);lv_style_set_x(&style, lv_pct(50));lv_style_set_y(&style, 80);lv_obj_t* obj = lv_obj_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_obj_t* label = lv_label_create(obj);lv_label_set_text(label, "Hello");
}

在这里插入图片描述

Background styles

渐变方向:

  • LV_GRAD_DIR_VER:垂直方向
  • LV_GRAD_DIR_HOR:水平方向
void lv_demo_style_2(void)
{static lv_style_t style;lv_style_init(&style);lv_style_set_radius(&style, 5);lv_style_set_bg_opa(&style, LV_OPA_COVER);static lv_grad_dsc_t grad;grad.dir = LV_GRAD_DIR_VER; // 渐变方向grad.stops_count = LV_GRADIENT_MAX_STOPS;grad.stops[0].color = lv_palette_lighten(LV_PALETTE_GREY, 1); // 颜色1grad.stops[1].color = lv_palette_main(LV_PALETTE_BLUE); // 颜色2grad.stops[0].frac = 128; // 1~255 grad.stops[1].frac = 192; // 1~255 lv_style_set_bg_grad(&style, &grad);lv_obj_t* obj = lv_obj_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_obj_center(obj);lv_obj_t* label = lv_label_create(obj);lv_label_set_text(label, "Hello");lv_obj_center(label);
}

在这里插入图片描述

Border styles

void lv_demo_style_3(void) // Border styles
{static lv_style_t style;lv_style_init(&style);/* Set a background color and a radius */lv_style_set_radius(&style, 5);lv_style_set_bg_opa(&style, LV_OPA_COVER);lv_style_set_bg_color(&style, lv_palette_lighten(LV_PALETTE_GREY, 1));/* Add border to the bottom+right */lv_style_set_border_color(&style, lv_palette_main(LV_PALETTE_BLUE));lv_style_set_border_width(&style, 5);lv_style_set_border_opa(&style, LV_OPA_50);lv_style_set_border_side(&style, LV_BORDER_SIDE_BOTTOM | LV_BORDER_SIDE_RIGHT);/* Create an object with the new style */lv_obj_t* obj = lv_obj_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_obj_center(obj);}

在这里插入图片描述

Outline styles

void lv_demo_style_4(void) // Outline styles
{static lv_style_t style;lv_style_init(&style);/* Set a background color and radius */lv_style_set_radius(&style, 5);lv_style_set_bg_opa(&style, LV_OPA_COVER);lv_style_set_bg_color(&style, lv_palette_lighten(LV_PALETTE_GREY, 1));/* Add outline */lv_style_set_outline_width(&style, 2);lv_style_set_outline_color(&style, lv_palette_main(LV_PALETTE_BLUE));lv_style_set_outline_pad(&style, 8);/* Create an object with the new style */lv_obj_t* obj = lv_obj_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_obj_center(obj);
}

在这里插入图片描述

Shadow styles

void lv_demo_style_5(void) // Shadow styles
{static lv_style_t style;lv_style_init(&style);/* Set a background color and a radius */lv_style_set_radius(&style, 5);lv_style_set_bg_opa(&style, LV_OPA_COVER);lv_style_set_bg_color(&style, lv_palette_lighten(LV_PALETTE_GREY, 1));/* Add a shadow */lv_style_set_shadow_width(&style, 55);lv_style_set_shadow_color(&style, lv_palette_main(LV_PALETTE_BLUE));// lv_style_set_shadow_ofs_x(&style, 10);// lv_style_set_shadow_ofs_y(&style, 20);/* Create an object with the new style */lv_obj_t* obj = lv_obj_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_obj_center(obj);
}

在这里插入图片描述
设置shadow offset的效果:
lv_style_set_shadow_ofs_x(&style, 10);
lv_style_set_shadow_ofs_y(&style, 20);
在这里插入图片描述

Image styles

const uint8_t img_cogwheel_argb_map[] = {
/Pixel format: Alpha 8 bit, Red: 3 bit, Green: 3 bit, Blue: 2 bit/
0xff, 0x00, 0xff, 0x00, 0xff, 0x00, 0xff, 0x00, 0xff, 0x00, 0xff, 0x00, 0xff,

}
const lv_img_dsc_t img_cogwheel_argb = {
.header.always_zero = 0,
.header.w = 100,
.header.h = 100,
.data_size = 10000 * LV_IMG_PX_SIZE_ALPHA_BYTE,
.header.cf = LV_IMG_CF_TRUE_COLOR_ALPHA,
.data = img_cogwheel_argb_map,
};

void lv_demo_style_6(void) // Image styles
{lv_style_t style;lv_style_init(&style);/* Set a background color and a radius */lv_style_set_radius(&style, 5);lv_style_set_bg_opa(&style, LV_OPA_COVER);lv_style_set_bg_color(&style, lv_palette_lighten(LV_PALETTE_GREY, 1));lv_style_set_border_width(&style, 2);lv_style_set_border_color(&style, lv_palette_main(LV_PALETTE_BLUE));lv_style_set_img_recolor(&style, lv_palette_main(LV_PALETTE_BLUE));lv_style_set_img_recolor_opa(&style, LV_OPA_50);lv_style_set_transform_angle(&style, 300);/* Create an object with the new style */lv_obj_t* obj = lv_obj_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);LV_IMG_DECLARE(img_cogwheel_argb);lv_img_set_src(obj, &img_cogwheel_argb);lv_obj_center(obj);
}

在这里插入图片描述

Arc styles

void lv_demo_style_7(void) // Arc styles
{static lv_style_t style;lv_style_init(&style);lv_style_set_arc_width(&style, 4);lv_style_set_arc_opa(&style, LV_OPA_COVER);lv_style_set_arc_color(&style, lv_palette_main(LV_PALETTE_RED));/* Create an object with the new style */lv_obj_t* obj = lv_arc_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_obj_center(obj);
}

在这里插入图片描述

Text styles

void lv_demo_style_8(void) // Text styles
{static lv_style_t style;lv_style_init(&style);lv_style_set_radius(&style, 5);lv_style_set_bg_opa(&style, LV_OPA_COVER);lv_style_set_bg_color(&style, lv_palette_lighten(LV_PALETTE_GREY, 2));lv_style_set_border_width(&style, 2);lv_style_set_border_color(&style, lv_palette_main(LV_PALETTE_BLUE));lv_style_set_pad_all(&style, 10);lv_style_set_text_color(&style, lv_palette_main(LV_PALETTE_BLUE));lv_style_set_text_letter_space(&style, 5);lv_style_set_text_line_space(&style, 20);lv_style_set_text_decor(&style, LV_TEXT_DECOR_UNDERLINE);/* Create an object with the new style */lv_obj_t* obj = lv_label_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);lv_label_set_text(obj, "Text of \n""a label");lv_obj_center(obj);}

在这里插入图片描述

Line styles

void lv_demo_style_9(void) // Line styles
{static lv_style_t style;lv_style_init(&style);lv_style_set_line_color(&style, lv_palette_main(LV_PALETTE_GREY));lv_style_set_line_width(&style, 6);lv_style_set_line_rounded(&style, true);/* Create an object with the new style */lv_obj_t* obj = lv_line_create(lv_scr_act());lv_obj_add_style(obj, &style, 0);static lv_point_t p[] = { {10, 30}, {30, 50}, {100, 0} };lv_line_set_points(obj, p, 3);lv_obj_center(obj);}

在这里插入图片描述

相关文章:

LVGL Styles

LVGL StylesGet started按钮添加标签按钮添加风格滑动条值显示StylesSize stylesBackground stylesBorder stylesOutline stylesShadow stylesImage stylesArc stylesText stylesLine stylesGet started 按钮添加标签 /*** brief 按钮事件回调函数* param e */ void btn_eve…...

扬帆优配|联通港股创近两年新高!A股资源类股爆发,食品饮料领跌

今日上午,A股商场和港股商场均现较大起伏震动,临近上午收盘出现一波跳水,不过,到上午收盘,上证指数仍微涨0.10%,煤炭等资源类板块明显上涨。 港股商场上午走弱,科技股领跌。 沪指微涨0.10%资源…...

Win10+VS2019+Qt5.15.2下编译QCAD

一:官方说法:WindowsDownload and install a C compiler, for example:Visual Studio C Express or Visual Studio CommunityDownload and install Qt from qt.io (see supported platforms):Download for example the online installer fileqt-opensour…...

【微信小程序】原生微信小程序ts模板下引入vant weapp

之前一直是在普通项目下使用 vant weapp,这不最近学了ts,使用微信开发工具的tsless初始化项目,再引入 vant 时踩了好久坑,特来记录一下 前言 本文章适合微信开发工具的ts项目,指的是项目目录结构如下图 总结 从上图…...

Puppeteer之Pyppeteer——自动登录Gmail(6)

前言 本文是该专栏的第6篇,结合项目案例让你熟练使用pyppeteer,后面会持续分享Pyppeteer的干货知识,记得关注。 有同学留言,使用selenium自动登录gmail邮箱,被Google识别为机器人怎么办?出现这个问题,主要在于Google可以检测出selenium的控件,无论你怎么加入规避方法,…...

python 绘图 —— 绘制从顶部向底部显示的柱形图[ax.bar()]

python 绘图 —— 绘制从顶部向底部显示的柱形图[ax.bar()] 效果图如下所示: 就是这个样子,一般比较少见将柱形图从上往下绘制的。可能是会为了更好的展示数据对比结果吧。这里绘图的主要思路如下: 利用ax.twinx()这个函数生成一个新的x轴…...

自定义Task工具,调用系统的IdleHandler方法

1、工具类&#xff0c;调用系统的IdleHandler方法package com.abbi.viewdemo;import android.os.Looper;import android.os.MessageQueue;import java.util.LinkedList;import java.util.Queue;public class DelayTaskDispatcher {private Queue<Task> delayTasks new L…...

生态GEP案例分享

浙江省领导参观德清”两山“平台4月30日上午&#xff0c;浙江省政府参事室一行领导&#xff0c;在德清县副县长陪同下考察当地数据智能运营中心&#xff0c;参观了国内首个县域数字“两山”决策支持平台建设成果。国内生产总值(GDP)&#xff0c;是指按国家市场价格计算的一个国…...

企业级信息系统开发学习笔记1.5 初探Spring AOP

文章目录零、本讲学习目标一、Spring AOP&#xff08;一&#xff09;AOP基本含义&#xff08;二&#xff09;AOP基本作用&#xff08;三&#xff09;AOP与OOP对比&#xff08;四&#xff09;AOP使用方式&#xff08;五&#xff09;AOP基本概念二、提出游吟诗人唱赞歌任务&#…...

Mysql数据库主主从设置

注意&#xff1a;在同一台服务器上部署主从或主主之类的时候&#xff0c;数据库data下有一个auto.cnf里的uuid不能重复。 原则&#xff1a;做同步之前要保证两个数据库数据一致. 锁表操作&#xff1a; FLUSH TABLES WITH READ LOCK; 注&#xff1a;没有锁定主服务器&#xf…...

监管持续,医疗卫生机构如何守好“涉疫”数据安全?

肆虐三年的新冠疫情&#xff0c;影响着全球经济发展、社会正常运行&#xff0c;也成为网络攻击、勒索软件攻击快速增长的温床&#xff0c;“滋生”了一系列网络、数据安全问题&#xff0c;受到各界关注。最近&#xff0c;上线运行三年的 “粤康码”发布公告、官宣部分服务下线&…...

STM32开发(13)----获取唯一设备标识符UID

获取唯一设备标识符UID前言一、什么事UID二、实验过程1.CubeMx配置2.代码实现3.实验结果总结前言 这一章节介绍如何获取STM32芯片中的唯一的ID号的两种方法。 一、什么事UID 在许多项目中&#xff0c;识别设备是必要的。从简单的设备描述到更复杂的设备&#xff0c;如 USB 串…...

华为OD机试 - 最优调度策略(Python) | 机试题+算法思路+考点+代码解析 【2023】

最优调度策略 题目 在通信系统中有一个常见的问题是对用户进行不同策略的调度 会得到不同系统消耗的性能 假设由 N 个待串行用户,每个用户可以使用 A/B/C 三种不同的调度策略 不同的策略会消耗不同的系统资源 请你根据如下规则进行用户调度 并返回总的消耗资源数 规则是:相…...

前端零基础入门-002-集成开发环境

本篇目标 了解市面上常用的前端集成开发环境&#xff08;ide&#xff09;掌握 HBuiberX 的使用&#xff1a;下载安装&#xff0c;新建项目、网页、运行网页。 内容摘要 本篇介绍了市面上流行的几款前端集成开发环境&#xff08;ide&#xff09;&#xff0c;并介绍了 Hbuilde…...

su和sudo的区别

linux中 su和sudo的区别 su和sudo是两个常用的切换到root超级用户命令。功能上类似&#xff0c;但使用上还是有不少差异。 su命令 su是切换到root用户的命令&#xff0c;主要用法如下&#xff1a; su&#xff1a;不带参数直接输入su将切换到root用户&#xff0c;需要输入root…...

【ChatGPT】使用ChatGPT进行51单片机程序编程体验

背景 最近ChatGPT大火&#xff0c;笔者尝试使用它进行了51单片机编程尝试。ChatGPT是一种由OpenAI训练的大型语言模型&#xff0c;具有强大的自然语言处理能力和生成代码的能力。 使用ChatGPT进行51单片机编程&#xff0c;笔者发现它可以帮助开发人员快速生成符合要求的代码&a…...

Docker之路(1.Docker概述、组成以及特点)

1.docker为什么会出现&#xff1f; 一款产品或者项目来说&#xff0c;一般有三个环境&#xff0c;日常/测试环境、预发环境、正式/线上环境 这么多环境&#xff0c;对其环境的配置是十分麻烦的&#xff0c;每一个机器都要部署环境&#xff0c;有的会有集群Redis、Hadoop等&…...

非对称加密算法在android的应用

前言android 系统安全内容总结 4、非对称加密算法应用 主要特性包括secure boot、AVB、OTA包签名、apk签名、apex、ko签名; 除此外上层应用keystore服务、涉及TEEOS非对称算法的功能安全会用到。属于功能安全本章节暂不描述。 4.1、secboot+avb secboot+avb属于安全启动参照…...

51单片机——定时器中断实验,小白讲解,相互学习

定时器介绍 1&#xff0c;CPU时序的有关知识 震荡周期&#xff1a;为单片机提供定时信号的震荡源的周期&#xff08;晶振周期或外加震荡周期&#xff09;。状态周期&#xff1a;2个震荡周期为1个状态周期&#xff0c;用S表示。震荡周期又称S周期或时钟周期。机器周期&#xff…...

什么是循环依赖,spring是如何去解决循环依赖问题的?什么是三级缓存?【spring】

文章目录什么是循环依赖&#xff1f;什么是三级缓存&#xff1f;执行流程什么是循环依赖&#xff1f; 在我们的开发中&#xff0c;会不可避免的遇到Bean之间循环依赖的&#xff0c;所谓循环依赖&#xff0c;就是两个或者两个以上的Bean互相持有对方&#xff0c;这样在程序运行…...

Spring Boot DevTools 热部署

在Spring Boot项目中加入 spring-boot-devtools 热部署依赖启动器后&#xff0c;通常不需要手动重启项目即可让更改生效。spring-boot-devtools 的核心特性之一就是自动重启或热加载。 Spring Boot DevTools 热部署关键知识点 &#x1f525; 目的&#xff1a;spring-boot-devt…...

核函数:解锁支持向量机的强大能力

在机器学习的世界中&#xff0c;支持向量机&#xff08;SVM&#xff09;是一种强大的分类算法&#xff0c;而核函数则是其背后的“魔法”&#xff0c;让 SVM 能够处理复杂的非线性问题。今天&#xff0c;我们就来深入探讨核函数的奥秘&#xff0c;看看它们是如何帮助 SVM 在高维…...

ASP.NET MVC添加模型示例

ASP.NET MVC高效构建Web应用ASP.NET MVC 我们总在谈“模型”&#xff0c;那到底什么是模型&#xff1f;简单说来&#xff0c;模型就是当我们使用软件去解决真实世界中各种实际问题的时候&#xff0c;对那些我们关心的实际事物的抽象和简化。比如&#xff0c;我们在软件系统中设…...

网络安全之Web渗透加解密

项目基本使用 准备环境&#xff1a;node.js python chrome npm install chrome-remote-interface pip install playwright playwright install chromium pip install mitmproxy ............... 第一步启动cdp.js。 第二步使用python .\cdp_load.py vue_demo&#xff0c;连…...

【机器学习基础】机器学习入门核心算法:随机森林(Random Forest)

机器学习入门核心算法&#xff1a;随机森林&#xff08;Random Forest&#xff09; 1. 算法逻辑2. 算法原理与数学推导2.1 核心组件2.2 数学推导2.3 OOB&#xff08;Out-of-Bag&#xff09;误差 3. 模型评估评估指标特征重要性可视化 4. 应用案例4.1 医疗诊断4.2 金融风控4.3 遥…...

FastAPI+Pyomo实现线性回归解决饮食问题

之前在 FastAPI介绍-CSDN博客 中介绍过FastAPI&#xff0c;在 Pyomo中线性规划接口的使用-CSDN博客 中使用Pyomo解决饮食问题&#xff0c;这里将两者组合&#xff0c;即FastAPI在服务器端启动&#xff0c;通过Pyomo实现线性回归&#xff1b;客户端通过浏览器获取饮食的最优解。…...

AudioTrack的理解

采样率说的是一秒钟采样多少点 波形频率说的是一个采样周期内有多少个波形 pcm编码说的是 16 还是8 直接决定write的时候使用short还是byte ‌一、初始化配置 ‌参数设定‌ 需定义音频格式、采样率及缓冲区大小&#xff0c;确保符合硬件支持范围 // 音频参数配置 int sample…...

2024 CKA模拟系统制作 | Step-By-Step | 16、题目搭建-sidecar 代理容器日志

目录 免费获取题库配套 CKA_v1.31_模拟系统 一、题目 二、考点分析 1. Sidecar 容器模式 2. 共享卷配置 3. 日志流式处理 4. 容器规范修改 三、考点详细讲解 1. Sidecar 模式架构 2. 关键组件解析 3. 日志流式处理原理 四、实验环境搭建步骤 1.编辑11-factor-app…...

前端面试准备-4

1.React Router的history模式中&#xff0c;push和replace有什么区别 都是用于页面导航&#xff0c;但是他们对浏览器历史记录的处理不一样。 ①&#xff1a;push是在浏览历史栈里加入一条新的浏览历史&#xff0c;点击返回键会返回上一个页面 ②;replace是替换当前历史记录…...

Windows搭建Swift语言编译环境?如何构建ObjC语言编译环境?Swift如何引入ObjC框架?Interface Builder的历史?

目录 Windows搭建Swift语言编译环境 如何构建ObjC语言编译环境? Swift如何引入ObjC框架? Swift和ObjC中IBOutlet和IBAction代表什么? Interface Builder的历史 Xcode的“Use Storyboards"的作用? Xcode的Playground是什么? Windows搭建Swift语言编译环境 Windo…...