Introduction: My Smart Mirror

About: Student NMCT at Howest Kortrijk (Belgium)

Time in the morning can be limited. You have to get ready for work, school,... Looking up the weather takes some of that limited time away. The Smart Mirror eliminates the time you need to open your phone or computer and lookup the weather. In this project we will make such a mirror. It will be able to tell you the time, the local weather, temperature and humidity of the location where your mirror is hanging. This data will also be shown on a home made website.

Step 1: The Components You Need

The list of components can be found in a pdf below

  • Computer screen with HDMI input (or DVI input with convertor like in my case)
  • DHT11 temperature and humidity sensor
  • Raspberry pi 3 model B
  • Wood
  • Hardware to fix the wood in place (screws, glue, brackets)
  • Confrontation mirror, try to order the dimensions as close to the dimensions of the screen. I ordered a custom size and measured the outside of the screen, fully assembled, with border. The screen will be able to rest on the access mirror.
  • Cables to connect the sensor to your raspberry pi (female-female 2.54 to 2.0mm jumper wires reccomended)
  • HDMI cable

Step 2: Raspberry Pi Setup

Now it's time to install some software to control the Raspberry Pi:

  • Raspbian OS image
  • Win32 disc manager

1) Install the Raspbian OS software from the Raspberry pi website.

Download the ZIP file and extract it to a desired location.

2) Download the Win32 disc manager.

  • Click on the folder icon to select the image
  • Then select at "Device" your microSD
  • Then click on "Write"

When the image is written on your MicroSD card, you can open it in Windows Explorer.

  • Open the file "cmdline.txt"
  • Add the following line before the word "rootwait": 169.254.10.0
  • Then save the file.

Now insert the MicroSD into your Raspberry pi

Apply power to your Pi with a 5,2V power adapter.

Connect a network cable to your Pi and your computer.

Step 3: Connecting to Your Raspberry Pi

Now we have installed everything you need to use your RPi

1) Install Putty and open it.

2) Create a connection (as shown in the picture)

3) Login to your pi:

  • username: pi
  • Password: raspberry

4) WIFI setup

sudo nano /etc/wpa_supplicant/wpa_supplicant.conf<br>

At the bottom of the file, you add these lines:

<p>network={<br>	ssid="name of the wireless network"<br>	psk="password of the wireless network"
</p><p>}</p>

5) To connect wireless to your RPi you first need to find your ip adress via this code:

ifconfig wlan0

You can now use this ip adress in putty to login wireless.

Step 4: Measuring the Dimensions for the Wooden Construction

You will need to measure 2 elements:

  • The dimensions of your screen (! only screen, no edge !)
  • Dimensions of the plexi mirror you bought

Do remember that these measurements will be the inside of the rectangle. When buying the wood, you will have to add 8 times the value of the width of the wood to have a correct length because it's nice if you saw the wood in miter.

For the front of the mirror, I used a wooden plank of 18 by 69mm and a length of 210cm

Write the dimensions down, we will use them later.

Step 5: Taking the Screen Apart

Now we will take the screen apart. Every screen is different, for my screen I had to loosen 4 screws and unfasten clips around the monitor. I my case, the screen was connected to the power supply by only a couple of wires. So I taped the back to the screen itself, so it wouldn't move around.

Step 6: Making the Front Section of the Mirror

  1. To make the front section, we need the measurements of the screen without border. You can choose how wide the wood had to be, but I recommend a height of +/- 20mm. The border doesn't have to be that tall.
  2. It helps if you first make a sketch like in the second picture with your measurements. It helps when cutting the planks.
  3. Measure the dimensions of your screen on the wood. Draw a corner of 45° outwards at each side. Repeat this for the 4 dimensions of your screen.
  4. You can cut the planks yourself using a circular saw, or ask the store where you bought the planks to do it for you.
  5. I drilled 2 small holes per plank per side in the height of the wood, so I could fit wooden taps inside the holes to connect the planks together.
  6. To permanently fix them together I used wood glue.
  7. Let the glue harden overnight.

