Simplify interface, fix wakelock bug
This commit is contained in:
@@ -1,19 +1,19 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<module external.linked.project.id="SimpleTimer" external.linked.project.path="$MODULE_DIR$" external.root.project.path="$USER_HOME$/Android/SimpleTimer" external.system.id="GRADLE" external.system.module.group="" external.system.module.version="unspecified" type="JAVA_MODULE" version="4">
|
<module external.linked.project.id="SimpleTimer" external.linked.project.path="$USER_HOME$/.shared/workstations/Android/SimpleTimer" external.root.project.path="$MODULE_DIR$" external.system.id="GRADLE" external.system.module.group="" external.system.module.version="unspecified" type="JAVA_MODULE" version="4">
|
||||||
<component name="FacetManager">
|
<component name="FacetManager">
|
||||||
<facet type="java-gradle" name="Java-Gradle">
|
<facet type="java-gradle" name="Java-Gradle">
|
||||||
<configuration>
|
<configuration>
|
||||||
<option name="BUILD_FOLDER_PATH" value="$MODULE_DIR$/build" />
|
<option name="BUILD_FOLDER_PATH" value="$USER_HOME$/.shared/workstations/Android/SimpleTimer/build" />
|
||||||
<option name="BUILDABLE" value="false" />
|
<option name="BUILDABLE" value="false" />
|
||||||
</configuration>
|
</configuration>
|
||||||
</facet>
|
</facet>
|
||||||
</component>
|
</component>
|
||||||
<component name="NewModuleRootManager" inherit-compiler-output="true">
|
<component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_7" inherit-compiler-output="true">
|
||||||
<exclude-output />
|
<exclude-output />
|
||||||
<content url="file://$MODULE_DIR$">
|
<content url="file://$USER_HOME$/.shared/workstations/Android/SimpleTimer">
|
||||||
<excludeFolder url="file://$MODULE_DIR$/.gradle" />
|
<excludeFolder url="file://$USER_HOME$/.shared/workstations/Android/SimpleTimer/.gradle" />
|
||||||
</content>
|
</content>
|
||||||
<orderEntry type="inheritedJdk" />
|
<orderEntry type="jdk" jdkName="1.8" jdkType="JavaSDK" />
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
<orderEntry type="sourceFolder" forTests="false" />
|
||||||
</component>
|
</component>
|
||||||
</module>
|
</module>
|
||||||
4
gradle/wrapper/gradle-wrapper.properties
vendored
4
gradle/wrapper/gradle-wrapper.properties
vendored
@@ -1,6 +1,6 @@
|
|||||||
#Wed Apr 10 15:27:10 PDT 2013
|
#Fri Feb 12 11:34:36 EST 2016
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-2.2-all.zip
|
||||||
|
|||||||
@@ -1,136 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<module external.linked.project.id=":mobile" external.linked.project.path="$MODULE_DIR$" external.root.project.path="$USER_HOME$/Android/SimpleTimer" external.system.id="GRADLE" external.system.module.group="SimpleTimer" external.system.module.version="unspecified" type="JAVA_MODULE" version="4">
|
|
||||||
<component name="FacetManager">
|
|
||||||
<facet type="android-gradle" name="Android-Gradle">
|
|
||||||
<configuration>
|
|
||||||
<option name="GRADLE_PROJECT_PATH" value=":mobile" />
|
|
||||||
</configuration>
|
|
||||||
</facet>
|
|
||||||
<facet type="android" name="Android">
|
|
||||||
<configuration>
|
|
||||||
<option name="SELECTED_BUILD_VARIANT" value="debug" />
|
|
||||||
<option name="SELECTED_TEST_ARTIFACT" value="_android_test_" />
|
|
||||||
<option name="ASSEMBLE_TASK_NAME" value="assembleDebug" />
|
|
||||||
<option name="COMPILE_JAVA_TASK_NAME" value="compileDebugSources" />
|
|
||||||
<option name="SOURCE_GEN_TASK_NAME" value="generateDebugSources" />
|
|
||||||
<option name="ASSEMBLE_TEST_TASK_NAME" value="assembleDebugAndroidTest" />
|
|
||||||
<option name="COMPILE_JAVA_TEST_TASK_NAME" value="compileDebugAndroidTestSources" />
|
|
||||||
<option name="TEST_SOURCE_GEN_TASK_NAME" value="generateDebugAndroidTestSources" />
|
|
||||||
<option name="ALLOW_USER_CONFIGURATION" value="false" />
|
|
||||||
<option name="MANIFEST_FILE_RELATIVE_PATH" value="/src/main/AndroidManifest.xml" />
|
|
||||||
<option name="RES_FOLDER_RELATIVE_PATH" value="/src/main/res" />
|
|
||||||
<option name="RES_FOLDERS_RELATIVE_PATH" value="file://$MODULE_DIR$/src/main/res" />
|
|
||||||
<option name="ASSETS_FOLDER_RELATIVE_PATH" value="/src/main/assets" />
|
|
||||||
</configuration>
|
|
||||||
</facet>
|
|
||||||
</component>
|
|
||||||
<component name="NewModuleRootManager" inherit-compiler-output="false">
|
|
||||||
<output url="file://$MODULE_DIR$/build/intermediates/classes/debug" />
|
|
||||||
<output-test url="file://$MODULE_DIR$/build/intermediates/classes/androidTest/debug" />
|
|
||||||
<exclude-output />
|
|
||||||
<content url="file://$MODULE_DIR$">
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/debug" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/generated/debug" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/androidTest/debug" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/generated/androidTest/debug" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/res" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/resources" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/assets" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/aidl" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/java" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/jni" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/rs" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/res" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/assets" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/aidl" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/jni" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/rs" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/res" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/resources" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/assets" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/aidl" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/java" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/jni" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/rs" isTestSource="true" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/assets" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/bundles" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/classes" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/coverage-instrumented-classes" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dependency-cache" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dex" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dex-cache" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.android.support/appcompat-v7/22.0.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.android.support/mediarouter-v7/22.0.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-ads/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-analytics/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-appindexing/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-appinvite/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-appstate/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-cast/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-drive/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-fitness/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-games/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-gcm/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-identity/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-location/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-maps/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-nearby/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-panorama/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-plus/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-safetynet/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-wallet/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/jacoco" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/javaResources" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/libs" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/lint" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/manifests" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/ndk" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/pre-dexed" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/proguard" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/res" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/rs" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/symbols" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/outputs" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/tmp" />
|
|
||||||
</content>
|
|
||||||
<orderEntry type="jdk" jdkName="Android API 22 Platform" jdkType="Android SDK" />
|
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-plus-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-maps-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-fitness-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="support-v4-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-base-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-analytics-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="mediarouter-v7-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-wallet-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-appinvite-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-panorama-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-identity-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-drive-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="appcompat-v7-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-appstate-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-nearby-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-gcm-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-appindexing-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="support-annotations-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-cast-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-wearable-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-safetynet-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-games-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-ads-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-location-7.5.0" level="project" />
|
|
||||||
</component>
|
|
||||||
</module>
|
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
android:allowBackup="true"
|
android:allowBackup="true"
|
||||||
android:icon="@mipmap/ic_launcher"
|
android:icon="@mipmap/ic_launcher"
|
||||||
android:label="@string/app_name_simple"
|
android:label="@string/app_name_simple"
|
||||||
android:theme="@android:style/Theme.DeviceDefault">
|
android:theme="@style/AppTheme">
|
||||||
<activity
|
<activity
|
||||||
android:name=".MainActivity"
|
android:name=".MainActivity"
|
||||||
android:label="@string/app_name_simple"
|
android:label="@string/app_name_simple"
|
||||||
|
|||||||
25
wear/src/main/java/org/isoron/base/ColorHelper.java
Normal file
25
wear/src/main/java/org/isoron/base/ColorHelper.java
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
package org.isoron.base;
|
||||||
|
|
||||||
|
public class ColorHelper
|
||||||
|
{
|
||||||
|
public static int mixColors(int color1, int color2, float amount)
|
||||||
|
{
|
||||||
|
final byte ALPHA_CHANNEL = 24;
|
||||||
|
final byte RED_CHANNEL = 16;
|
||||||
|
final byte GREEN_CHANNEL = 8;
|
||||||
|
final byte BLUE_CHANNEL = 0;
|
||||||
|
|
||||||
|
final float inverseAmount = 1.0f - amount;
|
||||||
|
|
||||||
|
int a = ((int) (((float) (color1 >> ALPHA_CHANNEL & 0xff) * amount) +
|
||||||
|
((float) (color2 >> ALPHA_CHANNEL & 0xff) * inverseAmount))) & 0xff;
|
||||||
|
int r = ((int) (((float) (color1 >> RED_CHANNEL & 0xff) * amount) +
|
||||||
|
((float) (color2 >> RED_CHANNEL & 0xff) * inverseAmount))) & 0xff;
|
||||||
|
int g = ((int) (((float) (color1 >> GREEN_CHANNEL & 0xff) * amount) +
|
||||||
|
((float) (color2 >> GREEN_CHANNEL & 0xff) * inverseAmount))) & 0xff;
|
||||||
|
int b = ((int) (((float) (color1 & 0xff) * amount) +
|
||||||
|
((float) (color2 & 0xff) * inverseAmount))) & 0xff;
|
||||||
|
|
||||||
|
return a << ALPHA_CHANNEL | r << RED_CHANNEL | g << GREEN_CHANNEL | b << BLUE_CHANNEL;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -4,12 +4,15 @@ import android.app.AlarmManager;
|
|||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.wearable.activity.WearableActivity;
|
import android.support.wearable.activity.WearableActivity;
|
||||||
import android.support.wearable.view.WatchViewStub;
|
import android.support.wearable.view.WatchViewStub;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import org.isoron.base.AmbientModeListener;
|
import org.isoron.base.AmbientModeListener;
|
||||||
|
import org.isoron.simpletimer.model.SimpleTimer;
|
||||||
|
import org.isoron.simpletimer.views.TimerView;
|
||||||
|
|
||||||
import java.util.Timer;
|
import java.util.Timer;
|
||||||
import java.util.TimerTask;
|
import java.util.TimerTask;
|
||||||
@@ -18,13 +21,16 @@ public class MainActivity extends WearableActivity
|
|||||||
{
|
{
|
||||||
|
|
||||||
private static final String TAG = "MainActivity";
|
private static final String TAG = "MainActivity";
|
||||||
|
public static final String PREFS_NAME = "SimpleTimerPrefs";
|
||||||
|
public static final int DEFAULT_INITIAL_TIME = 5 * 60 * 1000;
|
||||||
|
|
||||||
AmbientModeListener ambientModeListener = null;
|
AmbientModeListener ambientModeListener = null;
|
||||||
TimerView timerView;
|
TimerView timerView;
|
||||||
|
|
||||||
private AlarmManager ambientModeAlarmManager;
|
private AlarmManager alarmManager;
|
||||||
private PendingIntent ambientModePendingIntent;
|
private PendingIntent ambientModePendingIntent;
|
||||||
private Timer timer;
|
private Timer fixedRateTimer;
|
||||||
private boolean isActive = false;
|
private SimpleTimer stimer;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState)
|
protected void onCreate(Bundle savedInstanceState)
|
||||||
@@ -34,15 +40,18 @@ public class MainActivity extends WearableActivity
|
|||||||
|
|
||||||
setAmbientEnabled();
|
setAmbientEnabled();
|
||||||
|
|
||||||
ambientModeAlarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
|
stimer = new SimpleTimer();
|
||||||
|
|
||||||
|
alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
|
||||||
Intent ambientModeIntent = new Intent(getApplicationContext(), MainActivity.class);
|
Intent ambientModeIntent = new Intent(getApplicationContext(), MainActivity.class);
|
||||||
ambientModeIntent.setAction("REFRESH");
|
ambientModeIntent.setAction("REFRESH");
|
||||||
|
ambientModePendingIntent = PendingIntent
|
||||||
ambientModePendingIntent =
|
.getActivity(getApplicationContext(), 0, ambientModeIntent,
|
||||||
PendingIntent.getActivity(getApplicationContext(), 0, ambientModeIntent,
|
|
||||||
PendingIntent.FLAG_UPDATE_CURRENT);
|
PendingIntent.FLAG_UPDATE_CURRENT);
|
||||||
|
|
||||||
|
SharedPreferences preferences = getSharedPreferences(PREFS_NAME, 0);
|
||||||
|
final long initialTime = preferences.getLong("initialTime", DEFAULT_INITIAL_TIME);
|
||||||
|
|
||||||
final WatchViewStub stub = (WatchViewStub) findViewById(R.id.watch_view_stub);
|
final WatchViewStub stub = (WatchViewStub) findViewById(R.id.watch_view_stub);
|
||||||
stub.setOnLayoutInflatedListener(new WatchViewStub.OnLayoutInflatedListener()
|
stub.setOnLayoutInflatedListener(new WatchViewStub.OnLayoutInflatedListener()
|
||||||
{
|
{
|
||||||
@@ -50,19 +59,21 @@ public class MainActivity extends WearableActivity
|
|||||||
public void onLayoutInflated(WatchViewStub stub)
|
public void onLayoutInflated(WatchViewStub stub)
|
||||||
{
|
{
|
||||||
timerView = (TimerView) findViewById(R.id.timerview);
|
timerView = (TimerView) findViewById(R.id.timerview);
|
||||||
|
timerView.setTime(initialTime);
|
||||||
|
timerView.setTimer(stimer);
|
||||||
setAmbientModeListener(timerView);
|
setAmbientModeListener(timerView);
|
||||||
|
startFixedRateTimer();
|
||||||
startTimer();
|
refreshViews();
|
||||||
refresh();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startTimer()
|
private void startFixedRateTimer()
|
||||||
{
|
{
|
||||||
if (timer != null) timer.cancel();
|
if (fixedRateTimer != null) fixedRateTimer.cancel();
|
||||||
timer = new Timer();
|
|
||||||
timer.scheduleAtFixedRate(new TimerTask()
|
fixedRateTimer = new Timer();
|
||||||
|
fixedRateTimer.scheduleAtFixedRate(new TimerTask()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
@@ -72,44 +83,38 @@ public class MainActivity extends WearableActivity
|
|||||||
@Override
|
@Override
|
||||||
public void run()
|
public void run()
|
||||||
{
|
{
|
||||||
refresh();
|
refreshViews();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}, 0, 1000);
|
}, 0, 1000);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void stopTimer()
|
private void stopFixedRateTimer()
|
||||||
{
|
{
|
||||||
if (timer != null) timer.cancel();
|
if (fixedRateTimer != null) fixedRateTimer.cancel();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void refresh()
|
private void refreshViews()
|
||||||
{
|
{
|
||||||
Log.d(TAG, "refresh() ambient? " + isAmbient() + " active? " + isActive);
|
|
||||||
|
|
||||||
if (timerView != null)
|
if (timerView != null)
|
||||||
{
|
{
|
||||||
timerView.tick();
|
timerView.tick();
|
||||||
timerView.invalidate();
|
timerView.invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isAmbient() || !isActive)
|
if (isAmbient()) scheduleNextRefresh();
|
||||||
{
|
}
|
||||||
long delay = -1;
|
|
||||||
if (timerView != null)
|
|
||||||
{
|
|
||||||
if (isAmbient()) delay = timerView.getMillisecondsUntilNextMinute();
|
|
||||||
else delay = timerView.getRemainingTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (delay > 0)
|
private void scheduleNextRefresh()
|
||||||
{
|
{
|
||||||
Log.d(TAG, "sleeping for " + delay + " milliseconds (" + delay / 1000 / 60.0 + " minutes)");
|
long delay = timerView.getMillisecondsUntilNextMinute();
|
||||||
ambientModeAlarmManager.setExact(AlarmManager.RTC_WAKEUP,
|
if (delay < 0) return;
|
||||||
System.currentTimeMillis() + delay + 100, ambientModePendingIntent);
|
|
||||||
}
|
Log.d(TAG, "sleeping for " + delay + " milliseconds (" + delay / 1000 / 60.0 +
|
||||||
}
|
" minutes)");
|
||||||
|
alarmManager.setExact(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + delay + 100,
|
||||||
|
ambientModePendingIntent);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -117,8 +122,10 @@ public class MainActivity extends WearableActivity
|
|||||||
{
|
{
|
||||||
super.onEnterAmbient(ambientDetails);
|
super.onEnterAmbient(ambientDetails);
|
||||||
if (ambientModeListener != null) ambientModeListener.onEnterAmbient(ambientDetails);
|
if (ambientModeListener != null) ambientModeListener.onEnterAmbient(ambientDetails);
|
||||||
stopTimer();
|
|
||||||
refresh();
|
stopFixedRateTimer();
|
||||||
|
|
||||||
|
refreshViews();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -126,8 +133,10 @@ public class MainActivity extends WearableActivity
|
|||||||
{
|
{
|
||||||
super.onExitAmbient();
|
super.onExitAmbient();
|
||||||
if (ambientModeListener != null) ambientModeListener.onExitAmbient();
|
if (ambientModeListener != null) ambientModeListener.onExitAmbient();
|
||||||
startTimer();
|
|
||||||
refresh();
|
startFixedRateTimer();
|
||||||
|
|
||||||
|
refreshViews();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -135,6 +144,7 @@ public class MainActivity extends WearableActivity
|
|||||||
{
|
{
|
||||||
Log.d(TAG, "onUpdateAmbient()");
|
Log.d(TAG, "onUpdateAmbient()");
|
||||||
super.onUpdateAmbient();
|
super.onUpdateAmbient();
|
||||||
|
|
||||||
if (ambientModeListener != null) ambientModeListener.onUpdateAmbient();
|
if (ambientModeListener != null) ambientModeListener.onUpdateAmbient();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -151,7 +161,7 @@ public class MainActivity extends WearableActivity
|
|||||||
|
|
||||||
Log.d(TAG, "onNewIntent: " + intent.getAction());
|
Log.d(TAG, "onNewIntent: " + intent.getAction());
|
||||||
|
|
||||||
refresh();
|
refreshViews();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -159,27 +169,40 @@ public class MainActivity extends WearableActivity
|
|||||||
{
|
{
|
||||||
super.onPause();
|
super.onPause();
|
||||||
Log.d(TAG, "onPause()");
|
Log.d(TAG, "onPause()");
|
||||||
isActive = false;
|
|
||||||
stopTimer();
|
stopFixedRateTimer();
|
||||||
refresh();
|
|
||||||
|
refreshViews();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onStop()
|
protected void onStop()
|
||||||
{
|
{
|
||||||
super.onStop();
|
super.onStop();
|
||||||
|
stopFixedRateTimer();
|
||||||
|
|
||||||
|
savePreferences();
|
||||||
|
|
||||||
|
if (!isAmbient()) finishAffinity();
|
||||||
|
|
||||||
Log.d(TAG, "onStop()");
|
Log.d(TAG, "onStop()");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void savePreferences()
|
||||||
|
{
|
||||||
|
long totalTime = timerView.getTime();
|
||||||
|
SharedPreferences settings = getSharedPreferences(PREFS_NAME, 0);
|
||||||
|
SharedPreferences.Editor editor = settings.edit();
|
||||||
|
editor.putLong("initialTime", totalTime);
|
||||||
|
editor.commit();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onResume()
|
protected void onResume()
|
||||||
{
|
{
|
||||||
super.onResume();
|
super.onResume();
|
||||||
Log.d(TAG, "onResume()");
|
Log.d(TAG, "onResume()");
|
||||||
|
if (!isAmbient()) startFixedRateTimer();
|
||||||
isActive = true;
|
|
||||||
if(!isAmbient()) startTimer();
|
|
||||||
refresh();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -0,0 +1,59 @@
|
|||||||
|
package org.isoron.simpletimer.model;
|
||||||
|
|
||||||
|
public class SimpleTimer
|
||||||
|
{
|
||||||
|
private enum TimerState {
|
||||||
|
PAUSED, RUNNING
|
||||||
|
}
|
||||||
|
|
||||||
|
private long startTime;
|
||||||
|
private long totalTime;
|
||||||
|
private long remainingTime;
|
||||||
|
private TimerState state;
|
||||||
|
|
||||||
|
public static final int DEFAULT_INITIAL_TIME = 5 * 60 * 1000;
|
||||||
|
|
||||||
|
public SimpleTimer()
|
||||||
|
{
|
||||||
|
startTime = -1;
|
||||||
|
remainingTime = totalTime = DEFAULT_INITIAL_TIME;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void resume()
|
||||||
|
{
|
||||||
|
if(isRunning()) return;
|
||||||
|
|
||||||
|
startTime = System.currentTimeMillis();
|
||||||
|
state = TimerState.RUNNING;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void pause()
|
||||||
|
{
|
||||||
|
if(isPaused()) return;
|
||||||
|
state = TimerState.PAUSED;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isRunning()
|
||||||
|
{
|
||||||
|
return state == TimerState.RUNNING;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isPaused()
|
||||||
|
{
|
||||||
|
return state == TimerState.PAUSED;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void reset()
|
||||||
|
{
|
||||||
|
state = TimerState.PAUSED;
|
||||||
|
remainingTime = totalTime;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getRemainingTime()
|
||||||
|
{
|
||||||
|
long currentTime = System.currentTimeMillis();
|
||||||
|
long elapsedTime = currentTime - startTime;
|
||||||
|
|
||||||
|
return totalTime - elapsedTime;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
package org.isoron.simpletimer;
|
package org.isoron.simpletimer.views;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -10,25 +10,29 @@ import android.graphics.RectF;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.PowerManager;
|
import android.os.PowerManager;
|
||||||
import android.os.Vibrator;
|
import android.os.Vibrator;
|
||||||
|
import android.support.wearable.activity.WearableActivity;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.MotionEvent;
|
import android.view.MotionEvent;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.WindowManager;
|
|
||||||
|
|
||||||
import org.isoron.base.AmbientModeListener;
|
import org.isoron.base.AmbientModeListener;
|
||||||
|
import org.isoron.base.ColorHelper;
|
||||||
|
import org.isoron.simpletimer.MainActivity;
|
||||||
|
import org.isoron.simpletimer.model.SimpleTimer;
|
||||||
|
|
||||||
|
import java.util.Calendar;
|
||||||
|
|
||||||
import java.util.Timer;
|
|
||||||
|
|
||||||
public class TimerView extends View implements AmbientModeListener
|
public class TimerView extends View implements AmbientModeListener
|
||||||
{
|
{
|
||||||
private static final String TAG = "TimerView";
|
private static final String TAG = "TimerView";
|
||||||
|
|
||||||
private final int primaryColor;
|
private int primaryColor;
|
||||||
private final int secondaryColor;
|
private int secondaryColor;
|
||||||
private final int tertiaryColor;
|
private int tertiaryColor;
|
||||||
|
|
||||||
private final int backgroundColor;
|
private int backgroundColor;
|
||||||
|
|
||||||
private Paint paint;
|
private Paint paint;
|
||||||
private Paint paintInteractive;
|
private Paint paintInteractive;
|
||||||
@@ -39,8 +43,7 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
private int height;
|
private int height;
|
||||||
private int fontHeight;
|
private int fontHeight;
|
||||||
private int size;
|
private int size;
|
||||||
private Timer timer;
|
private final WearableActivity activity;
|
||||||
private final Activity activity;
|
|
||||||
private Vibrator vibrator;
|
private Vibrator vibrator;
|
||||||
|
|
||||||
private int step;
|
private int step;
|
||||||
@@ -49,33 +52,56 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
private long remainingTime;
|
private long remainingTime;
|
||||||
private long lastTick;
|
private long lastTick;
|
||||||
|
|
||||||
private int brightnessCountdown;
|
|
||||||
private boolean isBright = false;
|
|
||||||
|
|
||||||
private boolean hasLongPressed;
|
private boolean hasLongPressed;
|
||||||
private boolean hasMoved = false;
|
private boolean hasMoved = false;
|
||||||
private boolean ambientMode = false;
|
private boolean ambientMode = false;
|
||||||
|
|
||||||
private final int DEFAULT_TIME = 5 * 60 * 1000;
|
|
||||||
private final int GRANULARITY = 60 * 1000;
|
private final int GRANULARITY = 60 * 1000;
|
||||||
private final int BRIGHTNESS_LENGTH = 5;
|
|
||||||
private final long VIBRATION_FINISH[] = {0, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250};
|
private final long VIBRATION_FINISH[] = {0, 250, 250, 250, 250, 250, 250, 250, 250, 250, 250};
|
||||||
|
|
||||||
private RectF screenRect;
|
private RectF screenRect;
|
||||||
|
|
||||||
|
private SimpleTimer stimer;
|
||||||
|
|
||||||
public TimerView(Context ctx, AttributeSet attrs)
|
public TimerView(Context ctx, AttributeSet attrs)
|
||||||
{
|
{
|
||||||
super(ctx, attrs);
|
super(ctx, attrs);
|
||||||
this.activity = (Activity) ctx;
|
this.activity = (WearableActivity) ctx;
|
||||||
|
|
||||||
step = 0;
|
step = 0;
|
||||||
isRunning = false;
|
totalTime = MainActivity.DEFAULT_INITIAL_TIME;
|
||||||
totalTime = DEFAULT_TIME;
|
|
||||||
remainingTime = totalTime;
|
remainingTime = totalTime;
|
||||||
|
|
||||||
|
isRunning = false;
|
||||||
hasMoved = false;
|
hasMoved = false;
|
||||||
hasLongPressed = false;
|
hasLongPressed = false;
|
||||||
|
stimer = null;
|
||||||
|
|
||||||
|
initializePaints();
|
||||||
|
initializeColors();
|
||||||
|
|
||||||
|
vibrator = (Vibrator) activity.getSystemService(Activity.VIBRATOR_SERVICE);
|
||||||
|
|
||||||
|
setLongClickable(true);
|
||||||
|
setOnTouchListener(new TouchListener());
|
||||||
|
setOnLongClickListener(new LongClickListener());
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTimer(SimpleTimer stimer)
|
||||||
|
{
|
||||||
|
this.stimer = stimer;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initializeColors()
|
||||||
|
{
|
||||||
|
primaryColor = Color.parseColor("#0288d1");
|
||||||
|
secondaryColor = Color.WHITE;
|
||||||
|
tertiaryColor = ColorHelper.mixColors(primaryColor, Color.BLACK, 0.37f);
|
||||||
|
backgroundColor = Color.BLACK;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initializePaints()
|
||||||
|
{
|
||||||
paintInteractive = new Paint();
|
paintInteractive = new Paint();
|
||||||
paintInteractive.setColor(Color.parseColor("#B2FF59"));
|
paintInteractive.setColor(Color.parseColor("#B2FF59"));
|
||||||
paintInteractive.setStyle(Paint.Style.FILL);
|
paintInteractive.setStyle(Paint.Style.FILL);
|
||||||
@@ -91,96 +117,16 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
paintAmbient = new Paint();
|
paintAmbient = new Paint();
|
||||||
paintAmbient.setColor(Color.WHITE);
|
paintAmbient.setColor(Color.WHITE);
|
||||||
paintAmbient.setStyle(Paint.Style.FILL_AND_STROKE);
|
paintAmbient.setStyle(Paint.Style.FILL_AND_STROKE);
|
||||||
paintAmbient.setAntiAlias(false);
|
paintAmbient.setAntiAlias(true);
|
||||||
paintAmbient.setTextAlign(Paint.Align.CENTER);
|
paintAmbient.setTextAlign(Paint.Align.CENTER);
|
||||||
|
|
||||||
primaryColor = Color.parseColor("#0288d1");
|
|
||||||
secondaryColor = Color.WHITE;
|
|
||||||
tertiaryColor = mixColors(primaryColor, Color.BLACK, 0.37f);
|
|
||||||
backgroundColor = Color.BLACK;
|
|
||||||
|
|
||||||
vibrator = (Vibrator) activity.getSystemService(Activity.VIBRATOR_SERVICE);
|
|
||||||
|
|
||||||
setLongClickable(true);
|
|
||||||
setOnLongClickListener(new View.OnLongClickListener()
|
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public boolean onLongClick(View v)
|
|
||||||
{
|
|
||||||
if (hasMoved) return false;
|
|
||||||
highBrightness();
|
|
||||||
|
|
||||||
remainingTime = totalTime;
|
|
||||||
vibrator.vibrate(250);
|
|
||||||
hasLongPressed = true;
|
|
||||||
isRunning = false;
|
|
||||||
invalidate();
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
setOnTouchListener(new View.OnTouchListener()
|
|
||||||
{
|
|
||||||
private float prevY;
|
|
||||||
private long prevTime;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onTouch(View v, MotionEvent event)
|
|
||||||
{
|
|
||||||
int box = 20;
|
|
||||||
highBrightness();
|
|
||||||
|
|
||||||
switch (event.getAction() & MotionEvent.ACTION_MASK)
|
|
||||||
{
|
|
||||||
case MotionEvent.ACTION_DOWN:
|
|
||||||
prevY = event.getY();
|
|
||||||
prevTime = remainingTime;
|
|
||||||
hasMoved = false;
|
|
||||||
hasLongPressed = false;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MotionEvent.ACTION_MOVE:
|
|
||||||
float dy = (event.getY() - prevY) / box;
|
|
||||||
if (Math.abs(dy) < 1) break;
|
|
||||||
hasMoved = true;
|
|
||||||
|
|
||||||
if (isRunning) break;
|
|
||||||
totalTime = Math.max(GRANULARITY, prevTime - (long) dy * GRANULARITY);
|
|
||||||
totalTime = (totalTime / GRANULARITY) * GRANULARITY;
|
|
||||||
remainingTime = totalTime;
|
|
||||||
|
|
||||||
step = 1;
|
|
||||||
invalidate();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MotionEvent.ACTION_UP:
|
|
||||||
if (hasMoved) break;
|
|
||||||
if (hasLongPressed) break;
|
|
||||||
|
|
||||||
isRunning = !isRunning;
|
|
||||||
|
|
||||||
vibrator.vibrate(80);
|
|
||||||
invalidate();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
highBrightness();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void tick()
|
public void tick()
|
||||||
{
|
{
|
||||||
Log.d(TAG, "tick()");
|
|
||||||
long currentTime = System.currentTimeMillis();
|
long currentTime = System.currentTimeMillis();
|
||||||
|
|
||||||
step = (step + 1) % 2;
|
step = (step + 1) % 2;
|
||||||
|
|
||||||
if (brightnessCountdown-- == 0) lowBrightness();
|
|
||||||
|
|
||||||
if (remainingTime <= 0)
|
if (remainingTime <= 0)
|
||||||
{
|
{
|
||||||
isRunning = false;
|
isRunning = false;
|
||||||
@@ -199,12 +145,10 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
|
|
||||||
PowerManager powerManager =
|
PowerManager powerManager =
|
||||||
(PowerManager) activity.getSystemService(Activity.POWER_SERVICE);
|
(PowerManager) activity.getSystemService(Activity.POWER_SERVICE);
|
||||||
PowerManager.WakeLock mWakeLock = powerManager.newWakeLock(
|
PowerManager.WakeLock wakeLock = powerManager.newWakeLock(
|
||||||
(PowerManager.SCREEN_BRIGHT_WAKE_LOCK | PowerManager.FULL_WAKE_LOCK |
|
(PowerManager.SCREEN_BRIGHT_WAKE_LOCK | PowerManager.FULL_WAKE_LOCK |
|
||||||
PowerManager.ACQUIRE_CAUSES_WAKEUP), "MyWakelockTag");
|
PowerManager.ACQUIRE_CAUSES_WAKEUP), "MyWakelockTag");
|
||||||
mWakeLock.acquire();
|
wakeLock.acquire(500);
|
||||||
|
|
||||||
highBrightness();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -217,10 +161,15 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
return remainingTime % 60000;
|
return remainingTime % 60000;
|
||||||
}
|
}
|
||||||
|
|
||||||
public long getRemainingTime()
|
public long getTime()
|
||||||
{
|
{
|
||||||
if(!isRunning) return -1;
|
return totalTime;
|
||||||
return remainingTime;
|
}
|
||||||
|
|
||||||
|
public void setTime(long totalTime)
|
||||||
|
{
|
||||||
|
this.totalTime = totalTime;
|
||||||
|
this.remainingTime = totalTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -243,20 +192,32 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
@Override
|
@Override
|
||||||
protected void onDraw(Canvas canvas)
|
protected void onDraw(Canvas canvas)
|
||||||
{
|
{
|
||||||
// Log.d(TAG, "onDraw()");
|
|
||||||
paint = paintInteractive;
|
paint = paintInteractive;
|
||||||
|
|
||||||
if (ambientMode) paint = paintAmbient;
|
if (ambientMode) paint = paintAmbient;
|
||||||
|
|
||||||
clearBackground(canvas);
|
clearBackground(canvas);
|
||||||
drawOuterRing(canvas);
|
|
||||||
drawInnerRing(canvas);
|
|
||||||
drawTimer(canvas);
|
drawTimer(canvas);
|
||||||
drawCurrentTime(canvas);
|
drawCurrentTime(canvas);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void drawCurrentTime(Canvas canvas)
|
private void drawCurrentTime(Canvas canvas)
|
||||||
{
|
{
|
||||||
|
if (ambientMode) paint.setColor(Color.WHITE);
|
||||||
|
else paint.setColor(primaryColor);
|
||||||
|
|
||||||
|
Calendar c = Calendar.getInstance();
|
||||||
|
int hour = c.get(Calendar.HOUR_OF_DAY);
|
||||||
|
int minutes = c.get(Calendar.MINUTE);
|
||||||
|
|
||||||
|
if (ambientMode)
|
||||||
|
{
|
||||||
|
paint.setColor(Color.WHITE);
|
||||||
|
}
|
||||||
|
|
||||||
|
paint.setTextSize(size * 0.08f);
|
||||||
|
canvas.drawText(String.format("%02d:%02d", hour, minutes), screenRect.centerX(),
|
||||||
|
screenRect.centerY() + (int) (fontHeight * 2.0), paint);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void drawTimer(Canvas canvas)
|
private void drawTimer(Canvas canvas)
|
||||||
@@ -270,7 +231,7 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
minutes = (long) (60 * Math.ceil(remainingTime / 1000 / 60.0));
|
minutes = (long) (60 * Math.ceil(remainingTime / 1000 / 60.0));
|
||||||
paint.setTextSize(size * 0.25f);
|
paint.setTextSize(size * 0.25f);
|
||||||
canvas.drawText(String.format("%d", minutes / 60), screenRect.centerX(),
|
canvas.drawText(String.format("%d", minutes / 60), screenRect.centerX(),
|
||||||
screenRect.centerY() + (int) (fontHeight * 0.3), paint);
|
screenRect.centerY() + (int) (fontHeight * 0), paint);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -289,13 +250,13 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
paint.setTextSize(size * 0.25f);
|
paint.setTextSize(size * 0.25f);
|
||||||
canvas.drawText(String.format("%d", minutes / 60),
|
canvas.drawText(String.format("%d", minutes / 60),
|
||||||
screenRect.centerX() + minutesWidth / 2 - totalWidth / 2,
|
screenRect.centerX() + minutesWidth / 2 - totalWidth / 2,
|
||||||
screenRect.centerY() + (int) (fontHeight * 0.3), paint);
|
screenRect.centerY() + (int) (fontHeight * 0), paint);
|
||||||
|
|
||||||
paint.setTextSize(size * 0.15f);
|
paint.setTextSize(size * 0.15f);
|
||||||
paint.setColor(secondaryColor);
|
paint.setColor(secondaryColor);
|
||||||
canvas.drawText(String.format("%02d", seconds),
|
canvas.drawText(String.format("%02d", seconds),
|
||||||
screenRect.centerX() + minutesWidth + secondsWidth / 2 + size * 0.025f -
|
screenRect.centerX() + minutesWidth + secondsWidth / 2 + size * 0.025f -
|
||||||
totalWidth / 2, screenRect.centerY() + (int) (fontHeight * 0.3),
|
totalWidth / 2, screenRect.centerY() + (int) (fontHeight * 0),
|
||||||
paint);
|
paint);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -306,59 +267,10 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
String text = "minutes";
|
String text = "minutes";
|
||||||
if (minutes / 60 == 1) text = "minute";
|
if (minutes / 60 == 1) text = "minute";
|
||||||
|
|
||||||
canvas.drawText(text, screenRect.centerX(), screenRect.centerY() + (int) (fontHeight * 1.0),
|
canvas.drawText(text, screenRect.centerX(), screenRect.centerY() + (int) (fontHeight * 0.7),
|
||||||
paint);
|
paint);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void drawInnerRing(Canvas canvas)
|
|
||||||
{
|
|
||||||
int totalPieces = (int) Math.min(16, totalTime / 60000);
|
|
||||||
int remainingPieces = (int) Math.ceil(remainingTime / 60000.0);
|
|
||||||
|
|
||||||
float pieceAngle = 360.0f / totalPieces;
|
|
||||||
float gap = 1.0f;
|
|
||||||
|
|
||||||
RectF r = new RectF(screenRect);
|
|
||||||
r.inset(size * 0.1f, size * 0.1f);
|
|
||||||
|
|
||||||
if (ambientMode) paint.setColor(Color.WHITE);
|
|
||||||
else paint.setColor(primaryColor);
|
|
||||||
|
|
||||||
for (int i = 0; i < remainingPieces; i++)
|
|
||||||
canvas.drawArc(r, -90 - (i + 1) * pieceAngle, pieceAngle - gap, true, paint);
|
|
||||||
|
|
||||||
// canvas.drawArc(r, -90.0f, -360.0f * (remainingTime / 1000) / (totalTime / 1000), true, paint);
|
|
||||||
|
|
||||||
r.inset(size * 0.015f, size * 0.015f);
|
|
||||||
paint.setColor(backgroundColor);
|
|
||||||
canvas.drawArc(r, 0, 360, true, paint);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void drawOuterRing(Canvas canvas)
|
|
||||||
{
|
|
||||||
if (ambientMode) return;
|
|
||||||
|
|
||||||
int totalPieces = 60 / 5;
|
|
||||||
float remainingPercentage = (remainingTime / 1000 % 60) / 60.0f;
|
|
||||||
int remainingPieces = (int) Math.ceil(remainingPercentage * totalPieces);
|
|
||||||
|
|
||||||
if (remainingPieces == 0) remainingPieces = totalPieces;
|
|
||||||
|
|
||||||
float pieceAngle = 360.0f / totalPieces;
|
|
||||||
float gap = 0.5f;
|
|
||||||
|
|
||||||
RectF r = new RectF(screenRect);
|
|
||||||
r.inset(size * 0.075f, size * 0.075f);
|
|
||||||
|
|
||||||
paint.setColor(tertiaryColor);
|
|
||||||
for (int i = 0; i < remainingPieces; i++)
|
|
||||||
canvas.drawArc(r, -90 - (i + 1) * pieceAngle, pieceAngle - gap, true, paint);
|
|
||||||
|
|
||||||
r.inset(size * 0.015f, size * 0.015f);
|
|
||||||
paint.setColor(backgroundColor);
|
|
||||||
canvas.drawArc(r, 0, 360, true, paint);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void clearBackground(Canvas canvas)
|
private void clearBackground(Canvas canvas)
|
||||||
{
|
{
|
||||||
paint.setColor(backgroundColor);
|
paint.setColor(backgroundColor);
|
||||||
@@ -368,6 +280,8 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
@Override
|
@Override
|
||||||
public void onEnterAmbient(Bundle ambientDetails)
|
public void onEnterAmbient(Bundle ambientDetails)
|
||||||
{
|
{
|
||||||
|
if (!isRunning) activity.finishAffinity();
|
||||||
|
|
||||||
ambientMode = true;
|
ambientMode = true;
|
||||||
Log.d(TAG, "onEnterAmbient()");
|
Log.d(TAG, "onEnterAmbient()");
|
||||||
}
|
}
|
||||||
@@ -376,7 +290,6 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
public void onExitAmbient()
|
public void onExitAmbient()
|
||||||
{
|
{
|
||||||
ambientMode = false;
|
ambientMode = false;
|
||||||
highBrightness();
|
|
||||||
Log.d(TAG, "onExitAmbient()");
|
Log.d(TAG, "onExitAmbient()");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -386,50 +299,72 @@ public class TimerView extends View implements AmbientModeListener
|
|||||||
Log.d(TAG, "onUpdateAmbient()");
|
Log.d(TAG, "onUpdateAmbient()");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static int mixColors(int color1, int color2, float amount)
|
class TouchListener implements View.OnTouchListener
|
||||||
{
|
{
|
||||||
final byte ALPHA_CHANNEL = 24;
|
private float prevY;
|
||||||
final byte RED_CHANNEL = 16;
|
private long prevTime;
|
||||||
final byte GREEN_CHANNEL = 8;
|
|
||||||
final byte BLUE_CHANNEL = 0;
|
|
||||||
|
|
||||||
final float inverseAmount = 1.0f - amount;
|
@Override
|
||||||
|
public boolean onTouch(View v, MotionEvent event)
|
||||||
|
{
|
||||||
|
int box = 20;
|
||||||
|
|
||||||
int a = ((int) (((float) (color1 >> ALPHA_CHANNEL & 0xff) * amount) +
|
switch (event.getAction() & MotionEvent.ACTION_MASK)
|
||||||
((float) (color2 >> ALPHA_CHANNEL & 0xff) * inverseAmount))) & 0xff;
|
{
|
||||||
int r = ((int) (((float) (color1 >> RED_CHANNEL & 0xff) * amount) +
|
case MotionEvent.ACTION_DOWN:
|
||||||
((float) (color2 >> RED_CHANNEL & 0xff) * inverseAmount))) & 0xff;
|
prevY = event.getY();
|
||||||
int g = ((int) (((float) (color1 >> GREEN_CHANNEL & 0xff) * amount) +
|
prevTime = remainingTime;
|
||||||
((float) (color2 >> GREEN_CHANNEL & 0xff) * inverseAmount))) & 0xff;
|
hasMoved = false;
|
||||||
int b = ((int) (((float) (color1 & 0xff) * amount) +
|
hasLongPressed = false;
|
||||||
((float) (color2 & 0xff) * inverseAmount))) & 0xff;
|
break;
|
||||||
|
|
||||||
return a << ALPHA_CHANNEL | r << RED_CHANNEL | g << GREEN_CHANNEL | b << BLUE_CHANNEL;
|
case MotionEvent.ACTION_MOVE:
|
||||||
|
float dy = (event.getY() - prevY) / box;
|
||||||
|
if (Math.abs(dy) < 1) break;
|
||||||
|
hasMoved = true;
|
||||||
|
|
||||||
|
if (isRunning) break;
|
||||||
|
|
||||||
|
totalTime = Math.max(GRANULARITY, prevTime - (long) dy * GRANULARITY);
|
||||||
|
totalTime = (totalTime / GRANULARITY) * GRANULARITY;
|
||||||
|
remainingTime = totalTime;
|
||||||
|
|
||||||
|
step = 1;
|
||||||
|
invalidate();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MotionEvent.ACTION_UP:
|
||||||
|
if (hasMoved) break;
|
||||||
|
if (hasLongPressed) break;
|
||||||
|
|
||||||
|
isRunning = !isRunning;
|
||||||
|
|
||||||
|
vibrator.vibrate(80);
|
||||||
|
invalidate();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void changeBrightness(float brightness)
|
class LongClickListener implements View.OnLongClickListener
|
||||||
{
|
{
|
||||||
WindowManager.LayoutParams layout = activity.getWindow().getAttributes();
|
@Override
|
||||||
layout.screenBrightness = brightness;
|
public boolean onLongClick(View v)
|
||||||
activity.getWindow().setAttributes(layout);
|
{
|
||||||
|
if (hasMoved) return false;
|
||||||
|
|
||||||
|
remainingTime = totalTime;
|
||||||
|
isRunning = false;
|
||||||
|
|
||||||
|
vibrator.vibrate(250);
|
||||||
|
hasLongPressed = true;
|
||||||
|
|
||||||
|
invalidate();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void lowBrightness()
|
|
||||||
{
|
|
||||||
if (!isBright) return;
|
|
||||||
|
|
||||||
Log.d(TAG, "lowBrightness()");
|
|
||||||
changeBrightness(0F);
|
|
||||||
isBright = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void highBrightness()
|
|
||||||
{
|
|
||||||
brightnessCountdown = BRIGHTNESS_LENGTH;
|
|
||||||
if (isBright) return;
|
|
||||||
|
|
||||||
Log.d(TAG, "highBrightness()");
|
|
||||||
changeBrightness(0.8F);
|
|
||||||
isBright = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
@@ -6,7 +6,7 @@
|
|||||||
tools:context=".MainActivity"
|
tools:context=".MainActivity"
|
||||||
tools:deviceIds="wear_round">
|
tools:deviceIds="wear_round">
|
||||||
|
|
||||||
<org.isoron.simpletimer.TimerView
|
<org.isoron.simpletimer.views.TimerView
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:id="@+id/timerview"
|
android:id="@+id/timerview"
|
||||||
|
|||||||
6
wear/src/main/res/values/styles.xml
Normal file
6
wear/src/main/res/values/styles.xml
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<resources>
|
||||||
|
<style name="AppTheme" parent="android:Theme.DeviceDefault">
|
||||||
|
<item name="android:windowSwipeToDismiss">false</item>
|
||||||
|
</style>
|
||||||
|
</resources>
|
||||||
102
wear/wear.iml
102
wear/wear.iml
@@ -1,102 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<module external.linked.project.id=":wear" external.linked.project.path="$MODULE_DIR$" external.root.project.path="$USER_HOME$/Android/SimpleTimer" external.system.id="GRADLE" external.system.module.group="SimpleTimer" external.system.module.version="unspecified" type="JAVA_MODULE" version="4">
|
|
||||||
<component name="FacetManager">
|
|
||||||
<facet type="android-gradle" name="Android-Gradle">
|
|
||||||
<configuration>
|
|
||||||
<option name="GRADLE_PROJECT_PATH" value=":wear" />
|
|
||||||
</configuration>
|
|
||||||
</facet>
|
|
||||||
<facet type="android" name="Android">
|
|
||||||
<configuration>
|
|
||||||
<option name="SELECTED_BUILD_VARIANT" value="debug" />
|
|
||||||
<option name="SELECTED_TEST_ARTIFACT" value="_android_test_" />
|
|
||||||
<option name="ASSEMBLE_TASK_NAME" value="assembleDebug" />
|
|
||||||
<option name="COMPILE_JAVA_TASK_NAME" value="compileDebugSources" />
|
|
||||||
<option name="SOURCE_GEN_TASK_NAME" value="generateDebugSources" />
|
|
||||||
<option name="ASSEMBLE_TEST_TASK_NAME" value="assembleDebugAndroidTest" />
|
|
||||||
<option name="COMPILE_JAVA_TEST_TASK_NAME" value="compileDebugAndroidTestSources" />
|
|
||||||
<option name="TEST_SOURCE_GEN_TASK_NAME" value="generateDebugAndroidTestSources" />
|
|
||||||
<option name="ALLOW_USER_CONFIGURATION" value="false" />
|
|
||||||
<option name="MANIFEST_FILE_RELATIVE_PATH" value="/src/main/AndroidManifest.xml" />
|
|
||||||
<option name="RES_FOLDER_RELATIVE_PATH" value="/src/main/res" />
|
|
||||||
<option name="RES_FOLDERS_RELATIVE_PATH" value="file://$MODULE_DIR$/src/main/res" />
|
|
||||||
<option name="ASSETS_FOLDER_RELATIVE_PATH" value="/src/main/assets" />
|
|
||||||
</configuration>
|
|
||||||
</facet>
|
|
||||||
</component>
|
|
||||||
<component name="NewModuleRootManager" inherit-compiler-output="false">
|
|
||||||
<output url="file://$MODULE_DIR$/build/intermediates/classes/debug" />
|
|
||||||
<output-test url="file://$MODULE_DIR$/build/intermediates/classes/androidTest/debug" />
|
|
||||||
<exclude-output />
|
|
||||||
<content url="file://$MODULE_DIR$">
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/debug" isTestSource="false" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/debug" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/generated/debug" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/r/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/aidl/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/buildConfig/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/source/rs/androidTest/debug" isTestSource="true" generated="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/rs/androidTest/debug" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/build/generated/res/generated/androidTest/debug" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/res" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/resources" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/assets" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/aidl" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/java" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/jni" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/debug/rs" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/res" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/resources" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/assets" type="java-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/aidl" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/java" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/jni" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/main/rs" isTestSource="false" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/res" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/resources" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/assets" type="java-test-resource" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/aidl" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/java" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/jni" isTestSource="true" />
|
|
||||||
<sourceFolder url="file://$MODULE_DIR$/src/androidTest/rs" isTestSource="true" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/assets" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/bundles" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/classes" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/coverage-instrumented-classes" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dependency-cache" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dex" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/dex-cache" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.android.support/recyclerview-v7/22.0.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.android.support/support-v4/22.0.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-base/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.gms/play-services-wearable/7.5.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/exploded-aar/com.google.android.support/wearable/1.2.0/jars" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/incremental" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/jacoco" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/javaResources" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/libs" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/lint" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/manifests" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/ndk" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/pre-dexed" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/proguard" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/res" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/rs" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/intermediates/symbols" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/outputs" />
|
|
||||||
<excludeFolder url="file://$MODULE_DIR$/build/tmp" />
|
|
||||||
</content>
|
|
||||||
<orderEntry type="jdk" jdkName="Android API 22 Platform" jdkType="Android SDK" />
|
|
||||||
<orderEntry type="sourceFolder" forTests="false" />
|
|
||||||
<orderEntry type="library" exported="" name="support-v4-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-base-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="wearable-1.2.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="support-annotations-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="play-services-wearable-7.5.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="recyclerview-v7-22.0.0" level="project" />
|
|
||||||
<orderEntry type="library" exported="" name="wearable-1.0.0" level="project" />
|
|
||||||
</component>
|
|
||||||
</module>
|
|
||||||
Reference in New Issue
Block a user