2022 - 2023년도에 사용하던 블로그 내용을 이전해 온 기록입니다.
해당 블로그는 링크로 첨부하였으며
글 내용은 동일합니다.
package com.example.ocr;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.provider.MediaStore;
import android.util.Base64;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
import com.bumptech.glide.Glide;
import com.google.android.gms.tasks.Continuation;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;
import com.google.firebase.functions.FirebaseFunctions;
import com.google.firebase.functions.HttpsCallableResult;
import com.google.gson.Gson;
import com.google.gson.JsonArray;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.google.gson.JsonPrimitive;
//import com.google.mlkit.vision.common.InputImage;
//import com.google.mlkit.vision.text.Text;
//import com.google.mlkit.vision.text.TextRecognition;
//import com.google.mlkit.vision.text.TextRecognizer;
//import com.google.mlkit.vision.text.TextRecognizerOptionsInterface;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
public class MainActivity extends AppCompatActivity {
// private static final int CAMERA = 100;
private static final int GALLERY = 101;
private FirebaseFunctions mFunctions;
// mFunctions = FirebaseFunctions.getInstance();
ImageView imageView;
TextView text_info;
Button btn_get_image;
Button btn_detection_image;
Intent intent;
String imagePath;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imageView = findViewById(R.id.imageView);
text_info = findViewById(R.id.text_info);
btn_get_image = findViewById(R.id.btn_get_image);
btn_detection_image = findViewById(R.id.btn_detection_image);
btn_get_image.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
intent = new Intent(Intent.ACTION_PICK);
intent.setType(MediaStore.Images.Media.CONTENT_TYPE);
intent.setType("image/*");
startActivityForResult(intent, GALLERY);
}
});
btn_detection_image.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
detectTxt();
}
});
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == GALLERY && resultCode == RESULT_OK) {
Cursor cursor = getContentResolver().query(data.getData(), null, null, null, null);
if (cursor != null) {
cursor.moveToFirst();
int index = cursor.getColumnIndex(MediaStore.Images.ImageColumns.DATA);
imagePath = cursor.getString(index);
Bitmap bitmap = BitmapFactory.decodeFile(imagePath);
cursor.close();
}
try {
InputStream inputStream = getContentResolver().openInputStream(data.getData());
Bitmap bm = BitmapFactory.decodeStream(inputStream);
inputStream.close();
imageView.setImageBitmap(bm);
Glide.with(this).load(imagePath).into(imageView);
} catch (IOException e) {
e.printStackTrace();
}
}
}
private Bitmap scaleBitmapDown(Bitmap bitmap, int maxDimension) {
int originalWidth = bitmap.getWidth();
int originalHeight = bitmap.getHeight();
int resizedWidth = maxDimension;
int resizedHeight = maxDimension;
if (originalHeight > originalWidth) {
resizedHeight = maxDimension;
resizedWidth = (int) (resizedHeight * (float) originalWidth / (float) originalHeight);
} else if (originalWidth > originalHeight) {
resizedWidth = maxDimension;
resizedHeight = (int) (resizedWidth * (float) originalHeight / (float) originalWidth);
} else if (originalHeight == originalWidth) {
resizedHeight = maxDimension;
resizedWidth = maxDimension;
}
return Bitmap.createScaledBitmap(bitmap, resizedWidth, resizedHeight, false);
}
public void detectTxt() {
// Bitmap bitmap = MediaStore.Images.Media.getBitmap(getContentResolver(), uri);
// Bitmap bitmap = BitmapFactory.decodeFile(imagePath);
// Bitmap bitmap = imageView.getDrawable().getBitmap();
// BitmapDrawable bitmap = new BitmapDrawable(getResources(), bitmap);
BitmapDrawable d = (BitmapDrawable)((ImageView) findViewById(R.id.imageView)).getDrawable();
Bitmap bitmap2 = d.getBitmap();
Bitmap bitmap = scaleBitmapDown(bitmap2, 640);
// Convert bitmap to base64 encoded string
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.JPEG, 100, byteArrayOutputStream);
byte[] imageBytes = byteArrayOutputStream.toByteArray();
String base64encoded = Base64.encodeToString(imageBytes, Base64.NO_WRAP);
mFunctions = FirebaseFunctions.getInstance();
// Create json request to cloud vision
JsonObject request = new JsonObject();
// Add image to request
JsonObject image = new JsonObject();
image.add("content", new JsonPrimitive(base64encoded));
request.add("image", image);
//Add features to the request
JsonObject feature = new JsonObject();
feature.add("type", new JsonPrimitive("TEXT_DETECTION"));
// Alternatively, for DOCUMENT_TEXT_DETECTION:
//feature.add("type", new JsonPrimitive("DOCUMENT_TEXT_DETECTION"));
JsonArray features = new JsonArray();
features.add(feature);
request.add("features", features);
JsonObject imageContext = new JsonObject();
JsonArray languageHints = new JsonArray();
languageHints.add("ko");
imageContext.add("languageHints", languageHints);
request.add("imageContext", imageContext);
annotateImage(request.toString())
.addOnCompleteListener(new OnCompleteListener<JsonElement>() {
@Override
public void onComplete(@NonNull Task<JsonElement> task) {
if (!task.isSuccessful()) {
// Task failed with an exception
// ...
Toast.makeText(MainActivity.this, "인식 실패", Toast.LENGTH_SHORT).show();
} else {
// Task completed successfully
// ...
Toast.makeText(MainActivity.this, "인식 성공", Toast.LENGTH_SHORT).show();
}
}
});
}
private Task<JsonElement> annotateImage(String requestJson) {
return mFunctions
.getHttpsCallable("annotateImage")
.call(requestJson)
.continueWith(new Continuation<HttpsCallableResult, JsonElement>() {
@Override
public JsonElement then(@NonNull Task<HttpsCallableResult> task) {
// This continuation runs on either success or failure, but if the task
// has failed then getResult() will throw an Exception which will be
// propagated down.
return JsonParser.parseString(new Gson().toJson(task.getResult().getData()));
}
});
}
}
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<ImageView
android:id="@+id/imageView"
android:layout_width="200dp"
android:layout_height="200dp"
android:layout_marginTop="248dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.495"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
tools:src="@tools:sample/avatars" />
<Button
android:id="@+id/btn_get_image"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:text="이미지 가져오기"
app:layout_constraintEnd_toEndOf="@+id/btn_detection_image"
app:layout_constraintStart_toStartOf="@+id/btn_detection_image"
app:layout_constraintTop_toBottomOf="@+id/imageView" />
<Button
android:id="@+id/btn_detection_image"
android:layout_width="150dp"
android:layout_height="wrap_content"
android:layout_marginTop="16dp"
android:text="텍스트 인식"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/btn_get_image" />
<TextView
android:id="@+id/textView7"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="32dp"
android:text="이미지 속 텍스트 인식"
android:textStyle="bold"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="44dp"
android:orientation="horizontal"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView7">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="10dp"
android:textSize="20sp"
android:text="인식한 텍스트: "
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView7"
android:layout_marginStart="10dp" />
<TextView
android:id="@+id/text_info"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:text=""
android:textStyle="bold"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.498"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/textView7" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
[Android] Firebase로 OCR 사용해보기 (2)
package com.example.ocr; import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.appcompat.app.AppCompatActivity; import android.content.Intent; import android.database.Cursor; import android.graphics.Bitmap; import android
baehj.tistory.com
'Android' 카테고리의 다른 글
[Android] 블로그 이전 - Naver Map API 사용해보기 (2) Geocoding (1) | 2024.06.10 |
---|---|
[Android] 블로그 이전 - Naver Map API 사용해보기 (1) (0) | 2024.06.10 |
[Android] 블로그 이전 - php 이용하여 로그인/회원가입 구현 (1) | 2024.06.10 |
[Android] 블로그 이전 - Firebase 이용하여 로그인 구현 with Kotlin (0) | 2024.06.10 |
[Android] 블로그 이전 - Firebase MLKit로 OCR 사용해보기 (0) | 2024.06.10 |