Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pradyuman7/lookatme
VideoView that plays video only when :eyes: are open and :boy: is detected with various other features
https://github.com/pradyuman7/lookatme
android android-application android-development android-library android-studio eye-detection eye-tracker eye-tracking face face-detection face-recognition google-vision java machine-learning machinelearning smile-detection smiling videoview
Last synced: 7 days ago
JSON representation
VideoView that plays video only when :eyes: are open and :boy: is detected with various other features
- Host: GitHub
- URL: https://github.com/pradyuman7/lookatme
- Owner: Pradyuman7
- License: apache-2.0
- Created: 2019-03-04T10:54:52.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-03-28T02:14:58.000Z (almost 2 years ago)
- Last Synced: 2024-12-18T23:09:27.375Z (15 days ago)
- Topics: android, android-application, android-development, android-library, android-studio, eye-detection, eye-tracker, eye-tracking, face, face-detection, face-recognition, google-vision, java, machine-learning, machinelearning, smile-detection, smiling, videoview
- Language: Java
- Homepage:
- Size: 14.1 MB
- Stars: 206
- Watchers: 9
- Forks: 33
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
Awesome Lists containing this project
README
# LookAtMe
[![](https://jitpack.io/v/Pradyuman7/LookAtMe.svg)](https://jitpack.io/#Pradyuman7/LookAtMe)
[![API](https://img.shields.io/badge/API-15%2B-brightgreen.svg?style=flat)](https://android-arsenal.com/api?level=15)
[![Android Arsenal](https://img.shields.io/badge/Android%20Arsenal-LookAtMe-brightgreen.svg?style=flat)](https://android-arsenal.com/details/1/7551)
[![AwesomeAndroid](https://img.shields.io/badge/Awesome_Android-LookAtMe-purple.svg?style=flat)](https://android.libhunt.com/lookatme-alternatives)
[![Android Weekly](https://img.shields.io/badge/Android_Weekly-LookAtMe-lightblue.svg?style=flat)](https://androidweekly.cn/android-dev-weekly-issue-224/#LookAtMe)
[![Android Dev Digest](https://img.shields.io/badge/Android_Dev_Digest_222-LookAtMe-orange.svg?style=flat)](https://www.androiddevdigest.com/digest-222/)
[![Android Sweets](https://img.shields.io/badge/Android_Sweets-LookAtMe-black.svg?style=flat)](https://androidsweets.ongoodbits.com/2019/04/13/read-about-some-good-practices-when-converting-your-code-to-kotlin-and-check-this-weeks-amazing-library-pack)
[![Android-Tutorial-Online](https://img.shields.io/badge/Android_Tutorial_Online-LookAtMe-maroon.svg?style=flat)](https://www.androidtutorialonline.com/android-library-for-a-videoview/)
VideoView that plays video only when :eyes: are open and :boy: is detected with various other features## GIF
## AndroidPub (Medium) Post
[You can read the AndroidPub post about this library, the perks it provides and other details here](https://android.jlelse.eu/a-videoview-that-detects-your-face-and-tracks-your-eyes-afc3a04fd735).
## Screenshots
![screenshot_2019-01-10-07-02-17-959_com pd trackeye](https://user-images.githubusercontent.com/41565823/50949699-8978cc80-14a7-11e9-9899-b99fec80be41.jpg)
![screenshot_2019-01-10-07-02-22-894_com pd trackeye](https://user-images.githubusercontent.com/41565823/50949700-8978cc80-14a7-11e9-96e8-92eb7cfdb78f.jpg)## Prerequisites
Add this in your root `build.gradle` file (**not** your module `build.gradle` file):
```gradle
allprojects {
repositories {
...
maven { url 'https://www.jitpack.io' }
}
}
```## Dependency
Add this to your module's `build.gradle` file (make sure the version matches the JitPack badge above):
```gradle
dependencies {
implementation 'com.github.Pradyuman7:LookAtMe:Version1.0'
}
```For latest release, please check the JitPack version and match it with the dependency.
```gradle
dependencies {
implementation 'com.github.Pradyuman7:LookAtMe:Version2.0'
}
```## Usage
LookAtMe is very easy to use and can be directly used in your application. You just need to first declare the `LookAtMe` variable in your activity, and add the following in layout of your activity (XML file).
```java
private LookAtMe lookAtMe;
lookAtMe = findViewById(R.id.lookme);
``````XML
```After this, just initiallise `LookAtMe` variable with the activity context, add the video URI, start the video and just call `setLookMe()`, the whole code would look something like this:
```java
lookAtMe.init(this);
lookAtMe.setVideoURI(Uri.parse("android.resource://" + getPackageName() + "/" + R.raw.videoplayback));
// lookAtMe.setVideoPath("http://website.com/video/mp4/62000/62792m.mp4"); to use video from a url
lookAtMe.start();
lookAtMe.setLookMe();
```You can also personalise the experience according to your need, using `init()`. In this method you can add if you want the eye-tracking mode to be `FAST` or `ACCURATE`, and also which camera to use, front or back. The method bodies look like this:
```java
public void init(Context activityContext, String mode, String cameraFace){
// add mode to be fast or accurate and cameraFace to be front or back
}
```
```java
public void init(Context activityContext, String mode){
// add mode to be accurate or fast
}
```### Version2.0 additions
Now in Version2.0 the developer can also access that if the user laughed / smiled during the video. For this, just use this `initWithSmilingStatus()` method instead of the normal `init()` like this:
```java
lookAtMe.initWithSmilingStatus(this); // for smiling status of the user
```To access if the user smiled during the video after this, currently you have to acess the log of the app programatically.
Currently, LookAtMe counts when user smiles and for how many frames. If the user smiles for 100 frames in total, LookAtMe logs a line stating that "the user smiled for 100 Frames!". After that count resets to 0.You can access the log of your android app like this:
```java
try {
Process process = Runtime.getRuntime().exec("logcat");
BufferedReader bufferedReader = new BufferedReader(
new InputStreamReader(process.getInputStream()));StringBuilder log = new StringBuilder();
String line = "";
while ((line = bufferedReader.readLine()) != null) {
log.append(line);
}
TextView tv = (TextView)findViewById(R.id.textView1);
tv.setText(log.toString());
}
catch (IOException e) {}
```To know more about this, please refer [this link](https://stackoverflow.com/questions/12692103/read-logcat-programmatically-within-application).
## Pull Request
Have some new ideas or found a bug? Do not hesitate to open an `issue` and make a `pull request`.
## License
**LookAtME** is under [![License: Apache](https://img.shields.io/badge/License-Apache2.0-black.svg)](https://opensource.org/licenses/MIT). See the [LICENSE](.github/LICENSE.md) file for more info.
## Credits
The video being played in the android app is owned solely by Pixar animations and the author lays no claim over the video.