From 2cac08d38e2cb9c41a65d9716314647cac4edaf4 Mon Sep 17 00:00:00 2001 From: Shreya Date: Tue, 24 Oct 2017 21:30:12 +0530 Subject: [PATCH] Insert Pictures https://github.com/autyzm-pg/friendly-plans/issues/145 --- Friendly-plans/app/build.gradle | 6 +- .../friendly_plans/TaskCreateFragment.java | 126 +++++++++++++++++- .../java/pg/autyzm/friendly_plans/Utils.java | 55 ++++++++ Friendly-plans/build.gradle | 4 +- .../gradle/wrapper/gradle-wrapper.properties | 4 +- 5 files changed, 186 insertions(+), 9 deletions(-) create mode 100644 Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/Utils.java diff --git a/Friendly-plans/app/build.gradle b/Friendly-plans/app/build.gradle index 5ff46804..1654fe28 100644 --- a/Friendly-plans/app/build.gradle +++ b/Friendly-plans/app/build.gradle @@ -6,13 +6,13 @@ buildscript { mavenCentral() } dependencies { - classpath 'org.greenrobot:greendao-gradle-plugin:3.2.1' + classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' } } android { compileSdkVersion 24 - buildToolsVersion '24.0.2' + buildToolsVersion '25.0.0' defaultConfig { applicationId "pg.autyzm.friendly_plans" @@ -51,7 +51,7 @@ greendao { dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) - compile 'org.greenrobot:greendao:3.2.0' + compile 'org.greenrobot:greendao:3.2.2' compile 'com.android.support:appcompat-v7:24.2.0' compile "com.google.dagger:dagger:2.9" compile 'com.nbsp:library:1.2' diff --git a/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/TaskCreateFragment.java b/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/TaskCreateFragment.java index 7f871473..3d91e867 100644 --- a/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/TaskCreateFragment.java +++ b/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/TaskCreateFragment.java @@ -1,12 +1,19 @@ package pg.autyzm.friendly_plans; +import android.app.Activity; +import android.app.AlertDialog; import android.app.Fragment; import android.app.FragmentTransaction; import android.content.Context; +import android.content.DialogInterface; import android.content.Intent; +import android.content.pm.PackageManager; +import android.graphics.Bitmap; import android.media.AudioManager; import android.media.MediaPlayer; import android.os.Bundle; +import android.os.Environment; +import android.provider.MediaStore; import android.view.LayoutInflater; import android.view.View; import android.view.View.OnClickListener; @@ -21,7 +28,11 @@ import com.squareup.picasso.Picasso; import database.repository.AssetRepository; import database.repository.TaskTemplateRepository; + +import java.io.ByteArrayOutputStream; import java.io.File; +import java.io.FileNotFoundException; +import java.io.FileOutputStream; import java.io.IOException; import javax.inject.Inject; import pg.autyzm.friendly_plans.asset.AssetType; @@ -31,10 +42,13 @@ import pg.autyzm.friendly_plans.validation.TaskValidation; import pg.autyzm.friendly_plans.validation.Utils; + public class TaskCreateFragment extends Fragment { private static final String REGEX_TRIM_NAME = "_([\\d]*)(?=\\.)"; private static final String TASK_ID = "task_id"; + private static final int REQUEST_CAMERA =0 ; + private static final int SELECT_FILE = 1; @Inject public FilePickerProxy filePickerProxy; @@ -64,6 +78,7 @@ public class TaskCreateFragment extends Fragment { private ImageView playSoundIcon; private Long pictureId; private Long soundId; + String userChoosenTask; @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, @@ -106,7 +121,29 @@ private void registerViews(View view) { selectPicture.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { - filePickerProxy.openFilePicker(TaskCreateFragment.this, AssetType.PICTURE); + final CharSequence[] items = {"Take Photo", "Choose from Library", + "Cancel"}; + AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); + builder.setTitle("Add Photo!"); + builder.setItems(items, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int item) { + boolean result = pg.autyzm.friendly_plans.Utils.checkPermission(getActivity()); + if (items[item].equals("Take Photo")) { + userChoosenTask="Take Photo"; + if (result) + cameraIntent(); + } else if (items[item].equals("Choose from Library")) { + userChoosenTask="Choose from Library"; + if (result) + galleryIntent(); + } else if (items[item].equals("Cancel")) { + dialog.dismiss(); + } + } + }); + builder.show(); + } }); @@ -185,7 +222,7 @@ private void showStepsList(long taskId) { transaction.commit(); } - @Override +/* @Override public void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); @@ -196,7 +233,7 @@ public void onActivityResult(int requestCode, int resultCode, Intent data) { handleAssetSelecting(data, AssetType.SOUND); } } - } + }*/ private void handleAssetSelecting(Intent data, AssetType assetType) { Context context = getActivity().getApplicationContext(); @@ -296,5 +333,88 @@ private void showToastMessage(int resourceStringId) { resourceStringId, getActivity().getApplicationContext()); } + + private void cameraIntent() + { + Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); + startActivityForResult(intent, REQUEST_CAMERA); + } + + private void galleryIntent() + { + Intent intent = new Intent(); + intent.setType("image/*"); + intent.setAction(Intent.ACTION_GET_CONTENT);// + startActivityForResult(Intent.createChooser(intent, "Select File"),SELECT_FILE); + } + + @Override + public void onActivityResult(int requestCode, int resultCode, Intent data) { + super.onActivityResult(requestCode, resultCode, data); + + if (resultCode == Activity.RESULT_OK) { + if (requestCode == SELECT_FILE) + onSelectFromGalleryResult(data); + else if (requestCode == REQUEST_CAMERA) + onCaptureImageResult(data); + } + + + } + + private void onCaptureImageResult(Intent data) { + Bitmap thumbnail = (Bitmap) data.getExtras().get("data"); + ByteArrayOutputStream bytes = new ByteArrayOutputStream(); + thumbnail.compress(Bitmap.CompressFormat.JPEG, 90, bytes); + + File destination = new File(Environment.getExternalStorageDirectory(), + System.currentTimeMillis() + ".jpg"); + + FileOutputStream fo; + try { + destination.createNewFile(); + fo = new FileOutputStream(destination); + fo.write(bytes.toByteArray()); + fo.close(); + } catch (FileNotFoundException e) { + e.printStackTrace(); + } catch (IOException e) { + e.printStackTrace(); + } + + picturePreview.setImageBitmap(thumbnail); + } + + @SuppressWarnings("deprecation") + private void onSelectFromGalleryResult(Intent data) { + + Bitmap bm=null; + if (data != null) { + try { + bm = MediaStore.Images.Media.getBitmap(getActivity().getContentResolver(), data.getData()); + } catch (IOException e) { + e.printStackTrace(); + } + } + + picturePreview.setImageBitmap(bm); + } + + + @Override + public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { + switch (requestCode) { + case pg.autyzm.friendly_plans.Utils.MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE: + if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { + if(userChoosenTask.equals("Take Photo")) + cameraIntent(); + else if(userChoosenTask.equals("Choose from Library")) + galleryIntent(); + } else { + //code for deny + } + break; + } + } } diff --git a/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/Utils.java b/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/Utils.java new file mode 100644 index 00000000..bcb524cd --- /dev/null +++ b/Friendly-plans/app/src/main/java/pg/autyzm/friendly_plans/Utils.java @@ -0,0 +1,55 @@ +package pg.autyzm.friendly_plans; + +/** + * Created by shreya on 24/10/17. + */ + +import android.Manifest; +import android.annotation.TargetApi; +import android.app.Activity; +import android.content.Context; +import android.content.DialogInterface; +import android.content.pm.PackageManager; +import android.os.Build; +import android.support.v4.app.ActivityCompat; +import android.support.v4.content.ContextCompat; +import android.support.v7.app.AlertDialog; + +/** + * Created by shreya on 24/10/17. + */ + +public class Utils { + public static final int MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE = 123; + @TargetApi(Build.VERSION_CODES.JELLY_BEAN) + public static boolean checkPermission(final Context context) + { + int currentAPIVersion = Build.VERSION.SDK_INT; + if(currentAPIVersion>=android.os.Build.VERSION_CODES.M) + { + if (ContextCompat.checkSelfPermission(context, Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { + if (ActivityCompat.shouldShowRequestPermissionRationale((Activity) context, Manifest.permission.READ_EXTERNAL_STORAGE)) { + AlertDialog.Builder alertBuilder = new AlertDialog.Builder(context); + alertBuilder.setCancelable(true); + alertBuilder.setTitle("Permission necessary"); + alertBuilder.setMessage("External storage permission is necessary"); + alertBuilder.setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() { + @TargetApi(Build.VERSION_CODES.JELLY_BEAN) + public void onClick(DialogInterface dialog, int which) { + ActivityCompat.requestPermissions((Activity) context, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE); + } + }); + AlertDialog alert = alertBuilder.create(); + alert.show(); + } else { + ActivityCompat.requestPermissions((Activity) context, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, MY_PERMISSIONS_REQUEST_READ_EXTERNAL_STORAGE); + } + return false; + } else { + return true; + } + } else { + return true; + } + } +} diff --git a/Friendly-plans/build.gradle b/Friendly-plans/build.gradle index 965bb10f..4c43b387 100644 --- a/Friendly-plans/build.gradle +++ b/Friendly-plans/build.gradle @@ -3,9 +3,11 @@ buildscript { repositories { jcenter() + mavenCentral() } dependencies { - classpath 'com.android.tools.build:gradle:2.2.3' + classpath 'com.android.tools.build:gradle:2.3.3' + classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files diff --git a/Friendly-plans/gradle/wrapper/gradle-wrapper.properties b/Friendly-plans/gradle/wrapper/gradle-wrapper.properties index e8d0b8c2..3de5b5df 100644 --- a/Friendly-plans/gradle/wrapper/gradle-wrapper.properties +++ b/Friendly-plans/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ -#Fri Mar 17 09:06:03 CET 2017 +#Mon Oct 23 18:28:38 IST 2017 distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-2.14.1-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip