commit 9d89303ffbcfd2ff6e2523e5778b77ffb89df99e Author: Nereo Date: Wed Apr 8 18:50:36 2015 +0800 init 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 @@ + + + + + + + + + + + + + + + + + + + + + + + + +