systems and methods for communications with wearable devices are provided. Information may be stored in memory regarding user preferences, which may indicate whether vibration notification is allowed at a wearable device and whether vibration notification is allowed at a mobile device. A communication may be received at a mobile device. It may then be determined whether the wearable device and the mobile device are connected. The wearable device may be caused to generate a vibration notification if the wearable device and the mobile device are determined to be connected. The mobile device may be caused to generate a vibration notification if the wearable device and the mobile device are determined not to be connected.
| 
 | 8.  A system for device communications, the system comprising:
 a display that displays a user interface; an output device capable of outputting a notification; an input interface that receives one or more user inputs during display of the user interface, the one or more inputs corresponding to receipt of one or more notification preferences, wherein the one or more notification preferences identify at least that a wearable device is authorized to perform vibration-based communication-receipt notifications; a memory that stores at least the one or more notification preferences; a communication interface, wherein the communication interface:
 receives a viewable communication over a communication network, transmits the viewable communication to the wearable device, and receives a read update from the wearable device, the read update identifying that the viewable communication has been viewed via the wearable device; and a processor that executes instructions stored in the memory, wherein the processor executes the instructions to:
 mark the viewable communication as read, and identify a possible emergency based on the wearable device having been in motion for at least a predetermined duration of time. 15.  A non-transitory computer-readable storage medium, having embodied thereon a program executable by a processor to perform a method for device communications, the method comprising:
 receiving one or more notification preferences via a user interface, wherein the one or more notification preferences identify at least that a wearable device is authorized to perform vibration-based communication-receipt notifications; storing the one or more notification preferences within a memory of the mobile device; receiving a viewable communication at a mobile device communicatively coupled to the wearable device, the viewable communication sent over a communication network; transmitting the viewable communication from the mobile device to the wearable device, thereby triggering a vibration-based communication-receipt notification at the wearable device; receiving a read update from the wearable device at the mobile device, the read update identifying that the viewable communication has been viewed via the wearable device; marking the viewable communication as read at the mobile device; and identifying a possible emergency based on the wearable device having been in motion for at least a predetermined duration of time. 1.  A method for device communications, the method comprising:
 receiving one or more notification preferences via a user interface, wherein the one or more notification preferences identify at least that a wearable device is authorized to perform vibration-based communication-receipt notifications; storing the one or more notification preferences within a memory of the mobile device; receiving a viewable communication at a mobile device communicatively coupled to the wearable device, the viewable communication sent over a communication network; transmitting the viewable communication from the mobile device to the wearable device, thereby triggering a vibration-based communication receipt notification at the wearable device; receiving a read update from the wearable device at the mobile device, the read update identifying that the viewable communication has been viewed via the wearable device; and executing instructions stored in the memory of the mobile device, wherein execution of the instructions by a processor of the mobile device causes the mobile device to: mark the viewable communication as read at the mobile device, and identify a possible emergency based on the wearable device having been in motion for at least a predetermined duration of time. 2.  The method of  3.  The method of  6.  The method of  7.  The method of  storing information in the memory of the mobile device regarding a first command of a plurality of commands, the first command associated with the command input; retrieving the stored information upon receipt of the command input; and executing the identified command upon receipt of the command input. 9.  The system of  10.  The system of  13.  The system of  14.  The system of  16.  The non-transitory computer-readable storage medium of  17.  The non-transitory computer-readable storage medium of  18.  The non-transitory computer-readable storage medium of  19.  The non-transitory computer-readable storage medium of  20.  The non-transitory computer-readable storage medium of  storing information in the memory of the mobile device regarding a first command of a plurality of commands, the first command associated with the command input; retrieving the stored information upon receipt of the command input; and executing the identified command upon receipt of the command input. | |||||||||||||||||||||||||||
The present application claims the priority benefit of U.S. provisional application No. 62/007,897 filed Jun. 4, 2014 and entitled “Communications with Wearable Devices,” the disclosure of which is hereby incorporated by reference.
1. Field of the Invention
An embodiment of the invention relate to providing a sharing and app of a user's first mobile device with a second mobile device. More specifically, the present invention relates to optimizing memory for a wearable device.
2. Description of the Related Art
Mobile device software applications are a significant and growing portion of the smartphone industry. Mobile applications are designed to run on smartphones, tablet computers (including electronic reading devices or e-readers), and other mobile devices. apps may be made available by application developers through application distribution platforms, many of which are typically operated by the owner of the mobile operating system, such as the Apple® App StoresSM, Google Play™, Windows® Store, and BlackBerry® app World™. Some apps are available for free, while others must be bought. Usually, such apps are downloaded from the platform to a target device, such as an iPhone®, BlackBerry®, Android®, or Windows® phone, other mobile device, laptop, or desktop computer.
There are also a variety of different mobile devices with which applications may be shared. One category of such mobile devices may include wearable technology (e.g., smart watches, smart bracelets/cuffs). Such wearable technology may generally incorporate computing device functions into clothing or accessories that can be worn by the user. Some types of accessories may lack the full range of computing components or functions due to limitations relating to the ability to be worn (e.g., size, weight, structure, design). For example, a smart watch needs to be within a certain size and weight limitation to allow for wearing on a wrist of a user without obstructing normal movement. As such, a smart watch may not have the same memory capacity as other computing devices and may not be able to store or run the same types of applications.
As used herein, references to “smart watch” should be understood as being exemplary. The teachings herein may therefore pertain to any wearable device, including devices incorporated into or otherwise corresponding to clothing, jewelry, hatwear, and other items that can be worn by a user. Such wearable smart devices may likely possess buttons or similar means of collecting input from the user.
It is well known that handheld smart devices, such as smart phones, are able to synchronize with laptop and desktop computers, because such devices may be in communication with a common server. For example, if a user deletes an email on an app of their smart phone, the email will similarly appear deleted on their laptop. However, if a user possesses both a handheld smart device (e.g., smart phone) and a wearable smart device (e.g., smart watch), it is likely that these devices are not fully synchronized. For example, both smart devices are likely to receive simultaneous notifications of an incoming text or email.
Because handheld and wearable smart devices do not typically share a common server, full synchronization between the two devices may be difficult to achieve. Communication in general between the devices may also be limited, which may lead to the user experiencing multiple notifications for a single event. For instance, when a text message is received, both the handheld and wearable smart devices may vibrate, which may be a nuisance for the user. If the user attempts to minimize these notifications by directing all notifications to the wearable device, the user may miss the notification if the wearable device is not currently being worn. There is no simple method to consistently direct notifications to the desired device and ensure that the notification is actually received.
There is, therefore, a need in the art for improved systems and methods for communications with wearable devices.
Embodiments of the present invention provide systems and methods for communications with wearable devices. Information may be stored in memory regarding user preferences, which may indicate whether vibration notification is allowed at a wearable device and whether vibration notification is allowed at a mobile device. A communication may be received at a mobile device. It may then be determined whether the wearable device and the mobile device are connected. The wearable device may be caused to generate a vibration notification if the wearable device and the mobile device are determined to be connected. The mobile device may be caused to generate a vibration notification if the wearable device and the mobile device are determined not to be connected.
Various embodiments may include methods for communications with wearable devices. Such methods may include storing information in memory regarding user preferences indicating whether vibration notification is allowed at a wearable device and whether vibration notification is allowed at a mobile device, receiving a communication at a mobile device, the communication sent over a communication network, determining whether the wearable device and the mobile device are connected, causing the wearable device to generate a vibration notification if the wearable device and the mobile device are determined to be connected, and causing the mobile device to generate a vibration notification if the wearable device and the mobile device are determined not to be connected.
Further embodiments may include systems for communications with wearable devices. Such systems may include memory that stores information regarding user preferences, indicating whether vibration notification is allowed at a wearable device and whether vibration notification is allowed at a mobile device, a communication interface that receives a communication at a mobile device, the communication sent over a communication network, and a processor that executes instructions to determine whether the wearable device and the mobile device are connected, to cause the wearable device to generate a vibration notification if the wearable device and the mobile device are determined to be connected, and to cause the mobile device to generate a vibration notification if the wearable device and the mobile device are determined not to be connected.
Still further embodiments of the present invention may further include non-transitory computer-readable storage media, having embodied thereon a program executable by a processor to perform methods for communications with wearable devices as described herein.
Various embodiments of the present invention provide systems and methods for optimizing memory for a wearable device. The operating system of a handheld smart device may enabled to accept information from the user that directs notifications to either a handheld or wearable smart device in a systematic way. Using user-customizable software on the handheld smart device, notifications may be properly directed and delivered. The user-created programs may make use of wearable device's buttons and accelerometer to communicate information back to the handheld device.
Users may use any number of different handheld electronic devices 104, such as mobile phones, smartphones, personal digital assistants (PDAs), portable computing devices (e.g., laptop, netbook, tablets), handheld computing device, or any other type of computing device capable of communicating over communication network 168. User devices 104 may also be configured to access data from other storage media, such as memory cards or disk drives as may be appropriate in the case of downloaded services. User device 104 may include standard hardware computing components such as network and media interfaces, non-transitory computer-readable storage (memory), and processors for executing instructions that may be stored in memory.
Operating system (OS) 108 is a collection of software that manages computer hardware resources and provides common services for computer programs, including applications 124-132. The operating system 108 is an essential component of the system software in a computer system. Applications 124-132 are usually developed for a specific operation system 108 and therefore rely on the associated operating system 108 to perform its functions. For hardware functions such as input and output and memory allocation, the operating system 108 acts as an intermediary between applications 124-132 and the computer hardware. Although application code is usually executed directly by the hardware, applications 124-132 may frequently make a system call to an OS function or be interrupted by it. Operating systems 108 can be found on almost any device with computing or processing ability. Examples of popular modern operating systems include Android, BSD, iOS, Linux, OS X, QNX, Microsoft Windows, Windows Phone, and IBM z/OS. Most of these (except Windows, Windows Phone and z/OS) may share roots in UNIX.
Operating system settings 112 may be a software function that opens a display that lists OS functions that may be generated upon selection of a user interface button. Such a list of OS functions may be associated with various options that allow the user to designate certain preferences or settings with respect to how certain operating system functions are performed (e.g., display preferences, wireless network preferences, information sharing, accessibility of applications to system information, such as GPS/location, notifications). Once these settings 112 are set, the operating system 108 uses the settings 112 to perform various functions, which includes functions related to execution of an application 124-132.
Wearable device execution software 116 may be software designed to run on a smart device with the purpose of communicating with and executing commands on a wearable smart device. Such software may be specific to the wearable device 136 (e.g., Pebble smart watch app or Sony smart watch app).
Wearable device handheld database 120 may be an organized collection of data relevant to communications between a handheld device 104 and wearable smart device, which may include sequences of input signals received by the wearable smart device and correlated commands to be performed by the handheld smart device.
Applications 124-132 may include any number of software applications that may be installed on the user device 104, including native applications (e.g., Notes, Messages, Camera, FaceTime, Weather, etc. on iPhone) and downloaded applications (e.g., Facebook®, Twitter®, Instagram®).
As noted previously, smart watch 136 may include any wearable device. Such a wearable device may correspond to and be worn like a watch. Alternatively, the wearable device may correspond to other types of clothing, jewelry, other decorative accessory, etc. Such smart watch 136 may have some components and functions in common with handheld mobile device 104. In various instances, however, smart watch 136 may lack some components or ability to perform some functions (e.g., due to limitations related to wearability). Specific examples of wearable devices may include Pebble smart watch or Sony smart watch.
Remote communications network 176 and third party database network 184 may be databases associated with various entities other than the user. Remote communications network 176 and third party database network 184 may include or be associated with any type of server or other computing device as is known in the art, including standard hardware computing components such as network and media interfaces, non-transitory computer-readable storage (memory), and processors for executing instructions or accessing information that may be stored in memory. The functionalities of multiple servers may be integrated into a single server. Alternatively, different functionalities may be allocated among multiple servers, which may be located remotely from each other and communicate over the cloud. Any of the aforementioned servers (or an integrated server) may take on certain client-side, cache, or proxy server characteristics. These characteristics may depend on the particular network placement of the server or certain configurations of the server.
The smart watch 136 may communicates with the mobile device 104 wirelessly through a communications channel 164, which may be a Bluetooth channel. Alternatively, the devices in network environment 100 may communicate via any communication network known in the art, which may be an wireless local area network such as Bluetooth, UTMS, or WiFi (e.g., a IEEE 802.11 protocol), or high frequency systems (e.g., 900 MHz, 2.4 GHz, and 5.6 GHz communications systems), or infrared, other relatively localized wireless communication protocol, or any combination thereof. In that regard, communications network 199 may be a local area network (LAN), which may be communicatively coupled to a wide area network (WAN) such as the Internet. The Internet is a broad network of interconnected computers and servers allowing for the transmission and exchange of Internet Protocol (IP) data between users connected through a network service provider. Examples of network service providers are the public switched telephone network, a cable service provider, a provider of digital subscriber line (DSL) services, or a satellite service provider.
Settings 200 may further include, however, wearable communications menu 225, which may include options to enable wearable to update handheld 230, wearable to notify senders 235, receipt message 240, failure message 245, poll wearable 250, programming 260, standard execution 265, third party execution 270, and command sharing 275.
Wearable to update handheld 230 is an option allowing the wearable device to send notification to the handheld device. Wearable to notify senders 235 is an option to notify a sender of a message that it has been routed through to the wearable device. When enabled, wearable to notify senders 235 may cause two different types of message to be sent to a sender: a receipt message 240 indicating successful receipt of the message at the wearable device and a failure message indicating failure to receive the message at the wearable device. The handheld may send the failure message.
Poll wearable 250 is an option that may enable periodic polling of the wearable smart device by the wearable device execution software. Programming 260 is an option that may enable the use of specific programs regarding communications between the wearable and handheld smart devices. Standard execution 265 is an option that may enable the use of standard programs in the wearable device execution software. Third party execution 270 is an option that may enable the use of third-party programs in the wearable device execution software. Command sharing 275 is an option that may enable the communication of program commands to the third-party data network.
From step 312, the method proceeds to step 316 in which it may be determined whether the wearable actually occurred. If not, the method proceeds to step 324 where the handheld is vibrated. If yes, the method may proceed to step 320 where it may be determined whether vibration is authorized for both devices.
From step 320, if the user has authorized vibration of both devices, the method proceeds to step 324 where the handheld is vibrated. If the user has not authorized vibration of both devices, the method ends.
From step 320, the method proceeds to step 328 in which it may be determine whether any wearable command were received by the handheld. If yes, the method proceeds to step 336 where the command is executed. If no, the method proceeds to step 332 where it may be determined whether the user authorized a message display to indicate blocked notification.
If the user has authorized the message display, the method proceeds to step 336 for execution of the command. If the user has not authorized the message display, the method ends.
From step 412, if the wearable device accelerometer has recorded movement, the communication may be sent to the wearable device in step 416. If the wearable device accelerometer has not recorded movement, the method proceeds to step 440.
From step 416, the method proceeds to step 420 in which it may be determined whether the user has authorized use of wearable buttons to view communications. If not, the method proceeds to step 440. If the user has authorized wearable buttons, the method proceeds to step 424 in which it may be determined whether the user has authorized the wearable device to update the handheld. If not, the method proceeds to step 440. If the user has authorized the wearable device to update the handheld, the method may proceed to step 428 in which the communication may be marked as read on the handheld device.
From step 428, the method proceeds to step 432 in which it may be determine whether the wearable device has received information to delete the communication. If no, the method ends. If yes, the method proceeds to step 436 in which the communication is deleted before the method ends.
From step 440, it may be determine whether the user has authorized notifications to the sender. If yes, the method proceeds to step 444 in which the sender notification is sent before the method ends. If no, the method returns to step 404 when a next communication is received.
Under wearable device execution software menu 505, there may be a command list 510 with such commands as emergency mode command list 515, emergency call link 520, and new command link 525.
Wearable device execution software menu 505 may further include a custom programs list 530, which may include such programs as night mode contents list, new program link 540, start button 545, and stop button 550. Learn mode allows for the mobile device to learn which apps or functions are to be associated with a set of gestures or button taps/presses.
Wearable device execution software menu 505 may further include a buttons command list 555, including button commands for tap first button 530, tap second button 565, tap third button 570, depress for more than 4 seconds button 575, and depress more than 8 seconds button 580.
For example, command example 1 630 may be defined as when button one 605, button two 610, and button three 615 are held for 4 seconds. When such a combination of button presses is detected, the associated command is identified as communicating emergency mode to the handheld devices. Other command examples (e.g., command example 6 655) may further incorporate the accelerometer, such that detection of motion for a period of time (e.g., greater than 1 minute) may indicate that the device should be put in exercise mode.
If not, the method proceeds to step 720. If the wearable device has registered either button activation or vibration recorded by the accelerometer, the method may proceed to step 712 where it may be determined whether a match exists between the button sequence and a handheld command listed in the wearable device handheld database.
If a match does exist, the method proceeds to step 716 in which the handheld command is initiated before the method ends. If not the method proceeds to step 724, in which the wearable is reset and notified that the command was not recognized.
From step 724, the method proceeds to step 720 in which the handheld is polled as to its status at a specified time interval before returning back to step 704.
In step 808, information may be received from the user authorizing communication between the wearable and handheld devices. In some embodiments, the received information may further specify operation of the wearable device execution software.
In step 812, information may be received from the user authorizing the sending of notifications to the wearable and/or handheld device. In step 816, information may be received from the user authorizing sending of notifications to other users regarding receipt of messages at the handheld.
In step 820, information may be received from the user that programs the wearable buttons and accelerometer to perform specified functions in the wearable device execution software. In step 824, the information received from the user regarding the specified functions of the buttons and accelerometer in the wearable device handheld database may be stored.
In step 828, polling may occur if authorized by the user. Such polling may pertain to the status of the wearable device using the wearable device execution software. In step 832, information may be shared with the remote communications network and/or third party data network, if authorized by the user. Such sharing may be reciprocal as the user may provide their own information as to how they use their wearable device, as well as receive the information regarding wearable device use by other users.
In step 912, the wearable device and handheld device verify each other's existence, settings, and current relationship to the user. In step 916, notifications may be activated on the user-preferred device for receiving such notifications. The device that is not preferred may not be enabled or activated to receive notifications.
Processors 1004 as illustrated in 
Other sensors could be coupled to peripherals interface 1006, such as a temperature sensor, a biometric sensor, or other sensing device to facilitate corresponding functionalities. Location processor 1015 (e.g., a global positioning transceiver) can be coupled to peripherals interface 1006 to allow for generation of geo-location data thereby facilitating geo-positioning. An electronic magnetometer 1016 such as an integrated circuit chip could in turn be connected to peripherals interface 1006 to provide data related to the direction of true magnetic North whereby the mobile device could enjoy compass or directional functionality. Camera subsystem 1020 and an optical sensor 1022 such as a charged coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) optical sensor can facilitate camera functions such as recording photographs and video clips.
Communication functionality can be facilitated through one or more communication subsystems 1024, which may include one or more wireless communication subsystems. Wireless communication subsystems 1024 can include 802.x or Bluetooth transceivers as well as optical transceivers such as infrared. Wired communication system can include a port device such as a Universal Serial Bus (USB) port or some other wired port connection that can be used to establish a wired coupling to other computing devices such as network access devices, personal computers, printers, displays, or other processing devices capable of receiving or transmitting data. The specific design and implementation of communication subsystem 1024 may depend on the communication network or medium over which the device is intended to operate. For example, a device may include wireless communication subsystem designed to operate over a global system for mobile communications (GSM) network, a GPRS network, an enhanced data GSM environment (EDGE) network, 802.x communication networks, code division multiple access (CDMA) networks, or Bluetooth networks. Communication subsystem 1024 may include hosting protocols such that the device may be configured as a base station for other wireless devices. Communication subsystems can also allow the device to synchronize with a host device using one or more protocols such as TCP/IP, HTTP, or UDP.
Audio subsystem 1026 can be coupled to a speaker 1028 and one or more microphones 1030 to facilitate voice-enabled functions. These functions might include voice recognition, voice replication, or digital recording. Audio subsystem 1026 in conjunction may also encompass traditional telephony functions.
I/O subsystem 1040 may include touch controller 1042 and/or other input controller(s) 1044. Touch controller 1042 can be coupled to a touch surface 1046. Touch surface 1046 and touch controller 1042 may detect contact and movement or break thereof using any of a number of touch sensitivity technologies, including but not limited to capacitive, resistive, infrared, or surface acoustic wave technologies. Other proximity sensor arrays or elements for determining one or more points of contact with touch surface 1046 may likewise be utilized. In one implementation, touch surface 1046 can display virtual or soft buttons and a virtual keyboard, which can be used as an input/output device by the user.
Other input controllers 1044 can be coupled to other input/control devices 1048 such as one or more buttons, rocker switches, thumb-wheels, infrared ports, USB ports, and/or a pointer device such as a stylus. The one or more buttons (not shown) can include an up/down button for volume control of speaker 1028 and/or microphone 1030. In some implementations, device 1000 can include the functionality of an audio and/or video playback or recording device and may include a pin connector for tethering to other devices.
Memory interface 1002 can be coupled to memory 1050. Memory 1050 can include high-speed random access memory or non-volatile memory such as magnetic disk storage devices, optical storage devices, or flash memory. Memory 1050 can store operating system 1052, such as Darwin, RTXC, LINUX, UNIX, OS X, ANDROID, WINDOWS, or an embedded operating system such as VxWorks. Operating system 1052 may include instructions for handling basic system services and for performing hardware dependent tasks. In some implementations, operating system 1052 can include a kernel.
Memory 1050 may also store communication instructions 1054 to facilitate communicating with other mobile computing devices or servers. Communication instructions 1054 can also be used to select an operational mode or communication medium for use by the device based on a geographic location, which could be obtained by the GPS/Navigation instructions 1068. Memory 1050 may include graphical user interface instructions 1056 to facilitate graphic user interface processing such as the generation of an interface; sensor processing instructions 1058 to facilitate sensor-related processing and functions; phone instructions 1060 to facilitate phone-related processes and functions; electronic messaging instructions 1062 to facilitate electronic-messaging related processes and functions; web browsing instructions 1064 to facilitate web browsing-related processes and functions; media processing instructions 1066 to facilitate media processing-related processes and functions; GPS/Navigation instructions 1068 to facilitate GPS and navigation-related processes, camera instructions 1070 to facilitate camera-related processes and functions; and instructions 1072 for any other application that may be operating on or in conjunction with the mobile computing device. Memory 1050 may also store other software instructions for facilitating other processes, features and applications, such as applications related to navigation, social networking, location-based services or map displays.
Each of the above identified instructions and applications can correspond to a set of instructions for performing one or more functions described above. These instructions need not be implemented as separate software programs, procedures, or modules. Memory 1050 can include additional or fewer instructions. Furthermore, various functions of the mobile device may be implemented in hardware and/or in software, including in one or more signal processing and/or application specific integrated circuits.
Certain features may be implemented in a computer system that includes a back-end component, such as a data server, that includes a middleware component, such as an application server or an Internet server, or that includes a front-end component, such as a client computer having a graphical user interface or an Internet browser, or any combination of the foregoing. The components of the system can be connected by any form or medium of digital data communication such as a communication network. Some examples of communication networks include LAN, WAN and the computers and networks forming the Internet. The computer system can include clients and servers. A client and server are generally remote from each other and typically interact through a network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
One or more features or steps of the disclosed embodiments may be implemented using an API that can define on or more parameters that are passed between a calling application and other software code such as an operating system, library routine, function that provides a service, that provides data, or that performs an operation or a computation. The API can be implemented as one or more calls in program code that send or receive one or more parameters through a parameter list or other structure based on a call convention defined in an API specification document. A parameter can be a constant, a key, a data structure, an object, an object class, a variable, a data type, a pointer, an array, a list, or another call. API calls and parameters can be implemented in any programming language. The programming language can define the vocabulary and calling convention that a programmer will employ to access functions supporting the API. In some implementations, an API call can report to an application the capabilities of a device running the application, such as input capability, output capability, processing capability, power capability, and communications capability.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. The descriptions are not intended to limit the scope of the invention to the particular forms set forth herein. Thus, the breadth and scope of a preferred embodiment should not be limited by any of the above-described exemplary embodiments. It should be understood that the above description is illustrative and not restrictive. To the contrary, the present descriptions are intended to cover such alternatives, modifications, and equivalents as may be included within the spirit and scope of the invention as defined by the appended claims and otherwise appreciated by one of ordinary skill in the art. The scope of the invention should, therefore, be determined not with reference to the above description, but instead should be determined with reference to the appended claims along with their full scope of equivalents.
| Patent | Priority | Assignee | Title | 
| 10082876, | Aug 05 2015 | LG Electronics Inc. | Mobile terminal and controlling method thereof | 
| 9930034, | Jul 29 2015 | International Business Machines Corporation | Authenticating applications using a temporary password | 
| Patent | Priority | Assignee | Title | 
| 8249547, | Jun 16 2011 | Emergency alert device with mobile phone | |
| 8519834, | Aug 22 2010 | Wrist wound vibrating device | |
| 8589667, | Apr 19 2010 | Apple Inc. | Booting and configuring a subsystem securely from non-local storage | 
| 8611930, | May 09 2012 | Apple Inc | Selecting informative presentations based on navigation cues and user intent | 
| 8620344, | Apr 07 2010 | Apple Inc. | Location-based application program management | 
| 8626465, | Mar 30 2010 | Apple Inc. | Calibrating sensor measurements on mobile devices | 
| 8630216, | Jun 24 2010 | Apple Inc. | Method and apparatus for selective reading of system information in a mobile wireless device | 
| 8660501, | Dec 11 2006 | Apple Inc. | Wireless communications circuitry with simultaneous receive capabilities for handheld electronic devices | 
| 8706044, | Aug 31 2010 | Apple Inc. | Methods of testing wireless devices in over-the-air radio-frequency test systems without path loss characterization | 
| 8724723, | Nov 13 2008 | Apple Inc | Method and system for reduced complexity channel estimation and interference cancellation for V-MIMO demodulation | 
| 8750207, | Oct 15 2010 | Apple Inc.; Apple Inc | Adapting transmission to improve QoS in a mobile wireless device | 
| 8793094, | Jun 04 2010 | Apple Inc. | Vibrator motor speed determination in a mobile communications device | 
| 8811951, | Jan 07 2014 | GOOGLE LLC | Managing display of private information | 
| 8816868, | Jun 06 2011 | Apple Inc. | Adaptive low-battery warnings for battery-powered electronic devices | 
| 8831529, | Apr 30 2012 | Apple Inc.; Apple Inc | Wireless communications circuitry with temperature compensation | 
| 8831655, | Jun 05 2012 | Apple Inc.; Apple Inc | Methods and apparatus for coexistence of wireless subsystems in a wireless communication device | 
| 8836851, | Jun 01 2011 | Apple Inc. | Automatic exposure control based on multiple regions | 
| 8843158, | Feb 22 2012 | Apple Inc | Delivering content by predicting predetermined routes using wireless networks | 
| 8849308, | Nov 21 2012 | Apple Inc. | Tiling of map data | 
| 8862060, | Feb 15 2012 | Apple Inc. | Methods for mitigating effects of radio-frequency interference | 
| 8873418, | Apr 11 2008 | Apple Inc. | Methods and apparatus for network capacity enhancement for wireless device coexistence | 
| 8874090, | Apr 07 2010 | Apple Inc | Remote control operations in a video conference | 
| 8917632, | Apr 07 2010 | Apple Inc | Different rate controller configurations for different cameras of a mobile device | 
| 8934921, | Dec 14 2012 | Apple Inc. | Location determination using fingerprint data | 
| 9024749, | Dec 20 2011 | Tactile and visual alert device triggered by received wireless signals | |
| 20020115478, | |||
| 20050272408, | |||
| 20070026798, | |||
| 20070037605, | |||
| 20070087790, | |||
| 20070265038, | |||
| 20080040665, | |||
| 20080300024, | |||
| 20090088207, | |||
| 20100227631, | |||
| 20110059769, | |||
| 20120052922, | |||
| 20130040610, | |||
| 20130303192, | |||
| 20130317835, | |||
| 20130328917, | |||
| 20130331087, | |||
| 20130331118, | |||
| 20130331137, | |||
| 20130332108, | |||
| 20130332156, | |||
| 20140045480, | |||
| 20140045547, | |||
| 20140062773, | |||
| 20140065962, | |||
| 20140071221, | |||
| 20140105084, | |||
| 20140106677, | |||
| 20140139380, | |||
| 20140141803, | |||
| 20140162628, | |||
| 20140167794, | |||
| 20140168170, | |||
| 20140171114, | |||
| 20140180820, | |||
| 20140191979, | |||
| 20140200053, | |||
| 20140222335, | |||
| 20140232633, | |||
| 20140232634, | |||
| 20140247279, | |||
| 20140247280, | |||
| 20140269562, | |||
| 20140273849, | |||
| 20140274010, | |||
| 20140274150, | |||
| 20140283135, | |||
| 20140293959, | |||
| 20140344375, | |||
| 20140364089, | |||
| 20140364148, | |||
| 20140365120, | |||
| 20150011242, | |||
| 20150026623, | |||
| 20150031397, | |||
| 20150065055, | |||
| 20150073907, | |||
| 20150296480, | |||
| 20150312392, | |||
| 20160198319, | |||
| WO201533406, | |||
| WO2015187510, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Feb 10 2015 | CRONIN, JOHN | GrandiOs Technologies, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035003/ | 0478 | |
| Feb 20 2015 | GrandiOs Technologies, LLC | (assignment on the face of the patent) | / | 
| Date | Maintenance Fee Events | 
| Jun 03 2020 | M2551: Payment of Maintenance Fee, 4th Yr, Small Entity. | 
| Oct 21 2024 | REM: Maintenance Fee Reminder Mailed. | 
| Apr 07 2025 | EXP: Patent Expired for Failure to Pay Maintenance Fees. | 
| Date | Maintenance Schedule | 
| Feb 28 2020 | 4 years fee payment window open | 
| Aug 28 2020 | 6 months grace period start (w surcharge) | 
| Feb 28 2021 | patent expiry (for year 4) | 
| Feb 28 2023 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Feb 28 2024 | 8 years fee payment window open | 
| Aug 28 2024 | 6 months grace period start (w surcharge) | 
| Feb 28 2025 | patent expiry (for year 8) | 
| Feb 28 2027 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Feb 28 2028 | 12 years fee payment window open | 
| Aug 28 2028 | 6 months grace period start (w surcharge) | 
| Feb 28 2029 | patent expiry (for year 12) | 
| Feb 28 2031 | 2 years to revive unintentionally abandoned end. (for year 12) |