/SmartHomeSampleriOS

Sample Smart home application using Connect SDK

Primary LanguageObjective-CApache License 2.0Apache-2.0

SmartHomeSampleriOS app

About

This demo app demonstrates a scenario of using various Smart Home devices in two home scenes. They represent a living room and a family room, each containing a media device, light bulbs, and possibly other devices. The supported devices come from different categories (media players, light bulbs, switches, and iBeacons) and multiple manufacturers.

We believe the Smart Homes of the future, are not going to be driven by devices from a single manufacturer, instead a network of devices from various manufacturers.

The scenario of the app is:

  1. You enter the living room, which is detected by an iBeacon.
  2. A playlist starts to play on a TV or speaker, and the light bulbs change color to match one of the colors of the album art during playback.
  3. Then the user moves from the living room scene to the family room scene.
  4. Where the session information is transfered from the living room to the family room.
  5. The devices in the living switch off and the session is picked up in the family room.
  6. The user puts the scene to sleep using voice command (to replicate control using Siri or Google Now or other voice engine/assistants).
  7. The speaker fades out the music, while the LED bulbs fade out and switch off.
  8. The Scene wakes up after a defined time – to mimic waking up from an alarm.
  9. The LED Bulbs switch on along with speaker.

For additional information on Connect SDK, visit http://connectsdk.com/discover/.

Prerequisites

Required devices:

  • LG WebOS TV or DLNA-compatible media device for each scene, such as Sonos speakers.

The app has been tested and works with these devices:

Important: Make sure all the WiFi-supported devices (WebOS TV, Sonos speaker, Philips Hue hub, WeMo switch, and Wink hub) and your iOS device with the app are connected to the same WiFi network. To configure the devices, you need to use their respective apps.

Limitations

The app must be in the foreground with the screen unlocked to work properly with the devices.

Setup

Dependencies

  • Add ConnectSDK for iOS to the project. See link for setup instructions.
  • Belkin WeMo SDK: Get it from http://developers.belkin.com/wemo/sdk, unzip the file you'll receive, and copy the contents of the -iphoneos/ directory into SmartHomeSampleriOS/WeMoSDK/ directory. To fix the duplicate symbols errors during linking, patch one of the libraries by running the SmartHomeSampleriOS/WeMoSDK/wemo_duplicate_symbols_fix.sh script.
  • Philips Hue SDK: Place the HueSDK_iOS.framework into SmartHomeSampleriOS/PhilipsHue/ directory. Add Cocoa Lumberjack, which is required by Philips Hue, into SmartHomeSampleriOS/PhilipsHue/.
  • Nuance Dragon mobile SpeechKit framework: Place the SpeechKit.framework into SmartHomeSampleriOS/Nuance/ directory. Update the variables kNuanceAppId, kNuanceAppHost, kNuanceAppHost and SpeechKitApplicationKey in SmartHomeSampleriOS/Secret.m with the values provided. For instructions for SpeechKit setup, see this document.
  • Wink API: Update the following access parameters: kWinkUsername, kWinkPassword, kWinkClientId, and kWinkClientSecret in SmartHomeSampleriOS/Secret.m.

Scenes Configuration

At first launch, you are able to pick devices for your scenes. You can use the "Configure" button later to change the config.

Important: Make sure to select different devices for the scenes.

See also

For more information on using Connect SDK, we recommend you review the following material:

License

Copyright 2015 LG Electronics

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.