Step 7: Making the Back Side of the Mirror

  1. Now we will need the measurements of the plexi-mirror.
  2. We aren't going to cut the planks at a 45° angle.
  3. Your drawing should look like the third photo.
  4. For the length, we are going to add 2 times the width of the plank.
  5. For the height, we are going to cut the planks to the measurements of the plexi-mirror. The result is, when placing the planks like in the photo, the inside measurements are identical to the ones of the plexi-mirror.
  6. To fasten the wooden planks together, I drilled holes and fastened it with screws. Because this will be the back side, the refinement isn't a priority.

Step 8: Finishing the Wooden Construction

Now, we are going to fasten the 2 constructions together.

I used metal 90° bends and screws to fasten the 2 as shown in the picture.

You can also use these small triangles with screws, but it is not necessary.

Step 9: Placing the Plexi-mirror and Screen in the Construction

  1. If everything is correct, your mirror fits nicely in from the back and rests on an edge from the front part.
  2. I put some glue on the edge and placed the mirror in its final position.
  3. Place some weight on the mirror, so it dries nicely.
  4. Let it sit overnight.

Step 10: Placing It All Together

Now our construction is complete, we are going to place our screen in the housing, with the DHT11 temp sensor.

How you fix it, is up to you, just make sure the screen and pi aren't going anywhere.

I mounted the DHT11 temp sensor on the outside of the mirror, so the readings would be the most accurate.

Step 11: SQL- Database

  1. In this step we will be installing some items that will make it possible to run the database.
  2. sudo apt update

  3. sudo apt install -y python3-venv python3-pip python3-mysqldb mariadb-server uwsgi nginx uwsgi-plugin-python3

We currently have no user. We use this code to create user, you just need to fill in the user and the password:

CREATE USER 'FILL_USER_IN'@'localhost' IDENTIFIED BY 'FILL_PASSWORD_IN';
CREATE DATABASE smart-mirror;
GRANT ALL PRIVILEGES ON smart-mirror.* to 'FILL_USER_IN'@'localhost' WITH GRANT OPTION;
<p>sudo mariadb < sql/db_init.sql</p>

Step 12: SQL Connection to Pycharm

We will connect our database to pycharm

  1. Go to View > Tool Windows > Database and click on the green plus to add connection
  2. Choose Data Source > MySQL and Download driver, if it comes up

General

  • Host = localhost
  • Port = 3306
  • User = *name you chose in last step*
  • Password = * password you chose in last step *

SSH/SSL

  • Proxy host = * your ip adress *
  • Port = 22
  • Proxy user = pi
  • Proxy password = raspberry

To insert tables

  1. you right click on smart-mirror > open console
  2. Execute sql in the zip file in the console
  3. Database is made

Step 13: Getting Code for the Project

In pycharm go to:

  1. File > settings > Build, Execution, Deployment > Deployment

Fill the screen in like in the photo

Do the same in

  1. File > Default settings > Build, Execution, Deployment > Deployment

Now you just download the code from my github and open it in pycharm

Step 14: Auto Running the Project

To load the screen page on startup, in your Pi, you type this:

<p>cd /home/pi/.config/lxsession/LXDE-pi/</p>

and open the autostart file with nano

nano autostart

You make sure this is what is in the file:

<p>@lxpanel --profile LXDE-pi<br>@pcmanfm --desktop --profile LXDE-pi
@xscreensaver -no-splash
@point-rpi
@chromium-browser --incognito --kiosk 127.0.0.1/monitor
@xset s noblank
@xset s off
@xset -dpms</p>

Now the monitor page will load on startup and the screensaver is disabled.

Step 15: Enjoy Your Smart Mirror

Now you just power on the screen and pi, and let the mirror do its magic.

It takes some time for the Mirror to boot up, but let it do it's work.

The location on the screen is set to Kortrijk, Belgium, the location where the mirror is made, but if you want to change it, go into web > static > JavaScript folder in the code and search for the line where City = Kortrijk; (it is in the first lines of the code). You can change it to the location where you live. You should change it in the 2 javascript files for the location to change on the site and on the mirror.

Enjoy your Smart Mirror!