From df994e4fe077dc643658dbd4c65845b0e086fc8a Mon Sep 17 00:00:00 2001
From: Marvin Borner
Date: Fri, 31 Aug 2018 02:03:59 +0200
Subject: Added video button and began preview after image
---
app/src/main/AndroidManifest.xml | 5 ++-
app/src/main/java/me/texx/Texx/CameraActivity.kt | 36 +++++++++++++++++++---
.../main/java/me/texx/Texx/MediaPreviewActivity.kt | 22 +++++++++++++
app/src/main/res/layout/activity_camera.xml | 2 +-
app/src/main/res/layout/activity_media_preview.xml | 15 +++++++++
5 files changed, 74 insertions(+), 6 deletions(-)
create mode 100644 app/src/main/java/me/texx/Texx/MediaPreviewActivity.kt
create mode 100644 app/src/main/res/layout/activity_media_preview.xml
(limited to 'app')
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index b27c25b..1e82523 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -4,6 +4,8 @@
package="me.texx.Texx">
+
+
@@ -39,7 +41,8 @@
android:name="android.support.PARENT_ACTIVITY"
android:value="me.texx.Texx.MainActivity" />
-
+
+
\ No newline at end of file
diff --git a/app/src/main/java/me/texx/Texx/CameraActivity.kt b/app/src/main/java/me/texx/Texx/CameraActivity.kt
index df03164..9186f28 100644
--- a/app/src/main/java/me/texx/Texx/CameraActivity.kt
+++ b/app/src/main/java/me/texx/Texx/CameraActivity.kt
@@ -1,15 +1,24 @@
package me.texx.Texx
+import android.graphics.BitmapFactory
+import android.graphics.Color.RED
+import android.graphics.PorterDuff
+import android.graphics.PorterDuffColorFilter
+import android.graphics.drawable.Drawable
import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.view.Window
import android.view.WindowManager
import com.otaliastudios.cameraview.CameraListener
+import com.otaliastudios.cameraview.Gesture
+import com.otaliastudios.cameraview.GestureAction
+import com.otaliastudios.cameraview.SessionType
import daio.io.dresscode.dressCodeName
import daio.io.dresscode.matchDressCode
import kotlinx.android.synthetic.main.activity_camera.*
+import kotlinx.android.synthetic.main.activity_media_preview.*
import me.texx.Texx.util.ThemeUtil.getThemeName
-import org.jetbrains.anko.toast
+import org.jetbrains.anko.startActivity
class CameraActivity : AppCompatActivity() {
@@ -26,15 +35,34 @@ class CameraActivity : AppCompatActivity() {
}
private fun initCameraLayout() {
+ camera.mapGesture(Gesture.PINCH, GestureAction.ZOOM)
+ camera.mapGesture(Gesture.TAP, GestureAction.FOCUS_WITH_MARKER)
+ camera.mapGesture(Gesture.LONG_TAP, GestureAction.CAPTURE)
+ camera.mapGesture(Gesture.SCROLL_HORIZONTAL, GestureAction.EXPOSURE_CORRECTION)
+
camera.addCameraListener(object : CameraListener() {
- override fun onPictureTaken(jpeg: ByteArray?) {
- toast("Photo taken")
+ override fun onPictureTaken(jpeg: ByteArray) {
+ imagePreview.setImageBitmap(BitmapFactory.decodeByteArray(jpeg, 0, jpeg.size))
+ startActivity()
}
})
- photo_button.setOnClickListener {
+ camera_button.setOnClickListener {
camera.capturePicture()
}
+
+ camera_button.setOnLongClickListener {
+ if (camera.sessionType == SessionType.PICTURE) {
+ camera.sessionType = SessionType.VIDEO
+ val videoButtonDrawable: Drawable = this.resources.getDrawable(R.drawable.focus_marker_outline)
+ videoButtonDrawable.colorFilter = PorterDuffColorFilter(RED, PorterDuff.Mode.SRC_IN)
+ camera_button.setBackgroundDrawable(videoButtonDrawable)
+ } else {
+ camera.sessionType = SessionType.PICTURE
+ camera_button.setBackgroundDrawable(this.resources.getDrawable(R.drawable.focus_marker_outline))
+ }
+ true
+ }
}
override fun onResume() {
diff --git a/app/src/main/java/me/texx/Texx/MediaPreviewActivity.kt b/app/src/main/java/me/texx/Texx/MediaPreviewActivity.kt
new file mode 100644
index 0000000..cdc5c71
--- /dev/null
+++ b/app/src/main/java/me/texx/Texx/MediaPreviewActivity.kt
@@ -0,0 +1,22 @@
+package me.texx.Texx
+
+import android.os.Bundle
+import android.support.v7.app.AppCompatActivity
+import android.view.Window
+import android.view.WindowManager
+import daio.io.dresscode.dressCodeName
+import daio.io.dresscode.matchDressCode
+import me.texx.Texx.util.ThemeUtil.getThemeName
+
+class MediaPreviewActivity : AppCompatActivity() {
+
+ override fun onCreate(savedInstanceState: Bundle?) {
+ matchDressCode()
+ super.onCreate(savedInstanceState)
+ dressCodeName = getThemeName(this)
+ requestWindowFeature(Window.FEATURE_NO_TITLE)
+ window.setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
+ WindowManager.LayoutParams.FLAG_FULLSCREEN)
+ setContentView(R.layout.activity_camera)
+ }
+}
diff --git a/app/src/main/res/layout/activity_camera.xml b/app/src/main/res/layout/activity_camera.xml
index 527db7c..d9b7a35 100644
--- a/app/src/main/res/layout/activity_camera.xml
+++ b/app/src/main/res/layout/activity_camera.xml
@@ -7,7 +7,7 @@
tools:context=".CameraActivity">