Add apng viewer activity (Main2Activity)
This commit is contained in:
parent
8e36373754
commit
2074206d3d
Binary file not shown.
|
@ -8,7 +8,7 @@ android {
|
||||||
compileSdkVersion 27
|
compileSdkVersion 27
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
applicationId "oupson.apngcreator"
|
applicationId "oupson.apngcreator"
|
||||||
minSdkVersion 25
|
minSdkVersion 24
|
||||||
targetSdkVersion 26
|
targetSdkVersion 26
|
||||||
versionCode 1
|
versionCode 1
|
||||||
versionName "1.0"
|
versionName "1.0"
|
||||||
|
@ -30,9 +30,10 @@ android {
|
||||||
productFlavors {
|
productFlavors {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ext.anko_version='0.10.6'
|
ext.anko_version = '0.10.6'
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
|
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:$kotlin_version"
|
||||||
|
//noinspection GradleCompatible
|
||||||
implementation 'com.android.support:appcompat-v7:27.1.1'
|
implementation 'com.android.support:appcompat-v7:27.1.1'
|
||||||
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
|
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
|
||||||
testImplementation 'junit:junit:4.12'
|
testImplementation 'junit:junit:4.12'
|
||||||
|
|
|
@ -1,8 +1,11 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
package="oupson.apngcreator">
|
package="oupson.apngcreator">
|
||||||
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
|
|
||||||
<uses-permission android:name="android.permission.INTERNET"/>
|
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
|
||||||
|
<uses-permission android:name="android.permission.INTERNET" />
|
||||||
|
|
||||||
<application
|
<application
|
||||||
android:allowBackup="true"
|
android:allowBackup="true"
|
||||||
android:icon="@mipmap/ic_launcher"
|
android:icon="@mipmap/ic_launcher"
|
||||||
|
@ -17,6 +20,17 @@
|
||||||
<category android:name="android.intent.category.LAUNCHER" />
|
<category android:name="android.intent.category.LAUNCHER" />
|
||||||
</intent-filter>
|
</intent-filter>
|
||||||
</activity>
|
</activity>
|
||||||
|
<activity android:name=".Main2Activity"
|
||||||
|
android:label="APNG Viewer">
|
||||||
|
<intent-filter tools:ignore="AppLinkUrlError">
|
||||||
|
<action android:name="android.intent.action.VIEW"/>
|
||||||
|
|
||||||
|
<category android:name="android.intent.category.BROWSABLE"/>
|
||||||
|
<category android:name="android.intent.category.DEFAULT"/>
|
||||||
|
|
||||||
|
<data android:mimeType="image/png"/>
|
||||||
|
</intent-filter>
|
||||||
|
</activity>
|
||||||
</application>
|
</application>
|
||||||
|
|
||||||
</manifest>
|
</manifest>
|
|
@ -0,0 +1,63 @@
|
||||||
|
package oupson.apngcreator
|
||||||
|
|
||||||
|
import android.content.ContentResolver
|
||||||
|
import android.net.Uri
|
||||||
|
import android.os.Bundle
|
||||||
|
import android.provider.MediaStore
|
||||||
|
import android.support.v7.app.AppCompatActivity
|
||||||
|
import android.util.Log
|
||||||
|
import kotlinx.android.synthetic.main.activity_main2.*
|
||||||
|
import oupson.apng.ApngAnimator
|
||||||
|
|
||||||
|
class Main2Activity : AppCompatActivity() {
|
||||||
|
|
||||||
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
|
super.onCreate(savedInstanceState)
|
||||||
|
setContentView(R.layout.activity_main2)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onResume() {
|
||||||
|
super.onResume()
|
||||||
|
val animator = ApngAnimator(imageView3)
|
||||||
|
val uri = intent.data
|
||||||
|
if (uri.toString().contains("file:///")) {
|
||||||
|
animator.load(uri.path)
|
||||||
|
}
|
||||||
|
Log.e("TAG", intent.data.toString())
|
||||||
|
|
||||||
|
animator.load(getImageRealPath(contentResolver, uri, null))
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getImageRealPath(contentResolver: ContentResolver, uri: Uri, whereClause: String?): String {
|
||||||
|
var ret = ""
|
||||||
|
|
||||||
|
// Query the uri with condition.
|
||||||
|
val cursor = contentResolver.query(uri, null, whereClause, null, null)
|
||||||
|
|
||||||
|
if (cursor != null) {
|
||||||
|
val moveToFirst = cursor.moveToFirst()
|
||||||
|
if (moveToFirst) {
|
||||||
|
|
||||||
|
// Get columns name by uri type.
|
||||||
|
var columnName = MediaStore.Images.Media.DATA
|
||||||
|
|
||||||
|
if (uri === MediaStore.Images.Media.EXTERNAL_CONTENT_URI) {
|
||||||
|
columnName = MediaStore.Images.Media.DATA
|
||||||
|
} else if (uri === MediaStore.Audio.Media.EXTERNAL_CONTENT_URI) {
|
||||||
|
columnName = MediaStore.Audio.Media.DATA
|
||||||
|
} else if (uri === MediaStore.Video.Media.EXTERNAL_CONTENT_URI) {
|
||||||
|
columnName = MediaStore.Video.Media.DATA
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get column index.
|
||||||
|
val imageColumnIndex = cursor.getColumnIndex(columnName)
|
||||||
|
|
||||||
|
// Get column value which is the uri related file local path.
|
||||||
|
ret = cursor.getString(imageColumnIndex)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret
|
||||||
|
}
|
||||||
|
}
|
|
@ -26,7 +26,7 @@ import java.net.URL
|
||||||
class MainActivity : AppCompatActivity() {
|
class MainActivity : AppCompatActivity() {
|
||||||
lateinit var animator : ApngAnimator
|
lateinit var animator : ApngAnimator
|
||||||
|
|
||||||
val imageUrl = "https://cloud.githubusercontent.com/assets/13003036/24979875/e658e7c8-1fa3-11e7-908a-f1a201d38d52.png"
|
val imageUrl = "https://raw.githubusercontent.com/tinify/iMessage-Panda-sticker/master/Source/panda-original.png"
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".Main2Activity">
|
||||||
|
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/imageView3"
|
||||||
|
android:layout_width="0dp"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
android:layout_marginStart="8dp"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:layout_marginEnd="8dp"
|
||||||
|
android:layout_marginBottom="8dp"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent"
|
||||||
|
app:srcCompat="@android:color/transparent" />
|
||||||
|
</android.support.constraint.ConstraintLayout>
|
Loading…
Reference in New Issue