如何在Android中以Base64编码和解码图像?
在这里,我们将应用图像的“编码-解码”。通过制作这个应用程序,我们将能够了解如何使用 Base64 对图像进行编码。我们还将在按钮的帮助下解码我们的图像。
先决条件:
在继续使用此应用程序之前,您应该了解Java的 Base64。如果您不知道,请使用Java的基本类型 Base64 编码和解码。
我们将在本文中构建什么?
在这个应用程序中,我们将使用两个按钮编码和解码来执行各自的操作。此外,我们将使用 textView 显示编码文本,最后使用 imageView 显示解码图像。请注意,我们将使用Java语言实现此应用程序。下面给出了一个示例视频,以了解我们将在本文中做什么。
分步实施
第 1 步:创建一个新项目
- 打开一个新项目。
- 我们将使用Java语言处理 Empty Activity。保持所有其他选项不变。
- 您可以在方便时更改项目的名称。
- 将有两个名为activity_main.xml 和 MainActivity 的默认文件。Java。
如果您不知道如何在 Android Studio 中创建新项目,那么您可以参考如何在 Android Studio 中创建/启动新项目?
第 2 步:导航到 app > Manifests > AndroidManifest.xml 文件并向其添加以下权限
步骤 3:使用 activity_main.xml 文件
在这里,我们将设计应用程序的用户界面。我们将在各自的作品中使用以下组件:
- TextView – 显示编码文本
- ImageView – 显示解码后的图像。
- 按钮 – 单击时对图像进行编码或解码。
导航到app > res > layout > activity_main.xml并将以下代码添加到该文件中。
XML
Java
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.Manifest;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
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 java.io.ByteArrayOutputStream;
import java.io.IOException;
public class MainActivity extends AppCompatActivity {
// Initialize variable
Button btnEncode,btnDecode;
TextView textView;
ImageView imageView;
String sImage;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btnEncode=findViewById(R.id.btn_encode);
btnDecode=findViewById(R.id.btn_decode);
textView=findViewById(R.id.textView);
imageView= findViewById(R.id.imageView);
// Code for Encode button
btnEncode.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// check condition
if (ContextCompat.checkSelfPermission(MainActivity.this,
Manifest.permission.READ_EXTERNAL_STORAGE)!= PackageManager.PERMISSION_GRANTED)
{
// when permission is nor granted
// request permission
ActivityCompat.requestPermissions(MainActivity.this
, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},100);
}
else
{
// when permission
// is granted
// create method
selectImage();
}
}
});
// Code for Decode button
btnDecode.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// decode base64 string
byte[] bytes=Base64.decode(sImage,Base64.DEFAULT);
// Initialize bitmap
Bitmap bitmap= BitmapFactory.decodeByteArray(bytes,0,bytes.length);
// set bitmap on imageView
imageView.setImageBitmap(bitmap);
}
});
}
private void selectImage() {
// clear previous data
textView.setText("");
imageView.setImageBitmap(null);
// Initialize intent
Intent intent=new Intent(Intent.ACTION_PICK);
// set type
intent.setType("image/*");
// start activity result
startActivityForResult(Intent.createChooser(intent,"Select Image"),100);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
// check condition
if (requestCode==100 && grantResults[0]==PackageManager.PERMISSION_GRANTED)
{
// when permission
// is granted
// call method
selectImage();
}
else
{
// when permission is denied
Toast.makeText(this, "Permission Denied", Toast.LENGTH_SHORT).show();
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// check condition
if (requestCode==100 && resultCode==RESULT_OK && data!=null)
{
// when result is ok
// initialize uri
Uri uri=data.getData();
// Initialize bitmap
try {
Bitmap bitmap= MediaStore.Images.Media.getBitmap(getContentResolver(),uri);
// initialize byte stream
ByteArrayOutputStream stream=new ByteArrayOutputStream();
// compress Bitmap
bitmap.compress(Bitmap.CompressFormat.JPEG,100,stream);
// Initialize byte array
byte[] bytes=stream.toByteArray();
// get base64 encoded string
sImage= Base64.encodeToString(bytes,Base64.DEFAULT);
// set encoded text on textview
textView.setText(sImage);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
执行上述代码后, activity_main.xml文件的设计是这样的。
第 4 步:使用 MainActivity。 Java文件
这里我们为编码和解码按钮的 onClickListeners 编写代码,以便它们可以执行它们的函数。在MainActvity 中使用以下代码。 Java文件。
Java
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.Manifest;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
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 java.io.ByteArrayOutputStream;
import java.io.IOException;
public class MainActivity extends AppCompatActivity {
// Initialize variable
Button btnEncode,btnDecode;
TextView textView;
ImageView imageView;
String sImage;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btnEncode=findViewById(R.id.btn_encode);
btnDecode=findViewById(R.id.btn_decode);
textView=findViewById(R.id.textView);
imageView= findViewById(R.id.imageView);
// Code for Encode button
btnEncode.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// check condition
if (ContextCompat.checkSelfPermission(MainActivity.this,
Manifest.permission.READ_EXTERNAL_STORAGE)!= PackageManager.PERMISSION_GRANTED)
{
// when permission is nor granted
// request permission
ActivityCompat.requestPermissions(MainActivity.this
, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},100);
}
else
{
// when permission
// is granted
// create method
selectImage();
}
}
});
// Code for Decode button
btnDecode.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// decode base64 string
byte[] bytes=Base64.decode(sImage,Base64.DEFAULT);
// Initialize bitmap
Bitmap bitmap= BitmapFactory.decodeByteArray(bytes,0,bytes.length);
// set bitmap on imageView
imageView.setImageBitmap(bitmap);
}
});
}
private void selectImage() {
// clear previous data
textView.setText("");
imageView.setImageBitmap(null);
// Initialize intent
Intent intent=new Intent(Intent.ACTION_PICK);
// set type
intent.setType("image/*");
// start activity result
startActivityForResult(Intent.createChooser(intent,"Select Image"),100);
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
// check condition
if (requestCode==100 && grantResults[0]==PackageManager.PERMISSION_GRANTED)
{
// when permission
// is granted
// call method
selectImage();
}
else
{
// when permission is denied
Toast.makeText(this, "Permission Denied", Toast.LENGTH_SHORT).show();
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// check condition
if (requestCode==100 && resultCode==RESULT_OK && data!=null)
{
// when result is ok
// initialize uri
Uri uri=data.getData();
// Initialize bitmap
try {
Bitmap bitmap= MediaStore.Images.Media.getBitmap(getContentResolver(),uri);
// initialize byte stream
ByteArrayOutputStream stream=new ByteArrayOutputStream();
// compress Bitmap
bitmap.compress(Bitmap.CompressFormat.JPEG,100,stream);
// Initialize byte array
byte[] bytes=stream.toByteArray();
// get base64 encoded string
sImage= Base64.encodeToString(bytes,Base64.DEFAULT);
// set encoded text on textview
textView.setText(sImage);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
输出: