From 9d89303ffbcfd2ff6e2523e5778b77ffb89df99e Mon Sep 17 00:00:00 2001 From: Nereo Date: Wed, 8 Apr 2015 18:50:36 +0800 Subject: [PATCH] init --- .gitignore | 6 + .idea/.name | 1 + .idea/compiler.xml | 23 + .idea/copyright/profiles_settings.xml | 3 + .idea/encodings.xml | 5 + .idea/gradle.xml | 19 + .idea/misc.xml | 10 + .idea/modules.xml | 11 + .idea/scopes/scope_settings.xml | 5 + .idea/vcs.xml | 7 + MultiImageSelector.iml | 19 + app/.gitignore | 1 + app/app.iml | 95 ++++ app/build.gradle | 26 ++ app/proguard-rules.pro | 17 + .../multiimageselector/ApplicationTest.java | 13 + app/src/main/AndroidManifest.xml | 26 ++ .../multiimageselector/MainActivity.java | 119 +++++ app/src/main/res/layout/activity_main.xml | 101 ++++ app/src/main/res/menu/menu_main.xml | 6 + app/src/main/res/mipmap-hdpi/ic_launcher.png | Bin 0 -> 3418 bytes app/src/main/res/mipmap-mdpi/ic_launcher.png | Bin 0 -> 2206 bytes app/src/main/res/mipmap-xhdpi/ic_launcher.png | Bin 0 -> 4842 bytes .../main/res/mipmap-xxhdpi/ic_launcher.png | Bin 0 -> 7718 bytes app/src/main/res/values-w820dp/dimens.xml | 6 + app/src/main/res/values/dimens.xml | 5 + app/src/main/res/values/strings.xml | 6 + app/src/main/res/values/styles.xml | 8 + build.gradle | 19 + gradle.properties | 18 + gradle/wrapper/gradle-wrapper.jar | Bin 0 -> 49896 bytes gradle/wrapper/gradle-wrapper.properties | 6 + gradlew | 164 +++++++ gradlew.bat | 90 ++++ multi-image-selector/.gitignore | 1 + multi-image-selector/build.gradle | 25 + multi-image-selector/multi-image-selector.iml | 95 ++++ multi-image-selector/proguard-rules.pro | 17 + .../multi_image_selector/ApplicationTest.java | 13 + .../src/main/AndroidManifest.xml | 8 + .../MultiImageSelectorActivity.java | 131 ++++++ .../MultiImageSelectorFragment.java | 440 ++++++++++++++++++ .../adapter/FolderAdapter.java | 152 ++++++ .../adapter/ImageGridAdapter.java | 234 ++++++++++ .../multi_image_selector/bean/Folder.java | 25 + .../multi_image_selector/bean/Image.java | 28 ++ .../multi_image_selector/utils/FileUtils.java | 37 ++ .../multi_image_selector/utils/TimeUtils.java | 34 ++ .../src/main/res/color/default_text_color.xml | 8 + .../src/main/res/drawable-xhdpi/btn_back.png | Bin 0 -> 603 bytes .../res/drawable-xhdpi/default_check_s.png | Bin 0 -> 642 bytes .../main/res/drawable-xhdpi/ic_menu_back.png | Bin 0 -> 1319 bytes .../res/drawable-xhdpi/selector_indicator.png | Bin 0 -> 333 bytes .../src/main/res/drawable-xxhdpi/asv.png | Bin 0 -> 2759 bytes .../src/main/res/drawable-xxhdpi/asy.png | Bin 0 -> 4522 bytes .../main/res/drawable-xxhdpi/btn_selected.png | Bin 0 -> 1708 bytes .../res/drawable-xxhdpi/btn_unselected.png | Bin 0 -> 362 bytes .../res/drawable-xxhdpi/default_check.png | Bin 0 -> 986 bytes .../res/drawable-xxhdpi/default_error.png | Bin 0 -> 1041 bytes .../res/drawable-xxhdpi/text_indicator.png | Bin 0 -> 191 bytes .../src/main/res/drawable/action_btn.xml | 32 ++ .../src/main/res/layout/activity_default.xml | 18 + .../res/layout/cmp_customer_actionbar.xml | 43 ++ .../main/res/layout/fragment_multi_image.xml | 77 +++ .../src/main/res/layout/list_item_camera.xml | 17 + .../src/main/res/layout/list_item_folder.xml | 57 +++ .../src/main/res/layout/list_item_image.xml | 20 + .../src/main/res/values/dimens.xml | 5 + .../src/main/res/values/strings.xml | 3 + settings.gradle | 1 + 70 files changed, 2356 insertions(+) create mode 100644 .gitignore create mode 100644 .idea/.name create mode 100644 .idea/compiler.xml create mode 100644 .idea/copyright/profiles_settings.xml create mode 100644 .idea/encodings.xml create mode 100644 .idea/gradle.xml create mode 100644 .idea/misc.xml create mode 100644 .idea/modules.xml create mode 100644 .idea/scopes/scope_settings.xml create mode 100644 .idea/vcs.xml create mode 100644 MultiImageSelector.iml create mode 100644 app/.gitignore create mode 100644 app/app.iml create mode 100644 app/build.gradle create mode 100644 app/proguard-rules.pro create mode 100644 app/src/androidTest/java/me/nereo/multiimageselector/ApplicationTest.java create mode 100644 app/src/main/AndroidManifest.xml create mode 100644 app/src/main/java/me/nereo/multiimageselector/MainActivity.java create mode 100644 app/src/main/res/layout/activity_main.xml create mode 100644 app/src/main/res/menu/menu_main.xml create mode 100644 app/src/main/res/mipmap-hdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-mdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-xhdpi/ic_launcher.png create mode 100644 app/src/main/res/mipmap-xxhdpi/ic_launcher.png create mode 100644 app/src/main/res/values-w820dp/dimens.xml create mode 100644 app/src/main/res/values/dimens.xml create mode 100644 app/src/main/res/values/strings.xml create mode 100644 app/src/main/res/values/styles.xml create mode 100644 build.gradle create mode 100644 gradle.properties create mode 100644 gradle/wrapper/gradle-wrapper.jar create mode 100644 gradle/wrapper/gradle-wrapper.properties create mode 100644 gradlew create mode 100644 gradlew.bat create mode 100644 multi-image-selector/.gitignore create mode 100644 multi-image-selector/build.gradle create mode 100644 multi-image-selector/multi-image-selector.iml create mode 100644 multi-image-selector/proguard-rules.pro create mode 100644 multi-image-selector/src/androidTest/java/me/nereo/multi_image_selector/ApplicationTest.java create mode 100644 multi-image-selector/src/main/AndroidManifest.xml create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/MultiImageSelectorActivity.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/MultiImageSelectorFragment.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/adapter/FolderAdapter.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/adapter/ImageGridAdapter.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/bean/Folder.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/bean/Image.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/utils/FileUtils.java create mode 100644 multi-image-selector/src/main/java/me/nereo/multi_image_selector/utils/TimeUtils.java create mode 100644 multi-image-selector/src/main/res/color/default_text_color.xml create mode 100644 multi-image-selector/src/main/res/drawable-xhdpi/btn_back.png create mode 100644 multi-image-selector/src/main/res/drawable-xhdpi/default_check_s.png create mode 100644 multi-image-selector/src/main/res/drawable-xhdpi/ic_menu_back.png create mode 100644 multi-image-selector/src/main/res/drawable-xhdpi/selector_indicator.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/asv.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/asy.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/btn_selected.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/btn_unselected.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/default_check.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/default_error.png create mode 100644 multi-image-selector/src/main/res/drawable-xxhdpi/text_indicator.png create mode 100644 multi-image-selector/src/main/res/drawable/action_btn.xml create mode 100644 multi-image-selector/src/main/res/layout/activity_default.xml create mode 100644 multi-image-selector/src/main/res/layout/cmp_customer_actionbar.xml create mode 100644 multi-image-selector/src/main/res/layout/fragment_multi_image.xml create mode 100644 multi-image-selector/src/main/res/layout/list_item_camera.xml create mode 100644 multi-image-selector/src/main/res/layout/list_item_folder.xml create mode 100644 multi-image-selector/src/main/res/layout/list_item_image.xml create mode 100644 multi-image-selector/src/main/res/values/dimens.xml create mode 100644 multi-image-selector/src/main/res/values/strings.xml create mode 100644 settings.gradle diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..afbdab3 --- /dev/null +++ b/.gitignore @@ -0,0 +1,6 @@ +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..5a43c55 --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +MultiImageSelector \ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..217af47 --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,23 @@ + + + + + + diff --git a/.idea/copyright/profiles_settings.xml b/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000..e7bedf3 --- /dev/null +++ b/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/.idea/encodings.xml b/.idea/encodings.xml new file mode 100644 index 0000000..e206d70 --- /dev/null +++ b/.idea/encodings.xml @@ -0,0 +1,5 @@ + + + + + diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..85a6c64 --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,19 @@ + + + + + + + diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..9076de5 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,10 @@ + + + + + + + + + + diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..16aeed6 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,11 @@ + + + + + + + + + + + diff --git a/.idea/scopes/scope_settings.xml b/.idea/scopes/scope_settings.xml new file mode 100644 index 0000000..922003b --- /dev/null +++ b/.idea/scopes/scope_settings.xml @@ -0,0 +1,5 @@ + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..def6a6a --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,7 @@ + + + + + + + diff --git a/MultiImageSelector.iml b/MultiImageSelector.iml new file mode 100644 index 0000000..8935ebd --- /dev/null +++ b/MultiImageSelector.iml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/app/app.iml b/app/app.iml new file mode 100644 index 0000000..46168ca --- /dev/null +++ b/app/app.iml @@ -0,0 +1,95 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..5c156f5 --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,26 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 22 + buildToolsVersion "22.0.1" + + defaultConfig { + applicationId "me.nereo.multiimageselector" + minSdkVersion 12 + targetSdkVersion 22 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} + +dependencies { + compile fileTree(include: ['*.jar'], dir: 'libs') + compile 'com.android.support:appcompat-v7:22.0.0' + compile project(':multi-image-selector') +} diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..767408b --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in F:\Nereo\Program\Android\sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} diff --git a/app/src/androidTest/java/me/nereo/multiimageselector/ApplicationTest.java b/app/src/androidTest/java/me/nereo/multiimageselector/ApplicationTest.java new file mode 100644 index 0000000..e8fcd41 --- /dev/null +++ b/app/src/androidTest/java/me/nereo/multiimageselector/ApplicationTest.java @@ -0,0 +1,13 @@ +package me.nereo.multiimageselector; + +import android.app.Application; +import android.test.ApplicationTestCase; + +/** + * Testing Fundamentals + */ +public class ApplicationTest extends ApplicationTestCase { + public ApplicationTest() { + super(Application.class); + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..911b777 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/java/me/nereo/multiimageselector/MainActivity.java b/app/src/main/java/me/nereo/multiimageselector/MainActivity.java new file mode 100644 index 0000000..075595a --- /dev/null +++ b/app/src/main/java/me/nereo/multiimageselector/MainActivity.java @@ -0,0 +1,119 @@ +package me.nereo.multiimageselector; + +import android.content.Intent; +import android.support.v7.app.ActionBarActivity; +import android.os.Bundle; +import android.text.TextUtils; +import android.util.Log; +import android.view.Menu; +import android.view.MenuItem; +import android.view.View; +import android.widget.EditText; +import android.widget.RadioGroup; +import android.widget.TextView; + +import java.util.List; + +import me.nereo.multi_image_selector.MultiImageSelectorActivity; + + +public class MainActivity extends ActionBarActivity { + + private static final int REQUEST_IMAGE = 2; + + private TextView mResultText; + private RadioGroup mChoiceMode, mShowCamera; + private EditText mRequestNum; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + + mResultText = (TextView) findViewById(R.id.result); + mChoiceMode = (RadioGroup) findViewById(R.id.choice_mode); + mShowCamera = (RadioGroup) findViewById(R.id.show_camera); + mRequestNum = (EditText) findViewById(R.id.request_num); + + mChoiceMode.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { + @Override + public void onCheckedChanged(RadioGroup radioGroup, int checkedId) { + if(checkedId == R.id.multi){ + mRequestNum.setEnabled(true); + }else{ + mRequestNum.setEnabled(false); + mRequestNum.setText(""); + } + } + }); + + findViewById(R.id.button).setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View view) { + + int selectedMode = MultiImageSelectorActivity.MODE_MULTI; + + if(mChoiceMode.getCheckedRadioButtonId() == R.id.single){ + selectedMode = MultiImageSelectorActivity.MODE_SINGLE; + }else{ + selectedMode = MultiImageSelectorActivity.MODE_MULTI; + } + + boolean showCamera = mShowCamera.getCheckedRadioButtonId() == R.id.show; + + int maxNum = 9; + if(!TextUtils.isEmpty(mRequestNum.getText())){ + maxNum = Integer.valueOf(mRequestNum.getText().toString()); + } + + Intent intent = new Intent(MainActivity.this, MultiImageSelectorActivity.class); + // 是否显示拍摄图片 + intent.putExtra(MultiImageSelectorActivity.EXTRA_SHOW_CAMERA, showCamera); + // 最大可选择图片数量 + intent.putExtra(MultiImageSelectorActivity.EXTRA_SELECT_COUNT, maxNum); + // 选择模式 + intent.putExtra(MultiImageSelectorActivity.EXTRA_SELECT_MODE, selectedMode); + startActivityForResult(intent, REQUEST_IMAGE); + + } + }); + } + + @Override + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + super.onActivityResult(requestCode, resultCode, data); + if(requestCode == REQUEST_IMAGE){ + if(resultCode == RESULT_OK){ + List path = data.getStringArrayListExtra(MultiImageSelectorActivity.EXTRA_RESULT); + StringBuilder sb = new StringBuilder(); + for(String p: path){ + sb.append(p); + sb.append("\n"); + } + mResultText.setText(sb.toString()); + } + } + } + + @Override + public boolean onCreateOptionsMenu(Menu menu) { + // Inflate the menu; this adds items to the action bar if it is present. + getMenuInflater().inflate(R.menu.menu_main, menu); + return true; + } + + @Override + public boolean onOptionsItemSelected(MenuItem item) { + // Handle action bar item clicks here. The action bar will + // automatically handle clicks on the Home/Up button, so long + // as you specify a parent activity in AndroidManifest.xml. + int id = item.getItemId(); + + //noinspection SimplifiableIfStatement + if (id == R.id.action_settings) { + return true; + } + + return super.onOptionsItemSelected(item); + } +} diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..c00b711 --- /dev/null +++ b/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + +