diff --git a/.gitignore b/.gitignore index 47e4981..3d880e7 100644 --- a/.gitignore +++ b/.gitignore @@ -14,6 +14,7 @@ # Generated files bin/ gen/ +release/ # Gradle files .gradle/ diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..44d6480 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,7 @@ +### 0.2.0 +- minSdk 7 + +### 0.1.0 +- First Release +- Basic manual inflate +- minSdk 14 diff --git a/README.md b/README.md index 6896d46..5412ddd 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ Mr. Vector ========== ![Mr. Vector](http://i.imgur.com/ucFr5T7.png) -AKA VectorDrawableCompat: A 14+ backport of [VectorDrawable](https://developer.android.com/reference/android/graphics/drawable/VectorDrawable.html). +AKA VectorDrawableCompat: A 7+ backport of [VectorDrawable](https://developer.android.com/reference/android/graphics/drawable/VectorDrawable.html). ### Demo @@ -12,10 +12,10 @@ AKA VectorDrawableCompat: A 14+ backport of [VectorDrawable](https://developer.a ### Usage -See demo, at this point latest version is `0.1.0` +See demo, at this point latest version looks like ```groovy -compile 'com.telly:mrvector:(insert latest version)' +compile 'com.telly:mrvector:0.2.0' ``` ### Basic inflate diff --git a/demo/src/main/res/layout/activity_basic_inflate.xml b/demo/src/main/res/layout/activity_basic_inflate.xml index 7a8bbe2..0aafd04 100644 --- a/demo/src/main/res/layout/activity_basic_inflate.xml +++ b/demo/src/main/res/layout/activity_basic_inflate.xml @@ -25,6 +25,6 @@ android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" - android:background="?android:selectableItemBackground" + android:background="?selectableItemBackground" /> \ No newline at end of file diff --git a/extras/banner.sketch b/extras/banner.sketch new file mode 100644 index 0000000..71de759 Binary files /dev/null and b/extras/banner.sketch differ diff --git a/gradle.properties b/gradle.properties index 1101e44..b832c22 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,12 +1,12 @@ -VERSION_NAME=0.1.0 -VERSION_CODE=1 +VERSION_NAME=0.2.0 +VERSION_CODE=2 GROUP=com.telly POM_NAME=Mr. Vector Library POM_ARTIFACT_ID=mrvector POM_PACKAGING=aar -POM_DESCRIPTION=Mr. Vector (VectorDrawableCompat): A 14+ backport of VectorDrawable +POM_DESCRIPTION=Mr. Vector (VectorDrawableCompat): A 7+ backport of VectorDrawable POM_URL=https://github.com/telly/MrVector POM_SCM_URL=https://github.com/telly/MrVector POM_SCM_CONNECTION=scm:git@github.com:telly/MrVector.git @@ -17,7 +17,7 @@ POM_LICENCE_DIST=repo POM_DEVELOPER_ID=eveliotc POM_DEVELOPER_NAME=Evelio Tarazona Caceres -ANDROID_BUILD_MIN_SDK_VERSION=14 +ANDROID_BUILD_MIN_SDK_VERSION=7 ANDROID_BUILD_TARGET_SDK_VERSION=21 ANDROID_BUILD_SDK_VERSION=21 ANDROID_BUILD_TOOLS_VERSION=21.1.2 diff --git a/library/src/main/java/com/telly/mrvector/PathParser.java b/library/src/main/java/com/telly/mrvector/PathParser.java index e5220e0..71119b0 100644 --- a/library/src/main/java/com/telly/mrvector/PathParser.java +++ b/library/src/main/java/com/telly/mrvector/PathParser.java @@ -18,7 +18,6 @@ import android.util.Log; import java.util.ArrayList; -import java.util.Arrays; import static android.os.Build.VERSION_CODES.LOLLIPOP; @@ -189,7 +188,7 @@ private static float[] getFloats(String s) { startPosition = endPosition + 1; } } - return Arrays.copyOf(results, count); + return Utils.copyOf(results, count); } catch (NumberFormatException e) { Log.e(LOGTAG, "error in parsing \"" + s + "\""); throw e; @@ -247,7 +246,7 @@ private PathDataNode(char type, float[] params) { private PathDataNode(PathDataNode n) { mType = n.mType; - mParams = Arrays.copyOf(n.mParams, n.mParams.length); + mParams = Utils.copyOf(n.mParams, n.mParams.length); } /** diff --git a/library/src/main/java/com/telly/mrvector/Utils.java b/library/src/main/java/com/telly/mrvector/Utils.java index c068e39..ec73644 100644 --- a/library/src/main/java/com/telly/mrvector/Utils.java +++ b/library/src/main/java/com/telly/mrvector/Utils.java @@ -27,8 +27,6 @@ import android.util.Log; import java.lang.reflect.Method; -import java.util.HashMap; -import java.util.Map; import static android.graphics.PorterDuff.Mode; import static android.graphics.PorterDuff.Mode.SRC_IN; @@ -87,6 +85,7 @@ static int getLayoutDirection(Drawable drawable) { * * @hide */ + @TargetApi(Build.VERSION_CODES.HONEYCOMB) static Mode parseTintMode(int value, Mode defaultMode) { switch (value) { case 3: return Mode.SRC_OVER; @@ -133,4 +132,26 @@ static int getChangingConfigurations(TypedArray a) { } return 0; } + + static float[] copyOf(float[] original, int newLength) { + if (newLength < 0) { + throw new NegativeArraySizeException(Integer.toString(newLength)); + } + return copyOfRange(original, 0, newLength); + } + + static float[] copyOfRange(float[] original, int start, int end) { + if (start > end) { + throw new IllegalArgumentException(); + } + int originalLength = original.length; + if (start < 0 || start > originalLength) { + throw new ArrayIndexOutOfBoundsException(); + } + int resultLength = end - start; + int copyLength = Math.min(resultLength, originalLength - start); + float[] result = new float[resultLength]; + System.arraycopy(original, start, result, 0, copyLength); + return result; + } }