时间:2021-07-01 10:21:17 帮助过:44人阅读
原子镜的学名其实叫做 单向透视玻璃,但是在淘宝上搜 原子镜 这个关键词会好些
单面镜其实是“双面镜”,单面镜前后两面的光学性质根本没有分别,它之所以能产生单面反光的效果,完全是因为镜的两面处于不同光度的环境所造成的。我们先比较普通镜子和单面镜的结构。普通镜子是把银镀在玻璃上制成的。单面镜也一样,可是在镀银时就只会镀“一半”。怎样可以镀“一半”呢?方法倒是有点巧妙:镀上去的银(不是真银,是其他金属)十分薄,使一半的光可以通过,另一半就被反射回去。在实际使用时,犯人会面向镜面,而且身处有强光的房间。因为光线充足,反射的光较多,犯人便会在镜中看见自己的影象。此时证人站在镜的另一边,一个光线很微弱的房间里。虽然证人房间里部分的光线也可以穿过单面反光镜,但由于光度很低,所以犯人便看不到证人,只能看到自己的影像。情形就好像在街灯的强光下,我们不能看见萤火虫一样,因为来自萤火虫的微弱光线被街灯的光所盖过了。因此所谓单面反光的现象,只是视觉上的错觉罢了! (摘自百度百科)
原子镜广泛应用于监狱、公检法机构审讯室、精神病医院、大学科研机构研究室、大型会议室等,可达到里面看不到外面,外面可看到里面的效果。
这种厕所上起来感受应该比较刺激
当然还有应用于酒(tou)店(pai)的,所以在网上也有很多卖小尺寸的原子镜,一般是10x10cm的一块10块钱,我这个是12x14cm的也是10块钱,但是邮费就要20,所以很划不来,据说现在有种单透膜,可以达到同样的效果,没有研究过。
接下来说 LCD屏幕
我使用的是深圳微信公司出的4英寸LCD屏,这个屏幕用起来很方便,直接插起来就可以用
这块屏幕更详尽的介绍
然后树莓派
感觉这货没什么好说的,大家应该都知道,稍微说一下
这是一个迷人有趣的Linux电脑
树莓派(为学生计算机编程教育设计的一种卡片式电脑)编辑 Raspberry Pi(中文名为“树莓派”,简写为RPi,或者RasPi/RPi)是为学生计算机编程教育而设计,只有信用卡大小的卡片式电脑,其系统基于Linux。 随着Windows 10 IoT的发布,我们也将可以用上运行Windows的树莓派。 自问世以来,受众多计算机发烧友和创客的追捧,曾经一“派”难求。别看其外表“娇小”,内“心”却很强大,视频、音频等功能通通皆有,可谓是“麻雀虽小,五脏俱全”。
树莓派由注册于英国的慈善组织“Raspberry Pi 基金会”开发,Eben·Upton/埃·厄普顿为项目带头人。2012年3月,英国剑桥大学埃本·阿普顿(Eben Epton)正式发售世界上最小的台式机,又称卡片式电脑,外形只有信用卡大小,却具有电脑的所有基本功能,这就是Raspberry Pi电脑板,中文译名"树莓派"。这一基金会以提升学校计算机科学及相关学科的教育,让计算机变得有趣为宗旨。基金会期望这 一款电脑无论是在发展中国家还是在发达国家,会有更多的其它应用不断被开发出来,并应用到更多领域。在2006年树莓派早期概念是基于Atmel的 ATmega644单片机,首批上市的10000“台”树莓派的“板子”,由中国台湾和大陆厂家制造。
树莓派名字中的pi其实指的就是 python
所以我选择了 python 作为 镜子的编程语言那么说说我用python在这上面干了些什么
事实上最开始我的策略使用一个全屏的网页浏览器显示一个 黑底白字 的网站
可是坑爹的是 我更不不会web技术
然后我就打算要不试试python吧,本来还觉得不爽又要新学一门语言
但是python给我很大的惊喜
我并没有学习python的语法,而是看了两个例子就直接使用tkinter库开始编程
这就是python的优势: 简单
接触python到用tk写出第一个的界面,只用了1个小时的时间
就是一开始那个环形显示时间那个
对于准大一新生来说,不管是python的语法还是库的使用都很容易,所以python很适合用来入门
我甚至打算教我的女朋友(nue)(gou)
所有的界面都是黑底白字。
所以我开发了一个类,能让这些元素拥有动画效果,并且能让 Pm2.5 天气 时间 我和女朋友在一起了多少秒 等等 这些信息能够随机的在镜子上淡入淡出
我是比较偏向语音这个选择,因为这将会是一种新式的交互体验,就跟童话里的魔镜一样,我对这个镜子的定位是一个外形比较骚的公众信息聚合平台,所以语音相对于手机来说,更方便,而对于这样一个定位来讲,方便很重要,试想你在酒店想要找厕所,然后你问魔镜 ’魔镜魔镜,厕所在哪‘ 是不是比掏出手机链结魔镜,然后再用某种低效的输入进行交互方便的多?
再说百度等都有开放的API可以用何乐而不为?
所以下一步的目标就是把语音的功能开发出来,目前卡在了语音采集这个问题上。
还希望大神多指教
单位提供盒饭,不过需要自己前一天到内网的订餐页面订餐。有一天我忘了订餐,只好自己花钱订外卖了。实现的功能是查看把自己删了的微信好友,原理就是新建群组,用的是微信网页版的接口,如果加不进来就是被删好友了(不要在群组里讲话,别人是看不见的)
对了,这个用的是python2.x开发的,python3.x是运行不了的
这个是应用的Github界面
这个是运行之后的结果,会让你用微信扫一个二维码,然后就可以了
脑洞打开的小工具到没怎么写过,但是写了一个挑逗女神的一个小程序!!!#!/usr/bin/env python2.7
# --*-- encoding: utf-8 --*--
# enable print(,end='')
#from __future__ import print_function
import argparse
import sys
import os
import re
import bs4
import urlparse
import requests
def download(url, out, title):
#out = url.split('/')[-1]
resp = requests.get(url, stream=True)
if resp.status_code != requests.codes.ok:
return False
total = resp.headers.get('content-length')
if total is None:
total = 0
else:
total = int(total)
def show_progress(total, acc):
if total == 0:
sys.stdout.write("{} ?\r".format(out))
else:
#sys.stdout.write("{} [ {:3d}% ]\r".format(100*acc/total, out))
sys.stdout.write("{} \"{}\" {:3d}%\r".format(title, out, 100*acc/total))
sys.stdout.flush()
acc = 0
show_progress(total, acc)
with open(out, 'wb') as f:
for chunk in resp.iter_content(chunk_size=1024):
if chunk: # filter out keep-alive new chunks
f.write(chunk)
f.flush()
acc += len(chunk)
show_progress(total, acc)
sys.stdout.write("\n")
return True
def fetch(from_url, offset, count):
with open(from_url, "r") as f:
html = f.read()
soup = bs4.BeautifulSoup(html)
# get title
content = soup.find_all("h2", class_="first")
if len(content) == 0:
print("title not found!")
return
elif len(content) != 1:
print("title not unique!")
fdir = content[0].contents[0].encode("utf8").strip().replace("–", "-")
if not os.path.exists(fdir):
os.mkdir(fdir)
print("mkdir: \"{}\"".format(fdir))
# get image url
content = soup.find_all("div", id=re.compile("^post-"))
if len(content) == 0:
print("target not found!")
return
elif len(content) != 1:
print("target not unique!")
imgs = content[0].find_all("img")
start = 0 if offset is None else offset
end = len(imgs) if count is None else (start+count)
print("# of image: {}".format(nimg))
for idx in range(start, end):
img = imgs[idx]
url = str(img.attrs["src"])
#url = url.replace("http://t10", "http://i10")
url = url.replace("http://t", "http://i")
ext = url[url.rfind("."):]
out = "{0}/{1}{2}".format(fdir, idx+1, ext)
# get image file
for retry in range(0, 5):
title = ("({{:{}d}}/{{}})".format(len(str(end))).format(idx+1, end))
if download(url, out, title):
break
print("failed, try again ({})".format(retry+1))
def main():
parser = argparse.ArgumentParser(description='nah')
parser.add_argument('urls', type=str, nargs="+", help='Specify URLs')
parser.add_argument('--offset', type=int, nargs="?", help='offset')
parser.add_argument('--count', type=int, nargs="?", help='count')
args = parser.parse_args()
for url in args.urls:
fetch(url, args.offset, args.count)
if __name__ == "__main__":
main()
写过一个把图片转换成字符画的小程序,效果如下import Image
color = 'MNHQ$OC?7>!:-;.' #zifu
def to_html(func):
html_head = '''
body {font-family:Monospace; font-size:5px;}
'''
html_tail = ''
# ding yi HTML
def wrapper(img):
pic_str = func(img)
pic_str = ''.join(l + '
' for l in pic_str.splitlines())
return html_head + pic_str + html_tail
return wrapper
# fan hui zhi
@to_html
def make_char_img(img):
pix = img.load()
pic_str = ''
width, height = img.size
for h in xrange(height):
for w in xrange(width):
pic_str += color[int(pix[w, h]) * 14 / 255]
pic_str += '\n'
return pic_str
def preprocess(img_name):
img = Image.open(img_name)
w, h = img.size
m = max(img.size)
delta = m / 200.0
w, h = int(w / delta), int(h / delta)
img = img.resize((w, h))
img = img.convert('L')
return img
def save_to_file(filename, pic_str):
outfile = open(filename, 'w')
outfile.write(pic_str)
outfile.close()
def main():
img = preprocess(raw_input('input your filename:'))
pic_str = make_char_img(img)
save_to_file('char.html', pic_str)
if __name__ == '__main__':
main()
写过一个终端版的BT链接下载。。也不算脑洞大开。。