Permalink
Browse files

new app widget samples

  • Loading branch information...
1 parent 892b790 commit c37171fb294ec59c3927756d5acaa304aecb73d1 @commonsguy committed Dec 28, 2012
Showing with 3,002 additions and 0 deletions.
  1. +8 −0 AppWidget/Resize/.classpath
  2. +33 −0 AppWidget/Resize/.project
  3. +45 −0 AppWidget/Resize/AndroidManifest.xml
  4. +17 −0 AppWidget/Resize/ant.properties
  5. +85 −0 AppWidget/Resize/build.xml
  6. +40 −0 AppWidget/Resize/proguard.cfg
  7. +11 −0 AppWidget/Resize/project.properties
  8. BIN AppWidget/Resize/res/drawable-hdpi/ic_launcher.png
  9. BIN AppWidget/Resize/res/drawable-ldpi/ic_launcher.png
  10. BIN AppWidget/Resize/res/drawable-mdpi/ic_launcher.png
  11. BIN AppWidget/Resize/res/drawable-nodpi/widget_frame.9.png
  12. BIN AppWidget/Resize/res/drawable-xhdpi/ic_launcher.png
  13. +18 −0 AppWidget/Resize/res/layout/widget.xml
  14. +4 −0 AppWidget/Resize/res/values/strings.xml
  15. +8 −0 AppWidget/Resize/res/xml/widget_provider.xml
  16. +17 −0 AppWidget/Resize/src/com/commonsware/android/appwidget/resize/ActivationActivity.java
  17. +44 −0 AppWidget/Resize/src/com/commonsware/android/appwidget/resize/AppWidget.java
  18. +8 −0 AppWidget/TwoOrThreeDice/.classpath
  19. +33 −0 AppWidget/TwoOrThreeDice/.project
  20. +43 −0 AppWidget/TwoOrThreeDice/AndroidManifest.xml
  21. +17 −0 AppWidget/TwoOrThreeDice/ant.properties
  22. +85 −0 AppWidget/TwoOrThreeDice/build.xml
  23. +255 −0 AppWidget/TwoOrThreeDice/dado_1.svg
  24. +494 −0 AppWidget/TwoOrThreeDice/dado_2.svg
  25. +298 −0 AppWidget/TwoOrThreeDice/dado_3.svg
  26. +321 −0 AppWidget/TwoOrThreeDice/dado_4.svg
  27. +507 −0 AppWidget/TwoOrThreeDice/dado_5.svg
  28. +370 −0 AppWidget/TwoOrThreeDice/dado_6.svg
  29. +40 −0 AppWidget/TwoOrThreeDice/proguard.cfg
  30. +11 −0 AppWidget/TwoOrThreeDice/project.properties
  31. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/die_1.png
  32. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/die_2.png
  33. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/die_3.png
  34. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/die_4.png
  35. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/die_5.png
  36. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/die_6.png
  37. BIN AppWidget/TwoOrThreeDice/res/drawable-hdpi/ic_launcher.png
  38. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/die_1.png
  39. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/die_2.png
  40. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/die_3.png
  41. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/die_4.png
  42. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/die_5.png
  43. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/die_6.png
  44. BIN AppWidget/TwoOrThreeDice/res/drawable-ldpi/ic_launcher.png
  45. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/cw.png
  46. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/die_1.png
  47. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/die_2.png
  48. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/die_3.png
  49. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/die_4.png
  50. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/die_5.png
  51. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/die_6.png
  52. BIN AppWidget/TwoOrThreeDice/res/drawable-mdpi/ic_launcher.png
  53. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/die_1.png
  54. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/die_2.png
  55. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/die_3.png
  56. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/die_4.png
  57. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/die_5.png
  58. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/die_6.png
  59. BIN AppWidget/TwoOrThreeDice/res/drawable-xhdpi/ic_launcher.png
  60. BIN AppWidget/TwoOrThreeDice/res/drawable/widget_frame.9.png
  61. +8 −0 AppWidget/TwoOrThreeDice/res/layout/invisible.xml
  62. +33 −0 AppWidget/TwoOrThreeDice/res/layout/lockscreen.xml
  63. +25 −0 AppWidget/TwoOrThreeDice/res/layout/widget.xml
  64. +4 −0 AppWidget/TwoOrThreeDice/res/values/strings.xml
  65. +8 −0 AppWidget/TwoOrThreeDice/res/xml/widget_provider.xml
  66. +95 −0 AppWidget/TwoOrThreeDice/src/com/commonsware/android/appwidget/dice/AppWidget.java
  67. +17 −0 AppWidget/TwoOrThreeDice/src/com/commonsware/android/appwidget/dice/PairOfDiceActivity.java
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<classpath>
+ <classpathentry kind="src" path="src"/>
+ <classpathentry kind="src" path="gen"/>
+ <classpathentry kind="con" path="com.android.ide.eclipse.adt.ANDROID_FRAMEWORK"/>
+ <classpathentry exported="true" kind="con" path="com.android.ide.eclipse.adt.LIBRARIES"/>
+ <classpathentry kind="output" path="bin/classes"/>
+</classpath>
@@ -0,0 +1,33 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+ <name>ResizeAppWidget</name>
+ <comment></comment>
+ <projects>
+ </projects>
+ <buildSpec>
+ <buildCommand>
+ <name>com.android.ide.eclipse.adt.ResourceManagerBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ <buildCommand>
+ <name>com.android.ide.eclipse.adt.PreCompilerBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ <buildCommand>
+ <name>org.eclipse.jdt.core.javabuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ <buildCommand>
+ <name>com.android.ide.eclipse.adt.ApkBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ </buildSpec>
+ <natures>
+ <nature>com.android.ide.eclipse.adt.AndroidNature</nature>
+ <nature>org.eclipse.jdt.core.javanature</nature>
+ </natures>
+</projectDescription>
@@ -0,0 +1,45 @@
+<?xml version="1.0" encoding="utf-8"?>
+<manifest xmlns:android="http://schemas.android.com/apk/res/android"
+ package="com.commonsware.android.appwidget.resize"
+ android:versionCode="1"
+ android:versionName="1.0">
+
+ <uses-sdk
+ android:minSdkVersion="16"
+ android:targetSdkVersion="16"/>
+
+ <supports-screens
+ android:largeScreens="true"
+ android:normalScreens="true"
+ android:smallScreens="false"/>
+
+ <application
+ android:allowBackup="false"
+ android:icon="@drawable/ic_launcher"
+ android:label="@string/app_name">
+ <receiver
+ android:name="AppWidget"
+ android:icon="@drawable/ic_launcher"
+ android:label="@string/app_name">
+ <intent-filter>
+ <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/>
+ <action android:name="android.appwidget.action.APPWIDGET_OPTIONS_CHANGED"/>
+ </intent-filter>
+
+ <meta-data
+ android:name="android.appwidget.provider"
+ android:resource="@xml/widget_provider"/>
+ </receiver>
+
+ <activity
+ android:name="ActivationActivity"
+ android:theme="@android:style/Theme.NoDisplay">
+ <intent-filter>
+ <action android:name="android.intent.action.MAIN"/>
+
+ <category android:name="android.intent.category.LAUNCHER"/>
+ </intent-filter>
+ </activity>
+ </application>
+
+</manifest>
@@ -0,0 +1,17 @@
+# This file is used to override default values used by the Ant build system.
+#
+# This file must be checked in Version Control Systems, as it is
+# integral to the build system of your project.
+
+# This file is only used by the Ant script.
+
+# You can use this to override default values such as
+# 'source.dir' for the location of your java source folder and
+# 'out.dir' for the location of your output folder.
+
+# You can also use it define how the release builds are signed by declaring
+# the following properties:
+# 'key.store' for the location of your keystore and
+# 'key.alias' for the name of the key to use.
+# The password will be asked during the build when you use the 'release' target.
+
@@ -0,0 +1,85 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project name="PairOfDiceActivity" default="help">
+
+ <!-- The local.properties file is created and updated by the 'android' tool.
+ It contains the path to the SDK. It should *NOT* be checked into
+ Version Control Systems. -->
+ <loadproperties srcFile="local.properties" />
+
+ <!-- The ant.properties file can be created by you. It is only edited by the
+ 'android' tool to add properties to it.
+ This is the place to change some Ant specific build properties.
+ Here are some properties you may want to change/update:
+
+ source.dir
+ The name of the source directory. Default is 'src'.
+ out.dir
+ The name of the output directory. Default is 'bin'.
+
+ For other overridable properties, look at the beginning of the rules
+ files in the SDK, at tools/ant/build.xml
+
+ Properties related to the SDK location or the project target should
+ be updated using the 'android' tool with the 'update' action.
+
+ This file is an integral part of the build system for your
+ application and should be checked into Version Control Systems.
+
+ -->
+ <property file="ant.properties" />
+
+ <!-- The project.properties file is created and updated by the 'android'
+ tool, as well as ADT.
+
+ This contains project specific properties such as project target, and library
+ dependencies. Lower level build properties are stored in ant.properties
+ (or in .classpath for Eclipse projects).
+
+ This file is an integral part of the build system for your
+ application and should be checked into Version Control Systems. -->
+ <loadproperties srcFile="project.properties" />
+
+ <!-- quick check on sdk.dir -->
+ <fail
+ message="sdk.dir is missing. Make sure to generate local.properties using 'android update project'"
+ unless="sdk.dir"
+ />
+
+
+<!-- extension targets. Uncomment the ones where you want to do custom work
+ in between standard targets -->
+<!--
+ <target name="-pre-build">
+ </target>
+ <target name="-pre-compile">
+ </target>
+
+ /* This is typically used for code obfuscation.
+ Compiled code location: ${out.classes.absolute.dir}
+ If this is not done in place, override ${out.dex.input.absolute.dir} */
+ <target name="-post-compile">
+ </target>
+-->
+
+ <!-- Import the actual build file.
+
+ To customize existing targets, there are two options:
+ - Customize only one target:
+ - copy/paste the target into this file, *before* the
+ <import> task.
+ - customize it to your needs.
+ - Customize the whole content of build.xml
+ - copy/paste the content of the rules files (minus the top node)
+ into this file, replacing the <import> task.
+ - customize to your needs.
+
+ ***********************
+ ****** IMPORTANT ******
+ ***********************
+ In all cases you must update the value of version-tag below to read 'custom' instead of an integer,
+ in order to avoid having your file be overridden by tools such as "android update project"
+ -->
+ <!-- version-tag: 1 -->
+ <import file="${sdk.dir}/tools/ant/build.xml" />
+
+</project>
@@ -0,0 +1,40 @@
+-optimizationpasses 5
+-dontusemixedcaseclassnames
+-dontskipnonpubliclibraryclasses
+-dontpreverify
+-verbose
+-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*
+
+-keep public class * extends android.app.Activity
+-keep public class * extends android.app.Application
+-keep public class * extends android.app.Service
+-keep public class * extends android.content.BroadcastReceiver
+-keep public class * extends android.content.ContentProvider
+-keep public class * extends android.app.backup.BackupAgentHelper
+-keep public class * extends android.preference.Preference
+-keep public class com.android.vending.licensing.ILicensingService
+
+-keepclasseswithmembernames class * {
+ native <methods>;
+}
+
+-keepclasseswithmembers class * {
+ public <init>(android.content.Context, android.util.AttributeSet);
+}
+
+-keepclasseswithmembers class * {
+ public <init>(android.content.Context, android.util.AttributeSet, int);
+}
+
+-keepclassmembers class * extends android.app.Activity {
+ public void *(android.view.View);
+}
+
+-keepclassmembers enum * {
+ public static **[] values();
+ public static ** valueOf(java.lang.String);
+}
+
+-keep class * implements android.os.Parcelable {
+ public static final android.os.Parcelable$Creator *;
+}
@@ -0,0 +1,11 @@
+# This file is automatically generated by Android Tools.
+# Do not modify this file -- YOUR CHANGES WILL BE ERASED!
+#
+# This file must be checked in Version Control Systems.
+#
+# To customize properties used by the Ant build system use,
+# "ant.properties", and override values to adapt the script to your
+# project structure.
+
+# Project target.
+target=android-16
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="utf-8"?>
+<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
+ android:id="@+id/background"
+ android:layout_width="match_parent"
+ android:layout_height="match_parent"
+ android:background="@drawable/widget_frame"
+ android:orientation="horizontal">
+
+ <TextView
+ android:id="@+id/size"
+ android:layout_width="wrap_content"
+ android:layout_height="wrap_content"
+ android:layout_centerInParent="true"
+ android:textAppearance="?android:attr/textAppearanceMedium">
+
+ </TextView>
+
+</RelativeLayout>
@@ -0,0 +1,4 @@
+<?xml version="1.0" encoding="utf-8"?>
+<resources>
+ <string name="app_name">Resize App Widget Demo</string>
+</resources>
@@ -0,0 +1,8 @@
+<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
+ android:minWidth="180dip"
+ android:minHeight="110dip"
+ android:minResizeWidth="110dip"
+ android:minResizeHeight="40dip"
+ android:initialLayout="@layout/widget"
+ android:resizeMode="horizontal|vertical"
+/>
@@ -0,0 +1,17 @@
+package com.commonsware.android.appwidget.resize;
+
+import android.app.Activity;
+import android.os.Bundle;
+import android.widget.Toast;
+
+public class ActivationActivity extends Activity {
+ @Override
+ public void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+
+ Toast.makeText(this, "App widget ready to be added!",
+ Toast.LENGTH_LONG).show();
+
+ finish();
+ }
+}
@@ -0,0 +1,44 @@
+/***
+ Copyright (c) 2012 CommonsWare, LLC
+ Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ use this file except in compliance with the License. You may obtain a copy
+ of the License at http://www.apache.org/licenses/LICENSE-2.0. Unless required
+ by applicable law or agreed to in writing, software distributed under the
+ License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS
+ OF ANY KIND, either express or implied. See the License for the specific
+ language governing permissions and limitations under the License.
+
+ From _The Busy Coder's Guide to Android Development_
+ http://commonsware.com/Android
+ */
+
+package com.commonsware.android.appwidget.resize;
+
+import android.appwidget.AppWidgetManager;
+import android.appwidget.AppWidgetProvider;
+import android.content.Context;
+import android.os.Bundle;
+import android.widget.RemoteViews;
+import java.util.Locale;
+
+public class AppWidget extends AppWidgetProvider {
+ @Override
+ public void onAppWidgetOptionsChanged(Context ctxt,
+ AppWidgetManager mgr,
+ int appWidgetId,
+ Bundle newOptions) {
+ RemoteViews updateViews=
+ new RemoteViews(ctxt.getPackageName(), R.layout.widget);
+ String msg=
+ String.format(Locale.getDefault(),
+ "[%d-%d] x [%d-%d]",
+ newOptions.getInt(AppWidgetManager.OPTION_APPWIDGET_MIN_WIDTH),
+ newOptions.getInt(AppWidgetManager.OPTION_APPWIDGET_MAX_WIDTH),
+ newOptions.getInt(AppWidgetManager.OPTION_APPWIDGET_MIN_HEIGHT),
+ newOptions.getInt(AppWidgetManager.OPTION_APPWIDGET_MAX_HEIGHT));
+
+ updateViews.setTextViewText(R.id.size, msg);
+
+ mgr.updateAppWidget(appWidgetId, updateViews);
+ }
+}
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<classpath>
+ <classpathentry kind="src" path="src"/>
+ <classpathentry kind="src" path="gen"/>
+ <classpathentry kind="con" path="com.android.ide.eclipse.adt.ANDROID_FRAMEWORK"/>
+ <classpathentry exported="true" kind="con" path="com.android.ide.eclipse.adt.LIBRARIES"/>
+ <classpathentry kind="output" path="bin/classes"/>
+</classpath>
@@ -0,0 +1,33 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+ <name>TwoOrThreeDice</name>
+ <comment></comment>
+ <projects>
+ </projects>
+ <buildSpec>
+ <buildCommand>
+ <name>com.android.ide.eclipse.adt.ResourceManagerBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ <buildCommand>
+ <name>com.android.ide.eclipse.adt.PreCompilerBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ <buildCommand>
+ <name>org.eclipse.jdt.core.javabuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ <buildCommand>
+ <name>com.android.ide.eclipse.adt.ApkBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ </buildSpec>
+ <natures>
+ <nature>com.android.ide.eclipse.adt.AndroidNature</nature>
+ <nature>org.eclipse.jdt.core.javanature</nature>
+ </natures>
+</projectDescription>
Oops, something went wrong.

0 comments on commit c37171f

Please sign in to comment.