└── FirebaseUploadImage ├── .gitignore ├── .idea ├── compiler.xml ├── copyright │ └── profiles_settings.xml ├── gradle.xml ├── inspectionProfiles │ ├── Project_Default.xml │ └── profiles_settings.xml ├── misc.xml ├── modules.xml └── runConfigurations.xml ├── app ├── .gitignore ├── build.gradle ├── google-services.json ├── proguard-rules.pro └── src │ ├── androidTest │ └── java │ │ └── com │ │ └── tabian │ │ └── firebaseuploadimage │ │ └── ExampleInstrumentedTest.java │ ├── main │ ├── AndroidManifest.xml │ ├── java │ │ └── com │ │ │ └── tabian │ │ │ └── firebaseuploadimage │ │ │ ├── MainActivity.java │ │ │ └── UploadActivity.java │ └── res │ │ ├── layout │ │ ├── activity_main.xml │ │ └── upload_layout.xml │ │ ├── mipmap-hdpi │ │ └── ic_launcher.png │ │ ├── mipmap-mdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxxhdpi │ │ └── ic_launcher.png │ │ ├── values-w820dp │ │ └── dimens.xml │ │ └── values │ │ ├── colors.xml │ │ ├── dimens.xml │ │ ├── strings.xml │ │ └── styles.xml │ └── test │ └── java │ └── com │ └── tabian │ └── firebaseuploadimage │ └── ExampleUnitTest.java ├── build.gradle ├── gradle.properties ├── gradle └── wrapper │ ├── gradle-wrapper.jar │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat └── settings.gradle /FirebaseUploadImage/.gitignore: -------------------------------------------------------------------------------- 1 | *.iml 2 | .gradle 3 | /local.properties 4 | /.idea/workspace.xml 5 | /.idea/libraries 6 | .DS_Store 7 | /build 8 | /captures 9 | .externalNativeBuild 10 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/compiler.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/copyright/profiles_settings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/gradle.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 18 | 19 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/inspectionProfiles/Project_Default.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 10 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/inspectionProfiles/profiles_settings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 7 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/misc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 19 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 46 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/modules.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /FirebaseUploadImage/.idea/runConfigurations.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 11 | 12 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/.gitignore: -------------------------------------------------------------------------------- 1 | /build 2 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/build.gradle: -------------------------------------------------------------------------------- 1 | apply plugin: 'com.android.application' 2 | 3 | android { 4 | compileSdkVersion 24 5 | buildToolsVersion "24.0.1" 6 | defaultConfig { 7 | applicationId "com.tabian.firebaseuploadimage" 8 | minSdkVersion 18 9 | targetSdkVersion 24 10 | versionCode 1 11 | versionName "1.0" 12 | testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" 13 | } 14 | buildTypes { 15 | release { 16 | minifyEnabled false 17 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 18 | } 19 | } 20 | } 21 | 22 | dependencies { 23 | compile fileTree(dir: 'libs', include: ['*.jar']) 24 | androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { 25 | exclude group: 'com.android.support', module: 'support-annotations' 26 | }) 27 | compile 'com.android.support:appcompat-v7:24.2.1' 28 | compile 'com.google.firebase:firebase-auth:10.0.1' 29 | testCompile 'junit:junit:4.12' 30 | compile 'com.google.firebase:firebase-storage:10.0.1' 31 | compile 'com.google.firebase:firebase-auth:10.0.1' 32 | } 33 | apply plugin: 'com.google.gms.google-services' 34 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/google-services.json: -------------------------------------------------------------------------------- 1 | { 2 | "project_info": { 3 | "project_number": "271253123822", 4 | "firebase_url": "https://fir-uploadimage-c48f4.firebaseio.com", 5 | "project_id": "fir-uploadimage-c48f4", 6 | "storage_bucket": "fir-uploadimage-c48f4.appspot.com" 7 | }, 8 | "client": [ 9 | { 10 | "client_info": { 11 | "mobilesdk_app_id": "1:271253123822:android:eed7634c7bea201b", 12 | "android_client_info": { 13 | "package_name": "com.tabian.firebaseuploadimage" 14 | } 15 | }, 16 | "oauth_client": [ 17 | { 18 | "client_id": "271253123822-nak39podggck3oi4m58ght6m3b2p8h4c.apps.googleusercontent.com", 19 | "client_type": 1, 20 | "android_info": { 21 | "package_name": "com.tabian.firebaseuploadimage", 22 | "certificate_hash": "A1282F8C2B490A54CC1D7BDCEFEA5C630F537950" 23 | } 24 | }, 25 | { 26 | "client_id": "271253123822-fb1g9dvbume8r2tjqbrojhi7i0k9tvdh.apps.googleusercontent.com", 27 | "client_type": 3 28 | } 29 | ], 30 | "api_key": [ 31 | { 32 | "current_key": "AIzaSyAToMjBCxZrGEU3bmrbnisMQOJqX3gayQ0" 33 | } 34 | ], 35 | "services": { 36 | "analytics_service": { 37 | "status": 1 38 | }, 39 | "appinvite_service": { 40 | "status": 2, 41 | "other_platform_oauth_client": [ 42 | { 43 | "client_id": "271253123822-fb1g9dvbume8r2tjqbrojhi7i0k9tvdh.apps.googleusercontent.com", 44 | "client_type": 3 45 | } 46 | ] 47 | }, 48 | "ads_service": { 49 | "status": 2 50 | } 51 | } 52 | } 53 | ], 54 | "configuration_version": "1" 55 | } -------------------------------------------------------------------------------- /FirebaseUploadImage/app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # By default, the flags in this file are appended to flags specified 3 | # in C:\Users\User\AppData\Local\Android\sdk/tools/proguard/proguard-android.txt 4 | # You can edit the include path and order by changing the proguardFiles 5 | # directive in build.gradle. 6 | # 7 | # For more details, see 8 | # http://developer.android.com/guide/developing/tools/proguard.html 9 | 10 | # Add any project specific keep options here: 11 | 12 | # If your project uses WebView with JS, uncomment the following 13 | # and specify the fully qualified class name to the JavaScript interface 14 | # class: 15 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 16 | # public *; 17 | #} 18 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/src/androidTest/java/com/tabian/firebaseuploadimage/ExampleInstrumentedTest.java: -------------------------------------------------------------------------------- 1 | package com.tabian.firebaseuploadimage; 2 | 3 | import android.content.Context; 4 | import android.support.test.InstrumentationRegistry; 5 | import android.support.test.runner.AndroidJUnit4; 6 | 7 | import org.junit.Test; 8 | import org.junit.runner.RunWith; 9 | 10 | import static org.junit.Assert.*; 11 | 12 | /** 13 | * Instrumentation test, which will execute on an Android device. 14 | * 15 | * @see Testing documentation 16 | */ 17 | @RunWith(AndroidJUnit4.class) 18 | public class ExampleInstrumentedTest { 19 | @Test 20 | public void useAppContext() throws Exception { 21 | // Context of the app under test. 22 | Context appContext = InstrumentationRegistry.getTargetContext(); 23 | 24 | assertEquals("com.tabian.firebaseuploadimage", appContext.getPackageName()); 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/src/main/java/com/tabian/firebaseuploadimage/MainActivity.java: -------------------------------------------------------------------------------- 1 | package com.tabian.firebaseuploadimage; 2 | 3 | import android.content.Intent; 4 | import android.support.annotation.NonNull; 5 | import android.support.v7.app.AppCompatActivity; 6 | import android.os.Bundle; 7 | import android.util.Log; 8 | import android.view.View; 9 | import android.widget.Button; 10 | import android.widget.EditText; 11 | import android.widget.Toast; 12 | 13 | import com.google.firebase.auth.FirebaseAuth; 14 | import com.google.firebase.auth.FirebaseUser; 15 | 16 | public class MainActivity extends AppCompatActivity { 17 | 18 | private static final String TAG = "MainActivity"; 19 | 20 | private FirebaseAuth mAuth; 21 | private FirebaseAuth.AuthStateListener mAuthListener; 22 | 23 | // UI references. 24 | private EditText mEmail, mPassword; 25 | private Button btnSignIn, btnSignOut, btnUploadImage; 26 | 27 | @Override 28 | protected void onCreate(Bundle savedInstanceState) { 29 | super.onCreate(savedInstanceState); 30 | setContentView(R.layout.activity_main); 31 | //declare buttons and edit texts in oncreate 32 | mEmail = (EditText) findViewById(R.id.email); 33 | mPassword = (EditText) findViewById(R.id.password); 34 | btnSignIn = (Button) findViewById(R.id.email_sign_in_button); 35 | btnSignOut = (Button) findViewById(R.id.email_sign_out_button); 36 | btnUploadImage = (Button) findViewById(R.id.upload_screen); 37 | 38 | mAuth = FirebaseAuth.getInstance(); 39 | 40 | mAuthListener = new FirebaseAuth.AuthStateListener() { 41 | @Override 42 | public void onAuthStateChanged(@NonNull FirebaseAuth firebaseAuth) { 43 | FirebaseUser user = firebaseAuth.getCurrentUser(); 44 | if (user != null) { 45 | // User is signed in 46 | Log.d(TAG, "onAuthStateChanged:signed_in:" + user.getUid()); 47 | toastMessage("Successfully signed in with: " + user.getEmail()); 48 | } else { 49 | // User is signed out 50 | Log.d(TAG, "onAuthStateChanged:signed_out"); 51 | toastMessage("Successfully signed out."); 52 | } 53 | // ... 54 | } 55 | }; 56 | 57 | btnSignIn.setOnClickListener(new View.OnClickListener() { 58 | @Override 59 | public void onClick(View view) { 60 | String email = mEmail.getText().toString(); 61 | String pass = mPassword.getText().toString(); 62 | if (!email.equals("") && !pass.equals("")) { 63 | mAuth.signInWithEmailAndPassword(email, pass); 64 | } else { 65 | toastMessage("You didn't fill in all the fields."); 66 | } 67 | } 68 | }); 69 | 70 | btnSignOut.setOnClickListener(new View.OnClickListener() { 71 | @Override 72 | public void onClick(View view) { 73 | mAuth.signOut(); 74 | toastMessage("Signing Out..."); 75 | } 76 | }); 77 | 78 | btnUploadImage.setOnClickListener(new View.OnClickListener() { 79 | @Override 80 | public void onClick(View view) { 81 | Log.d(TAG, "onClick: Switching Activities."); 82 | Intent intent = new Intent(MainActivity.this, UploadActivity.class); 83 | startActivity(intent); 84 | } 85 | }); 86 | } 87 | 88 | @Override 89 | public void onStart() { 90 | super.onStart(); 91 | mAuth.addAuthStateListener(mAuthListener); 92 | } 93 | 94 | @Override 95 | public void onStop() { 96 | super.onStop(); 97 | if (mAuthListener != null) { 98 | mAuth.removeAuthStateListener(mAuthListener); 99 | } 100 | } 101 | 102 | //add a toast to show when successfully signed in 103 | 104 | /** 105 | * customizable toast 106 | * 107 | * @param message 108 | */ 109 | private void toastMessage(String message) { 110 | Toast.makeText(this, message, Toast.LENGTH_SHORT).show(); 111 | } 112 | } -------------------------------------------------------------------------------- /FirebaseUploadImage/app/src/main/java/com/tabian/firebaseuploadimage/UploadActivity.java: -------------------------------------------------------------------------------- 1 | package com.tabian.firebaseuploadimage; 2 | 3 | import android.app.ProgressDialog; 4 | import android.content.Context; 5 | import android.graphics.Bitmap; 6 | import android.graphics.BitmapFactory; 7 | import android.net.Uri; 8 | import android.os.Build; 9 | import android.os.Bundle; 10 | import android.support.annotation.NonNull; 11 | import android.support.annotation.Nullable; 12 | import android.support.v7.app.AppCompatActivity; 13 | import android.util.AttributeSet; 14 | import android.util.Log; 15 | import android.view.View; 16 | import android.widget.Button; 17 | import android.widget.EditText; 18 | import android.widget.ImageView; 19 | import android.widget.Toast; 20 | 21 | import com.google.android.gms.tasks.OnFailureListener; 22 | import com.google.android.gms.tasks.OnSuccessListener; 23 | import com.google.firebase.auth.FirebaseAuth; 24 | import com.google.firebase.auth.FirebaseUser; 25 | import com.google.firebase.storage.FirebaseStorage; 26 | import com.google.firebase.storage.StorageReference; 27 | import com.google.firebase.storage.UploadTask; 28 | 29 | import java.io.File; 30 | import java.io.FileInputStream; 31 | import java.io.FileNotFoundException; 32 | import java.util.ArrayList; 33 | 34 | /** 35 | * Created by User on 2/13/2017. 36 | */ 37 | 38 | public class UploadActivity extends AppCompatActivity { 39 | 40 | private static final String TAG = "UploadActivity"; 41 | 42 | //declare variables 43 | private ImageView image; 44 | private EditText imageName; 45 | private Button btnUpload,btnNext,btnBack; 46 | private ProgressDialog mProgressDialog; 47 | 48 | private final static int mWidth = 512; 49 | private final static int mLength = 512; 50 | 51 | private ArrayList pathArray; 52 | private int array_position; 53 | 54 | private StorageReference mStorageRef; 55 | private FirebaseAuth auth; 56 | 57 | public UploadActivity() { 58 | } 59 | 60 | @Override 61 | protected void onCreate(@Nullable Bundle savedInstanceState) { 62 | super.onCreate(savedInstanceState); 63 | setContentView(R.layout.upload_layout); 64 | image = (ImageView) findViewById(R.id.uploadImage); 65 | btnBack = (Button) findViewById(R.id.btnBackImage); 66 | btnNext = (Button) findViewById(R.id.btnNextImage); 67 | btnUpload = (Button) findViewById(R.id.btnUploadImage); 68 | imageName = (EditText) findViewById(R.id.imageName); 69 | pathArray = new ArrayList<>(); 70 | mProgressDialog = new ProgressDialog(UploadActivity.this); 71 | auth = FirebaseAuth.getInstance(); 72 | 73 | mStorageRef = FirebaseStorage.getInstance().getReference(); 74 | 75 | checkFilePermissions(); 76 | 77 | addFilePaths(); 78 | 79 | btnBack.setOnClickListener(new View.OnClickListener() { 80 | @Override 81 | public void onClick(View view) { 82 | if(array_position > 0){ 83 | Log.d(TAG, "onClick: Back an Image."); 84 | array_position = array_position - 1; 85 | loadImageFromStorage(); 86 | } 87 | } 88 | }); 89 | 90 | btnNext.setOnClickListener(new View.OnClickListener() { 91 | @Override 92 | public void onClick(View view) { 93 | if(array_position < pathArray.size() - 1){ 94 | Log.d(TAG, "onClick: Next Image."); 95 | array_position = array_position + 1; 96 | loadImageFromStorage(); 97 | } 98 | } 99 | }); 100 | 101 | btnUpload.setOnClickListener(new View.OnClickListener() { 102 | @Override 103 | public void onClick(View view) { 104 | Log.d(TAG, "onClick: Uploading Image."); 105 | mProgressDialog.setMessage("Uploading Image..."); 106 | mProgressDialog.show(); 107 | 108 | //get the signed in user 109 | FirebaseUser user = auth.getCurrentUser(); 110 | String userID = user.getUid(); 111 | 112 | String name = imageName.getText().toString(); 113 | if(!name.equals("")){ 114 | Uri uri = Uri.fromFile(new File(pathArray.get(array_position))); 115 | StorageReference storageReference = mStorageRef.child("images/users/" + userID + "/" + name + ".jpg"); 116 | storageReference.putFile(uri).addOnSuccessListener(new OnSuccessListener() { 117 | @Override 118 | public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) { 119 | // Get a URL to the uploaded content 120 | Uri downloadUrl = taskSnapshot.getDownloadUrl(); 121 | toastMessage("Upload Success"); 122 | mProgressDialog.dismiss(); 123 | } 124 | }).addOnFailureListener(new OnFailureListener() { 125 | @Override 126 | public void onFailure(@NonNull Exception e) { 127 | toastMessage("Upload Failed"); 128 | mProgressDialog.dismiss(); 129 | } 130 | }) 131 | ; 132 | } 133 | 134 | } 135 | }); 136 | 137 | } 138 | 139 | /** 140 | * Add the file paths you want to use into the array 141 | */ 142 | private void addFilePaths(){ 143 | Log.d(TAG, "addFilePaths: Adding file paths."); 144 | String path = System.getenv("EXTERNAL_STORAGE"); 145 | pathArray.add(path+"/Pictures/Portal/image1.jpg"); 146 | pathArray.add(path+"/Pictures/Portal/image2.jpg"); 147 | pathArray.add(path+"/Pictures/Portal/image3.jpg"); 148 | loadImageFromStorage(); 149 | } 150 | 151 | private void loadImageFromStorage() 152 | { 153 | try{ 154 | String path = pathArray.get(array_position); 155 | File f=new File(path, ""); 156 | Bitmap b = BitmapFactory.decodeStream(new FileInputStream(f)); 157 | image.setImageBitmap(b); 158 | }catch (FileNotFoundException e){ 159 | Log.e(TAG, "loadImageFromStorage: FileNotFoundException: " + e.getMessage() ); 160 | } 161 | 162 | } 163 | 164 | private void checkFilePermissions() { 165 | if(Build.VERSION.SDK_INT > Build.VERSION_CODES.LOLLIPOP){ 166 | int permissionCheck = UploadActivity.this.checkSelfPermission("Manifest.permission.READ_EXTERNAL_STORAGE"); 167 | permissionCheck += UploadActivity.this.checkSelfPermission("Manifest.permission.WRITE_EXTERNAL_STORAGE"); 168 | if (permissionCheck != 0) { 169 | this.requestPermissions(new String[]{android.Manifest.permission.WRITE_EXTERNAL_STORAGE,android.Manifest.permission.READ_EXTERNAL_STORAGE}, 1001); //Any number 170 | } 171 | }else{ 172 | Log.d(TAG, "checkBTPermissions: No need to check permissions. SDK version < LOLLIPOP."); 173 | } 174 | } 175 | 176 | /** 177 | * customizable toast 178 | * @param message 179 | */ 180 | private void toastMessage(String message){ 181 | Toast.makeText(this,message,Toast.LENGTH_SHORT).show(); 182 | } 183 | 184 | } 185 | 186 | 187 | 188 | 189 | 190 | 191 | 192 | 193 | 194 | 195 | 196 | 197 | 198 | 199 | 200 | 201 | 202 | 203 | 204 | 205 | 206 | 207 | 208 | 209 | 210 | 211 | -------------------------------------------------------------------------------- /FirebaseUploadImage/app/src/main/res/layout/activity_main.xml: -------------------------------------------------------------------------------- 1 | 9 | 10 | 14 | 15 | 20 | 21 | 22 | 23 | 30 | 31 | 32 | 33 | 43 | 44 |