树莓派 + Home Assistant + HomeKit 从零开始打造个人智能家居系统 篇五:平面图(Floorplan)

2017-09-09 12:00:00 217点赞 1473收藏 170评论

通过本篇教程,你将获得 Home Assistant 的另一种交互方式:平面图(Floorplan),并跟随示例创建属于你独一无二的个人家庭控制界面。

如果说 Home Assistant 复杂难搞,那么就在于它的配置过程实在没有什么用户体验可言,任何一个细节,从功能到展示、从设备到服务都需要你自己去安排;而如果说 Home Assistant 为何吸引人,那么也在于它的拥有无限的可能,你能够构建出只属于你的 Style。本系列前期的文章,主要为了引领大家入门,对 Home Assistant 的整个配置过程有一个了解,在此基础上,通过官网论坛的补充,慢慢打造你的个人智能家居系统。从本篇开始,我会试着分享一些更个性化的设置,一些额外的实验性的功能。

一、效果展示

Floorplan for Home Assistant 使用系统的前端功能,以一个更直观“家庭平面图”作为交互界面。在 Home Assistant 的 Web 页面控制的所有设备、服务、场景,都可以在平面图中显示并控制。

▲Floorplan for Home Assistant 1▲Floorplan for Home Assistant 1

▲Floorplan for Home Assistant 2▲Floorplan for Home Assistant 2

▲Floorplan for Home Assistant 3▲Floorplan for Home Assistant 3

▲Floorplan for Home Assistant 4▲Floorplan for Home Assistant 4

二、基础准备

实现原理

Home Assistant 提供的前端功能。由于 Home Assistant 本身使用 Web 页面控制,理论上你可以以任意的 Web 图形化形式展示并控制整个系统。而在平面图(Floorplan)中,通过使自定义的 ha-floorplan.html 页面文件配合SVG 格式图片 floorplan.svg,可以将图片中的可视化设备赋予系统设备的实例 ID(Entity ID),达到关联控制的目的。

3D 的显示效果很棒,可是由于下面几个原因我最终仍选择了 2D 视图模式:

- 角度固定导致设备显示问题。

- 灯具的显示控制问题。

- SVG 实现形式的局限(不支持三维物体的描述,如效果展示2,大部分仍采用了菜单的形式来控制设备)。

SVG:可缩放矢量图形(Scalable Vector Graphics)是一种基于可扩展标记语言(XML),用于描述二维矢量图形的图形格式。SVG由W3C制定,是一个开放标准

使用工具

SVG 编辑软件Inkscape,免费、开源的矢量图形编辑器,提供了大量绘图和对象操作工具,不仅能导入导出SVG,还支持AI、EPS、PSD和PNG。

▲Inkscape▲Inkscape

三、安装项目

复制文档

项目文档(或百度网盘 提取密码:rt2n)中下载最新的相关文件,复制到你的 config 目录下,结构如下:

▲目录结构▲目录结构

主要需要修改的文件:

floorplan.yaml:设备配置文件

floorplan.svg:平面图图片文件

floorplan.css:显示效果样式文件

显示方式

平面图(Floorplan)在 Home Assistant 中有两种显示方式:

侧边栏

▲侧边栏▲侧边栏

configuration.yaml 添加如下配置:


panel_custom:
- name: floorplan
sidebar_title: Floorplan
sidebar_icon: mdi:bulletin-board
url_path: floorplan
config: !include floorplan.yaml

状态卡片

▲状态卡片▲状态卡片

configuration.yaml 添加如下配置:


# 虚拟了一个实例来表示平面图,实例类型任意。
homeassistant:
customize:
binary_sensor.floorplan:
custom_ui_state_card: floorplan
config: !include floorplan.yaml
binary_sensor:
- platform: mqtt
state_topic: dummy/floorplan/sensor
name: Floorplan
group:
zones:
name: Zones
entities:
- binary_sensor.floorplan

以任意方式配置之后重启 Home Assistant 服务,在 Floorplan 面板中你应该能看见如下界面:

▲Floorplan 初始界面▲Floorplan 初始界面

官方文档提供了默认的配置文件与 SVG 平面图文件,由于没有跟你的系统关联,无法进行任何操作,下面让我们先将你的设备加入 floorplan.yaml 文件中。

四、添加设备

目前仅支持传感器(Sensor)、开关(Switch)、灯具(Light)、报警面板(Alarm Panel)、二进制传感器(Binary Sensors)、摄像头Camera)、媒体播放器Media Player),将你的设备的实例 ID(Entity ID) 添加到 floorplan.yaml 文件相应位置(仅以部分设备为例,详情参照下载文档):


name: Demo Floorplan
image: /local/custom_ui/floorplan/floorplan.svg
stylesheet: /local/custom_ui/floorplan/floorplan.css

# 可选项
warnings: # 开启错误提示,可以在Web页面查看
# pan_zoom: # 缩放
# hide_app_toolbar: # 隐藏 Toolbar
# date_format: DD-MMM-YYYY # 自定义日期格式

last_motion_entity: sensor.template_last_motion # 最后动作设备
last_motion_class: last-motion

groups:

- name: Sensors #传感器 名称自定 可以有多组
entities:
- sensor.dark_sky_temperature # 温度传感器 在此处添加你的设备 ID
# 文字显示模板,在我的文档中定义了两类,分别带有温湿度单位的,可自行参考
text_template: '${entity.state ? Math.ceil(entity.state) : "undefined"}'
# 显示模板 调用不同的 CSS 信息
class_template: '
var temp = parseFloat(entity.state.replace("°", ""));
if (temp < 10)
return "temp-low"; # 在 CSS 文件中的 .temp-low 类下修改相关显示属性
else if (temp < 30)
return "temp-medium";
else
return "temp-high";
'

- name: Lights
entities:
- light.hallway
- light.living_room
- light.patio
- group.kitchen_lights
- group.living_room_lights
states: # 状态 以及相应调用的 CSS 信息
- state: 'on'
class: 'light-on'
- state: 'off'
class: 'light-off'
action: #执行动作
domain: homeassistant
service: toggle

▲错误提示▲错误提示

配置完成后,需要重启 Home Assistant 服务,如果你开启了配置文件中的“ warnings ”错误提示,刷新浏览器,你将会看到类似上图的信息,提示我们在 SVG 文件中没有找到相应的设备,下面我们将绘制属于你的平面图并将设备与图形关联起来。

五、平面图绘制

平面图一般是在你的户型图基础上进行修改与添加相关设备显示,通过 floorplan.svg 文件展示出来。

获取你的户型图

如果你拥有自己的户型图源文件,你可以直接导入到 Inkscape 中进行修改。如果你没有的话,推荐以下两种方式简单的获取你的户型图:

Inkscape 支持 CAD 文件导入,但是会产生很多杂项,线条也是独立的,不方便后期修改,经过测试仍推荐重绘个人平面图。如果你不需要后期美化,可以在酷家乐下载你的户型图 CAD 文件,并通过在线DXF转SVG直接获得的你的户型图 SVG 文件。

平面图(Floorplan)

酷家乐:在线制作户型图。开始设计后直接搜索你的户型图,找到后直接导出最简户型。

#原创新人#小白装修设计快速入门作为一向爱折腾的人,以前工作上曾经需要做装饰效果图都很抗拒,朋友的房子要装修,想出份设计图,又需要折腾起装修设计软件。可是我压根没有学过设计啊,coredraw、CAD会一点、SKETCHUP会用、3Dmax是真心复杂到不会用。上网找度娘,试用了好几个网站,这里总结一下。给同样准备装修新屋的值得友们lincool| 292 评论166 收藏3k查看详情

▲新建户型▲新建户型

▲导出户型▲导出户型

magicplan:使用拍摄与增强现实功能创建个人户型图。如果线上没有你的户型图,你可以使用 magicplan 自行制作。需要注意的是 magicplan 导出功能需要收费,这里我们仅使用制成后的截图来供我们参考制作所需的平面图。

▲magicplan▲magicplan

户型图 SVG 文件的绘制

为了后期进一步美化与定制,我们没有使用 CAD 源文件,这就需要我们手动修改户型图。将之前得到的户型图文件拖拽进 Inkscape 进行临摹。

▲ 绘制户型图▲ 绘制户型图

美化后的户型图完全符合 SVG 文件的要求,你可以试着再往里面添加你的家具家电。

▲ 绘制户型图▲ 绘制户型图

设备的关联

之所以重绘户型图,一个原因是为了能够使你的平面图看起来更美观,另一个原因就是为了之后的设备关联。所有你想要在平面图中控制的设备,你都需要设置它在 SVG 文件中的属性,赋予相关图形你的实例 ID(Entity ID)。

为了方便触控设备的操作,遵循人机交互的需求(Human Interface),我采用统一大小格式的图标来作为设备的控件。大多数相关图标可以在 FLATICON 网站下载,文末附件中也含有我用到的一些图标供大家参考。

平面图(Floorplan)

以下仅以灯具控制以及温湿度信息显示为例:

关联灯具

在平面图中适合位置添加你选择的图标,调整到适合大小,设置对象属性。

▲添加灯具▲添加灯具

关联温湿度信息

在平面图中适合位置添加任意文字,调整到你希望显示的大小,设置对象属性。

▲添加温湿度信息▲添加温湿度信息

完成后保存 floorplan.svg 文件并替换原文件,刷新浏览器,查看效果,并注意错误提示。

六、个性化设置

经过前面几步,你已经可以在浏览器中使用平面图控制你的设备了,下面主要涉及 floorplan.css 文件的修改,也就是对设备开关状态显示效果、信息显示效果、门窗状态显示效果的自定义,示例如下:

SVG 与 CSS 文件的修改不需要重启 Home Assistant 服务,保存后刷新浏览器即可。

信息文本样式

如我们在 floorplan.yaml 文件中添加的温湿度传感器为例(本例包含多种样式的判断选择):


# 温度 由于温湿度的单位不同,将之分别定义显示模板 text_template
- name: Sensors
entities:
- sensor.temperature_158d0001141e1a
- sensor.temperature_158d0001145a31
text_template: '${entity.state ? Math.ceil(entity.state) : "undefined"}${entity.attributes.unit_of_measurement}'
# 样式模板,温度在低于15、15-30、高于30,分别按照 temp-low、temp-medium、temp-high 的样式显示,在本例中分别显示 蓝色(寒冷)、绿色(舒适)、红色(炎热)
class_template: '
var temp = parseFloat(entity.state);
if (temp < 15)
return "temp-low";
else if (temp < 30)
return "temp-medium";
else
return "temp-high";
'
# 湿度
- name: Sensors
entities:
- sensor.humidity_158d0001141e1a
- sensor.humidity_158d0001145a31
text_template: '${entity.state ? Math.ceil(entity.state) : "undefined"}${entity.attributes.unit_of_measurement}'
# 样式模板,湿度在低于45、45-65、高于65,分别按照 humidity-low、humidity-medium、humidity-high 的样式显示,在本例中分别显示 黄色(干燥)、绿色(舒适)、蓝色(潮湿)
class_template: '
var humidity = parseFloat(entity.state);
if (humidity < 45)
return "humidity-low";
else if (humidity < 65)
return "humidity-medium";
else
return "humidity-high";
'

floorplan.css 文件中对应如下:


/*CSS样式表,修改类似#5bc0de的信息,即改变相应状态显示颜色*/
.temp-low {
fill: #5bc0de !important;
}
.temp-medium {
fill: #5cb85c !important;
}
.temp-high {
fill: #d9534f !important;
}
.humidity-low {
fill: #f0ad4e !important;
}
.humidity-medium {
fill: #5cb85c !important;
}
.humidity-high {
fill: #5bc0de !important;
}

图标控件样式

如我们在 floorplan.yaml 文件中添加的灯具为例。通常会有开和关两个状态,对应两个样式。


states:
- state: 'on'
class: 'light-on'
- state: 'off'
class: 'light-off'

floorplan.css 文件中对应如下:


.light-off {
opacity: 0.75; /*关闭时不透明度为75%*/
}

.light-on { /*开启时正常显示*/
}

效果如下:

▲图标控件样式▲图标控件样式

给一组样式对比, floorplan.css 文件:


.light-off {
stroke: white; !important;
fill: #C3B7F4 !important;
}

.light-on {
stroke: white; !important;
fill: #F8D2B9 !important;
}

效果如下:

▲图标控件样式▲图标控件样式

同理我们可以设置门窗、人体感应器不同状态下的颜色、显示,这里就不一一说明了。

目前大多数浏览器支持的 CSS 效果还有很多,如果你对相关知识有一定了解,你还可以设置动态显示效果,比如风扇开时显示动态图标,关闭时显示静态图标。

Adobe 在线取色器

七、相关文档下载

文中用到的配置文件、图标、SVG、CSS文档在百度网盘(提取密码:rt2n)提供下载,以便大家参考。

感谢大家的热情支持,由于近一周事情比较多,断断续续才完成了这篇文章,有些评论也无法即时回复,十分抱歉。

祝好,再会!

展开 收起

乐天派 人体存在传感器居基础感应控制Matter双生态多平台Mijia IOS Homekit六种数据探测 传感器

乐天派 人体存在传感器居基础感应控制Matter双生态多平台Mijia IOS Homekit六种数据探测 传感器

259元起

MIJIA 米家 MJYDOAYL 自动感应夜灯 白色

MIJIA 米家 MJYDOAYL 自动感应夜灯 白色

19.9元起

京东京造 TH1 时钟温湿度计 白色

京东京造 TH1 时钟温湿度计 白色

29.9元起

Xiaomi 小米 米家智能插座3

Xiaomi 小米 米家智能插座3

49.9元起

MIJIA 米家 1S 增强版 智能台灯 白色

MIJIA 米家 1S 增强版 智能台灯 白色

156元起

Xiaomi 小米 ZSWG01CM 智能中枢网关 黑色

Xiaomi 小米 ZSWG01CM 智能中枢网关 黑色

191.79元起

linptech 领普 居 优惠商品

linptech 领普 居 优惠商品

50.9元起

Xiaomi 小米 DMWG03LM 智能多模网关2 白色

Xiaomi 小米 DMWG03LM 智能多模网关2 白色

181.8元起

玺加 智能窗帘宝X3 光能充电窗帘伴侣

玺加 智能窗帘宝X3 光能充电窗帘伴侣

暂无报价

Xiaomi 小米 无线开关 蓝牙版

Xiaomi 小米 无线开关 蓝牙版

32.9元起

HUAWEI 华为 智能门锁 Plus AI 3D人脸解锁快准稳 高清猫眼远程守护 AI指纹锁

HUAWEI 华为 智能门锁 Plus AI 3D人脸解锁快准稳 高清猫眼远程守护 AI指纹锁

2899元起

Aqara 绿米联创 烟雾报警器

Aqara 绿米联创 烟雾报警器

219元起

Xiaomi 小米 SJWS01LM 水浸卫士 白色

Xiaomi 小米 SJWS01LM 水浸卫士 白色

55元起

京东京造 温湿度计 mini款

京东京造 温湿度计 mini款

17.9元起

Xiaomi 小米 米家夜灯2 红外人体感应夜灯

Xiaomi 小米 米家夜灯2 红外人体感应夜灯

49元起

Xiaomi 小米 米家人体传感器2S 居 智能监测联动

Xiaomi 小米 米家人体传感器2S 居 智能监测联动

61.02元起
170评论

  • 精彩
  • 最新
  • 已经做好,但是ipad上无法显示

    校验提示文案

    提交
    我也发现了,官方升级后前端采用 Polymer 2.0,ha-floorplan 项目没有更新跟进。 [喜极而泣]

    校验提示文案

    提交
    收起所有回复
  • 根据楼主的方式去做了,发现安装hass.io的时候出错了,出现房子之后就黑屏了,我的是树莓派2b+,请问楼主出现过这样的情况吗?

    校验提示文案

    提交
    还没有过,应该是网络原因,除此之外你可以重新安装系统试试。我是的树莓派3。

    校验提示文案

    提交
    收起所有回复
  • 小白请问,京东微联的设备可以接入吗?想入智能窗帘,求推荐

    校验提示文案

    提交
    京东微联没有开放相关协议,无法接入。不过叮咚音箱可以接入。

    校验提示文案

    提交
    据大神了解,有可接入的智能窗帘吗?

    校验提示文案

    提交
    还有1条回复
    收起所有回复
  • 请问作者有没有试过在iphone Home Assistant客户端或者在iphone safari浏览器中打开Floorplan侧边栏,我打开以后无法显示,报错Script error:See browser console for detail.但是在PC上打开就没有这个问题

    校验提示文案

    提交
    最新的Home Assistant 升级了前端显示组件,而 Floorplan 项目没有跟进,所以在 iOS 端显示有错误。只能等等了。

    校验提示文案

    提交
    是的,我昨天在GitHub下看到相同的问题了。
    另外请问作者,刷了Hassio系统的树莓派外接hdmi能不能输出像网页这样的控制界面,现在只能输出一个Hassio的LOGO,如果可以那只要外接一块触摸屏就能挂墙上做家庭控制中心了 [赞]

    校验提示文案

    提交
    收起所有回复
  • 为啥我的floorplan页面只会转圈。。。啥都不显示

    校验提示文案

    提交
    换个浏览器试试?

    校验提示文案

    提交
    谢了 弄好了。。svg文件放错地方了。。

    校验提示文案

    提交
    收起所有回复
  • 海尔热水器阿里智能可以连接HA么?

    校验提示文案

    提交
    阿里智能没有开放相关协议,没有接入HA

    校验提示文案

    提交
    那也就只能用红外开关而已了

    校验提示文案

    提交
    收起所有回复
  • 房间灯光 是用智能灯泡 还是 小米智能插座实现??

    校验提示文案

    提交
    智能墙壁开关、智能插座、智能灯泡都可以,一样的

    校验提示文案

    提交
    收起所有回复
  • ipad做中枢,远程控制时经常显示无设备响应,基本上失去了远程控制的意义,请问楼主有解决办法吗?

    校验提示文案

    提交
    iCloud 的锅,你可以试试保持 iPad 亮屏。

    校验提示文案

    提交
    不可能让ipad常亮,这样ipad发热严重

    校验提示文案

    提交
    收起所有回复
  • @Jun-long 请教一下gif动画中的人体靠近平板自动点亮屏幕是怎么做到的?

    校验提示文案

    提交
    应该是 Android 平板的某个摄像头感应插件,但是我也没找到

    校验提示文案

    提交
    用的是amazon fire?

    校验提示文案

    提交
    还有3条回复
    收起所有回复
  • 看完觉得好累,弄点墙面开关,或者加点遥控器,生活好的那么复杂有嘛必要 [喷水] [苦恼]

    校验提示文案

    提交
  • 我想租个群,以后一起探讨这方面的交流活动,可以加一个联系方式么,楼主

    校验提示文案

    提交
  • 想问下 博联和lifaair出得空气净化器能不能接入 看似还没支持

    校验提示文案

    提交
  • 实在太强了

    校验提示文案

    提交
  • 楼主是否可以告之一下QQ,有问题想私下请教

    校验提示文案

    提交
  • 看了一遍,真的超级牛*,以后有机会搞

    校验提示文案

    提交
  • 你好,我想咨询下,为什么我按前面的教程放好了文件,改了配置文件,重启后 侧面菜单没有floorplan

    校验提示文案

    提交
  • 哎...这样的晦涩半成品 你真的需要么?首先你要有一套别墅,其次你要懂CAD,还得懂点编程语言,还要浪费大量的时间来DIY这个东西...最最重要的是,市场上有很多现成的方案(比如小米智能家居,海尔U-home) 家居系统的最基本要素,可靠、耐用、有售后! 自己搞得DIY系统,除非你长时间玩这个否则半年后你就会忘了怎么进行基本的环境搭建,软件的升级等等。学习成本太高了。强烈建议3闲人员进行diy,有闲钱、有闲时、有闲人。

    校验提示文案

    提交
  • 沙发啦 。。继续学

    校验提示文案

    提交
  • 每一篇都学习了,正在使用一块linux的板子实践中

    校验提示文案

    提交
  • 哈哈 搭建进行中 就差这一篇了 非常感谢

    校验提示文案

    提交
提示信息

取消
确认
评论举报

相关好价推荐
查看更多好价

相关文章推荐

更多精彩文章
更多精彩文章
相关好价
最新文章 热门文章
1.4K
扫一下,分享更方便,购买更轻松