Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 23.07.2013
Сообщений: 62

Сохранение картинки с камеры и ее извлечение

02.12.2019, 16:41. Показов 752. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день форумчане, нужно решить вопрос по сохранению изображения из imgview, полученного из камеры и его сохранения в sqlite, а в последующем извлечении из базы и выводу в listview

Регистрация карточки ActivityReg.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
package com.example.bandit;
 
import android.content.ContentValues;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
 
 
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.net.Uri;
import android.os.Bundle;
 
import com.google.android.material.floatingactionbutton.FloatingActionButton;
 
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.FileProvider;
import androidx.appcompat.widget.Toolbar;
 
import android.os.Environment;
import android.provider.MediaStore;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast;
 
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class ActivityReg extends AppCompatActivity {
 
    private static int TAKE_PICTURE_REQUEST = 1;
    private String mCurrentPhotoPath;
    private EditText txtName;
    private EditText txtOpis;
    private ImageView imgFace;
    private Button btnSave;
    private Uri photoURI;
 
    DatabaseHelper databaseHelper;
    SQLiteDatabase db;
    Cursor userCursor;
    SimpleCursorAdapter userAdapter;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_reg);
 
        databaseHelper = new DatabaseHelper(this);
        // создаем базу данных
        try {
            databaseHelper.updateDataBase();
        } catch (IOException ioe) {
            throw new Error("Не возможно инициализировать базу данных");
        }
 
        try {
            db = databaseHelper.getWritableDatabase();
        } catch (SQLException sqle) {
            throw sqle;
        }
 
        txtName = (EditText) findViewById(R.id.txtName);
        txtOpis = (EditText) findViewById(R.id.txtOpis);
        imgFace = (ImageView) findViewById(R.id.imgFace);
        btnSave = (Button)  findViewById(R.id.btnSave);
 
        imgFace.setVisibility(View.GONE);
 
        btnSave.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                save();
            }
        });
 
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(ActivityReg.this, BanditActivity.class);
                startActivity(intent);
            }
        });
 
        FloatingActionButton fab = findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                dispatchTakePictureIntent();
                imgFace.setVisibility(View.VISIBLE);
            }
        });
    }
 
    public void save () {
        Bitmap img = ((BitmapDrawable)imgFace.getDrawable()).getBitmap();
        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        img.compress(Bitmap.CompressFormat.PNG, 100, stream);
        byte[] bArray = stream.toByteArray();
        db = databaseHelper.getWritableDatabase();
        ContentValues cv = new ContentValues();
        cv.put(databaseHelper.COLUMN_PICTURE, bArray);
        cv.put(databaseHelper.COLUMN_NAME, txtName.getText().toString());
        cv.put(databaseHelper.COLUMN_INFO, txtOpis.getText().toString());
        try {
            db.insert(databaseHelper.TABLE, null, cv);
       } catch (Exception e) {
           e.printStackTrace();
      }
      db.close();
    }
 
 
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
 
       if (requestCode == TAKE_PICTURE_REQUEST && resultCode == RESULT_OK) {
           imgFace.setImageURI(photoURI);
       }
    }
 
    private File createImageFile() throws IOException {
        // Create an image file name
        String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
        String imageFileName = "BMP_" + timeStamp + "_";
        File storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES);
        File image = File.createTempFile(
                imageFileName,  /* prefix */
                ".bmp",         /* suffix */
                storageDir      /* directory */
        );
 
        // Save a file: path for use with ACTION_VIEW intents
        mCurrentPhotoPath = image.getAbsolutePath();
        return image;
    }
 
    private void dispatchTakePictureIntent() {
        Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
        // Ensure that there's a camera activity to handle the intent
        if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
            // Create the File where the photo should go
            File photoFile = null;
            try {
                photoFile = createImageFile();
            } catch (IOException ex) {
                // Error occurred while creating the File
                Toast.makeText(this, "Error!", Toast.LENGTH_SHORT).show();
            }
            // Continue only if the File was successfully created
            if (photoFile != null) {
                photoURI = FileProvider.getUriForFile(this,
                        "com.example.bandit.myUniquefileprovider",
                        photoFile);
                takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI);
                startActivityForResult(takePictureIntent, TAKE_PICTURE_REQUEST);
            }
        }
    }
}
Вывод значений в listview BanditActivity.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
package com.example.bandit;
 
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
 
import com.google.android.material.floatingactionbutton.FloatingActionButton;
import com.google.android.material.snackbar.Snackbar;
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
 
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.FilterQueryProvider;
import android.text.Editable;
import android.text.TextWatcher;
 
 
import java.io.IOException;
 
 
public class BanditActivity extends AppCompatActivity {
 
    private ImageView imgPhoto;
    private TextView txtName;
    private TextView txtOpis;
    private TextView header;
    private EditText txtsearch;
 
 
    ListView userList;
    DatabaseHelper databaseHelper;
    SQLiteDatabase db;
    Cursor userCursor;
    SimpleCursorAdapter userAdapter;
 
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_bandit);
 
        databaseHelper = new DatabaseHelper(this);
        // создаем базу данных
        try {
            databaseHelper.updateDataBase();
        } catch (IOException ioe) {
            throw new Error("Не возможно инициализировать базу данных");
        }
 
        try {
            db = databaseHelper.getWritableDatabase();
        } catch (SQLException sqle) {
            throw sqle;
        }
 
 
        imgPhoto = (ImageView) findViewById(R.id.imgPhoto);
        txtName = (TextView) findViewById(R.id.txtName);
        txtOpis = (TextView) findViewById(R.id.txtOpis);
        userList = (ListView) findViewById(R.id.userList);
        header = (TextView) findViewById(R.id.header);
        txtsearch = (EditText) findViewById(R.id.txtsearch);
 
 
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
 
        FloatingActionButton fab = findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(BanditActivity.this, ActivityReg.class);
                startActivity(intent);
            }
        });
    }
 
 
    @Override
    public void onResume() {
        super.onResume();
try{
        // открываем подключение
        db = databaseHelper.getWritableDatabase();
        //получаем данные из бд в виде курсора
        userCursor = db.rawQuery("select * from " + DatabaseHelper.TABLE, null);
        // определяем, какие столбцы из курсора будут выводиться в ListView
        String[] headers = new String[]{DatabaseHelper.COLUMN_NAME, DatabaseHelper.COLUMN_INFO, DatabaseHelper.COLUMN_PICTURE};
        // создаем адаптер, передаем в него курсор
        userAdapter = new SimpleCursorAdapter(this, R.layout.adapter_item,
                userCursor, headers, new int[]{R.id.txtName, R.id.txtOpis, R.id.imgPhoto}, 0);
 
    // если в текстовом поле есть текст, выполняем фильтрацию
 
 
        if (!txtsearch.getText().toString().isEmpty())
            userAdapter.getFilter().filter(txtsearch.getText().toString());
 
    // установка слушателя изменения текста
 
        txtsearch.addTextChangedListener(new TextWatcher() {
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
 
            }
 
            @Override
            public void onTextChanged(CharSequence s, int start, int count, int after) {
                userAdapter.getFilter().filter(s.toString());
            }
 
            @Override
            public void afterTextChanged(Editable s) {
                userAdapter.getFilter().filter(s.toString());
 
            }
        });
 
    // устанавливаем провайдер фильтрации
 
        userAdapter.setFilterQueryProvider(new FilterQueryProvider() {
            @Override
            public Cursor runQuery(CharSequence constraint) {
                if (constraint == null || constraint.length() == 0) {
 
                    return db.rawQuery("select * from " + DatabaseHelper.TABLE, null);
                } else {
                    return db.rawQuery("select * from " + DatabaseHelper.TABLE + " where " +
                            DatabaseHelper.COLUMN_NAME + " like ?", new String[]{"%" + constraint.toString() + "%"});
                }
            }
        });
 
        header.setText("Количество элементов в базе: " + String.valueOf(userCursor.getCount()));
        userAdapter.setViewBinder(new YourViewBinder());
        userList.setAdapter(userAdapter);
}
        catch (SQLException ex){}
    }
 
    //Подключение картинки в базу
 
        public class YourViewBinder implements SimpleCursorAdapter.ViewBinder {
            public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
 
                if (view.getId() == R.id.imgPhoto) {
                    ImageView iv = (ImageView) view;
                    //iv.setImageResource(R.drawable.kazakov);
                    try {
                        Bitmap bm = BitmapFactory.decodeStream(getAssets().open(cursor.getString(columnIndex)));
                        iv.setImageBitmap(bm);
                    } catch (IOException e) {
//                        e.printStackTrace();
                        byte[] imgByte = cursor.getBlob(4);
                        Bitmap bm = BitmapFactory.decodeByteArray(imgByte, 0, imgByte.length);
                        iv.setImageBitmap(bm);
                    }
                    return true;
                }
 
                return false;
            }
        }
 
 
 
    @Override
    public void onDestroy(){
        super.onDestroy();
        // Закрываем подключение и курсор
        db.close();
        userCursor.close();
    }
 
}
Сведения в базу данных вносятся, но при выводе, приложение рушится, при проходе строки, полученной вводом сведений, в том числе полученных из камеры

Я думаю ошибка в этом месте, но как ее исправить не имею понятия

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
    //Подключение картинки в базу
 
        public class YourViewBinder implements SimpleCursorAdapter.ViewBinder {
            public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
 
                if (view.getId() == R.id.imgPhoto) {
                    ImageView iv = (ImageView) view;
                    //iv.setImageResource(R.drawable.kazakov);
                    try {
                        Bitmap bm = BitmapFactory.decodeStream(getAssets().open(cursor.getString(columnIndex)));
                        iv.setImageBitmap(bm);
                    } catch (IOException e) {
//                        e.printStackTrace();
                        byte[] imgByte = cursor.getBlob(4);
                        Bitmap bm = BitmapFactory.decodeByteArray(imgByte, 0, imgByte.length);
                        iv.setImageBitmap(bm);
                    }
                    return true;
                }
 
                return false;
            }
        }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.12.2019, 16:41
Ответы с готовыми решениями:

Извлечение картинки из БД
Здавствуйте. Реализовал метод по извлечению картинки из БД. Он вызывается при нажатии на кнопку. После нажатия выскакивает такая ошибка:...

Извлечение картинки из БД
Здравтсвуйте, есть код, с помощью которого сохраняю картинки для каждого юзера в БД, теперь нужно как-то эти картинки достать и вставить в...

Поиск и сохранение изображений от Google.Картинки и Яндекс.Картинки
Мир вам, братья по увлечению! Я на вашем форуме впервые, давно хотел влиться в какое-нибудь сообщество веб-девелоперов, т.к. сам уже...

3
0 / 0 / 0
Регистрация: 23.07.2013
Сообщений: 62
04.12.2019, 11:56  [ТС]
Исправил ошибку, однако изображение загружается если снимок получен был с передней камеры, при получении снимка с задней камеры, возникает ошибка следующая

Window is full: requested allocation 2939254 bytes, free space 2090203 bytes, window size 2097152 bytes

Как исправить ошибку переполнения окна курсора?

Исправленные варианты:

ActivityReg.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
package com.example.bandit;
 
import android.content.ContentValues;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
 
 
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.net.Uri;
import android.os.Bundle;
 
import com.google.android.material.floatingactionbutton.FloatingActionButton;
 
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.FileProvider;
import androidx.appcompat.widget.Toolbar;
 
import android.os.Environment;
import android.provider.MediaStore;
import android.util.Base64;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast;
 
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class ActivityReg extends AppCompatActivity {
 
    private static int TAKE_PICTURE_REQUEST = 1;
    private String mCurrentPhotoPath;
    private EditText txtName;
    private EditText txtOpis;
    private ImageView imgFace;
    private Button btnSave;
    private Uri photoURI;
 
    DatabaseHelper databaseHelper;
    SQLiteDatabase db;
    Cursor userCursor;
    SimpleCursorAdapter userAdapter;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_reg);
 
        databaseHelper = new DatabaseHelper(this);
        // создаем базу данных
        try {
            databaseHelper.updateDataBase();
        } catch (IOException ioe) {
            throw new Error("Не возможно инициализировать базу данных");
        }
 
        try {
            db = databaseHelper.getWritableDatabase();
        } catch (SQLException sqle) {
            throw sqle;
        }
 
        txtName = (EditText) findViewById(R.id.txtName);
        txtOpis = (EditText) findViewById(R.id.txtOpis);
        imgFace = (ImageView) findViewById(R.id.imgFace);
        btnSave = (Button)  findViewById(R.id.btnSave);
 
        imgFace.setVisibility(View.GONE);
 
        btnSave.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                save();
            }
        });
 
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(ActivityReg.this, BanditActivity.class);
                startActivity(intent);
            }
        });
 
        FloatingActionButton fab = findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                dispatchTakePictureIntent();
                imgFace.setVisibility(View.VISIBLE);
            }
        });
    }
 
    public void save () {
        Bitmap img = ((BitmapDrawable)imgFace.getDrawable()).getBitmap();
        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        img.compress(Bitmap.CompressFormat.JPEG, 100, stream);
        byte[] bArray = stream.toByteArray();
        String base64Image = Base64.encodeToString(bArray, Base64.DEFAULT);
        db = databaseHelper.getWritableDatabase();
        ContentValues cv = new ContentValues();
        cv.put(databaseHelper.COLUMN_PICTURE, base64Image);
        cv.put(databaseHelper.COLUMN_NAME, txtName.getText().toString());
        cv.put(databaseHelper.COLUMN_INFO, txtOpis.getText().toString());
        try {
            db.insert(databaseHelper.TABLE, null, cv);
       } catch (Exception e) {
           e.printStackTrace();
      }
      db.close();
    }
 
 
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
 
       if (requestCode == TAKE_PICTURE_REQUEST && resultCode == RESULT_OK) {
           imgFace.setImageURI(photoURI);
       }
    }
 
    private File createImageFile() throws IOException {
        // Create an image file name
        String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
        String imageFileName = "BMP_" + timeStamp + "_";
        File storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES);
        File image = File.createTempFile(
                imageFileName,  /* prefix */
                ".bmp",         /* suffix */
                storageDir      /* directory */
        );
 
        // Save a file: path for use with ACTION_VIEW intents
        mCurrentPhotoPath = image.getAbsolutePath();
        return image;
    }
 
    private void dispatchTakePictureIntent() {
        Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
        // Ensure that there's a camera activity to handle the intent
        if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
            // Create the File where the photo should go
            File photoFile = null;
            try {
                photoFile = createImageFile();
            } catch (IOException ex) {
                // Error occurred while creating the File
                Toast.makeText(this, "Error!", Toast.LENGTH_SHORT).show();
            }
            // Continue only if the File was successfully created
            if (photoFile != null) {
                photoURI = FileProvider.getUriForFile(this,
                        "com.example.bandit.myUniquefileprovider",
                        photoFile);
                takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI);
                startActivityForResult(takePictureIntent, TAKE_PICTURE_REQUEST);
            }
        }
    }
}
BanditActivity.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
package com.example.bandit;
 
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
 
import com.google.android.material.floatingactionbutton.FloatingActionButton;
import com.google.android.material.snackbar.Snackbar;
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
 
import android.util.Base64;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.FilterQueryProvider;
import android.text.Editable;
import android.text.TextWatcher;
 
 
import java.io.IOException;
 
 
public class BanditActivity extends AppCompatActivity {
 
    private ImageView imgPhoto;
    private TextView txtName;
    private TextView txtOpis;
    private TextView header;
    private EditText txtsearch;
 
 
    ListView userList;
    DatabaseHelper databaseHelper;
    SQLiteDatabase db;
    Cursor userCursor;
    SimpleCursorAdapter userAdapter;
 
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_bandit);
 
        databaseHelper = new DatabaseHelper(this);
        // создаем базу данных
        try {
            databaseHelper.updateDataBase();
        } catch (IOException ioe) {
            throw new Error("Не возможно инициализировать базу данных");
        }
 
        try {
            db = databaseHelper.getWritableDatabase();
        } catch (SQLException sqle) {
            throw sqle;
        }
 
 
        imgPhoto = (ImageView) findViewById(R.id.imgPhoto);
        txtName = (TextView) findViewById(R.id.txtName);
        txtOpis = (TextView) findViewById(R.id.txtOpis);
        userList = (ListView) findViewById(R.id.userList);
        header = (TextView) findViewById(R.id.header);
        txtsearch = (EditText) findViewById(R.id.txtsearch);
 
 
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
 
        FloatingActionButton fab = findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(BanditActivity.this, ActivityReg.class);
                startActivity(intent);
            }
        });
    }
 
 
    @Override
    public void onResume() {
        super.onResume();
try{
        // открываем подключение
        db = databaseHelper.getWritableDatabase();
        //получаем данные из бд в виде курсора
        userCursor = db.rawQuery("select * from " + DatabaseHelper.TABLE, null);
        // определяем, какие столбцы из курсора будут выводиться в ListView
        String[] headers = new String[]{DatabaseHelper.COLUMN_NAME, DatabaseHelper.COLUMN_INFO, DatabaseHelper.COLUMN_PICTURE};
        // создаем адаптер, передаем в него курсор
        userAdapter = new SimpleCursorAdapter(this, R.layout.adapter_item,
                userCursor, headers, new int[]{R.id.txtName, R.id.txtOpis, R.id.imgPhoto}, 0);
 
    // если в текстовом поле есть текст, выполняем фильтрацию
 
 
        if (!txtsearch.getText().toString().isEmpty())
            userAdapter.getFilter().filter(txtsearch.getText().toString());
 
    // установка слушателя изменения текста
 
        txtsearch.addTextChangedListener(new TextWatcher() {
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
 
            }
 
            @Override
            public void onTextChanged(CharSequence s, int start, int count, int after) {
                userAdapter.getFilter().filter(s.toString());
            }
 
            @Override
            public void afterTextChanged(Editable s) {
                userAdapter.getFilter().filter(s.toString());
 
            }
        });
 
    // устанавливаем провайдер фильтрации
 
        userAdapter.setFilterQueryProvider(new FilterQueryProvider() {
            @Override
            public Cursor runQuery(CharSequence constraint) {
                if (constraint == null || constraint.length() == 0) {
 
                    return db.rawQuery("select * from " + DatabaseHelper.TABLE, null);
                } else {
                    return db.rawQuery("select * from " + DatabaseHelper.TABLE + " where " +
                            DatabaseHelper.COLUMN_NAME + " like ?", new String[]{"%" + constraint.toString() + "%"});
                }
            }
        });
 
        header.setText("Количество элементов в базе: " + String.valueOf(userCursor.getCount()));
        userAdapter.setViewBinder(new YourViewBinder());
        userList.setAdapter(userAdapter);
}
        catch (SQLException ex){}
    }
 
    //Подключение картинки в базу
 
        public class YourViewBinder implements SimpleCursorAdapter.ViewBinder {
            public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
 
                if (view.getId() == R.id.imgPhoto) {
                    ImageView iv = (ImageView) view;
                    //iv.setImageResource(R.drawable.kazakov);
                    try {
                        Bitmap bm = BitmapFactory.decodeStream(getAssets().open(cursor.getString(columnIndex)));
                        iv.setImageBitmap(bm);
                    } catch (IOException e) {
//                        e.printStackTrace();
                        byte[] imgByte = Base64.decode(cursor.getBlob(3), Base64.DEFAULT);
                        BitmapFactory.Options opt = new BitmapFactory.Options();
                        Bitmap bn = BitmapFactory.decodeByteArray(imgByte, 0, imgByte.length, opt);
                        Bitmap bitmapMini = Bitmap.createScaledBitmap(bn, 245, 311, false);
                        iv.setImageBitmap(bitmapMini);
                    }
                    return true;
                }
 
                return false;
            }
        }
 
 
 
    @Override
    public void onDestroy(){
        super.onDestroy();
        // Закрываем подключение и курсор
        db.close();
        userCursor.close();
    }
 
}
0
1570 / 1168 / 426
Регистрация: 08.05.2012
Сообщений: 5,219
04.12.2019, 12:16
Никто не записывает картинки в базу данных.
0
0 / 0 / 0
Регистрация: 23.07.2013
Сообщений: 62
04.12.2019, 12:36  [ТС]
Исправил, достаточно было уменьшить размер с камеры перед записью в базу и ее кодировании в Base64

Если кому нужно для работы вот полные коды ACTIVITY

ActivityReg.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
package com.example.bandit;
 
import android.content.ContentValues;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
 
 
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.net.Uri;
import android.os.Bundle;
 
import com.google.android.material.floatingactionbutton.FloatingActionButton;
 
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.FileProvider;
import androidx.appcompat.widget.Toolbar;
 
import android.os.Environment;
import android.provider.MediaStore;
import android.util.Base64;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.SimpleCursorAdapter;
import android.widget.Toast;
 
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class ActivityReg extends AppCompatActivity {
 
    private static int TAKE_PICTURE_REQUEST = 1;
    private String mCurrentPhotoPath;
    private EditText txtName;
    private EditText txtOpis;
    private ImageView imgFace;
    private Button btnSave;
    private Uri photoURI;
 
    DatabaseHelper databaseHelper;
    SQLiteDatabase db;
    Cursor userCursor;
    SimpleCursorAdapter userAdapter;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_reg);
 
        databaseHelper = new DatabaseHelper(this);
        // создаем базу данных
        try {
            databaseHelper.updateDataBase();
        } catch (IOException ioe) {
            throw new Error("Не возможно инициализировать базу данных");
        }
 
        try {
            db = databaseHelper.getWritableDatabase();
        } catch (SQLException sqle) {
            throw sqle;
        }
 
        txtName = (EditText) findViewById(R.id.txtName);
        txtOpis = (EditText) findViewById(R.id.txtOpis);
        imgFace = (ImageView) findViewById(R.id.imgFace);
        btnSave = (Button)  findViewById(R.id.btnSave);
 
        imgFace.setVisibility(View.GONE);
 
        btnSave.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                save();
            }
        });
 
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(ActivityReg.this, BanditActivity.class);
                startActivity(intent);
            }
        });
 
        FloatingActionButton fab = findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                dispatchTakePictureIntent();
                imgFace.setVisibility(View.VISIBLE);
            }
        });
    }
 
    public void save () {
        Bitmap img = ((BitmapDrawable)imgFace.getDrawable()).getBitmap();
        Bitmap bitmapMini = Bitmap.createScaledBitmap(img, 245, 311, false);
        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        bitmapMini.compress(Bitmap.CompressFormat.JPEG, 100, stream);
        byte[] bArray = stream.toByteArray();
        String base64Image = Base64.encodeToString(bArray, Base64.DEFAULT);
        db = databaseHelper.getWritableDatabase();
        ContentValues cv = new ContentValues();
        cv.put(databaseHelper.COLUMN_PICTURE, base64Image);
        cv.put(databaseHelper.COLUMN_NAME, txtName.getText().toString());
        cv.put(databaseHelper.COLUMN_INFO, txtOpis.getText().toString());
        try {
            db.insert(databaseHelper.TABLE, null, cv);
       } catch (Exception e) {
           e.printStackTrace();
      }
      db.close();
    }
 
 
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
 
       if (requestCode == TAKE_PICTURE_REQUEST && resultCode == RESULT_OK) {
           imgFace.setImageURI(photoURI);
       }
    }
 
    private File createImageFile() throws IOException {
        // Create an image file name
        String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
        String imageFileName = "BMP_" + timeStamp + "_";
        File storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES);
        File image = File.createTempFile(
                imageFileName,  /* prefix */
                ".bmp",         /* suffix */
                storageDir      /* directory */
        );
 
        // Save a file: path for use with ACTION_VIEW intents
        mCurrentPhotoPath = image.getAbsolutePath();
        return image;
    }
 
    private void dispatchTakePictureIntent() {
        Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
        // Ensure that there's a camera activity to handle the intent
        if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
            // Create the File where the photo should go
            File photoFile = null;
            try {
                photoFile = createImageFile();
            } catch (IOException ex) {
                // Error occurred while creating the File
                Toast.makeText(this, "Error!", Toast.LENGTH_SHORT).show();
            }
            // Continue only if the File was successfully created
            if (photoFile != null) {
                photoURI = FileProvider.getUriForFile(this,
                        "com.example.bandit.myUniquefileprovider",
                        photoFile);
                takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI);
                startActivityForResult(takePictureIntent, TAKE_PICTURE_REQUEST);
            }
        }
    }
}
BanditActivity.java

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
package com.example.bandit;
 
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.Bundle;
 
import com.google.android.material.floatingactionbutton.FloatingActionButton;
import com.google.android.material.snackbar.Snackbar;
 
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
 
import android.util.Base64;
import android.view.View;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.FilterQueryProvider;
import android.text.Editable;
import android.text.TextWatcher;
 
 
import java.io.IOException;
 
 
public class BanditActivity extends AppCompatActivity {
 
    private ImageView imgPhoto;
    private TextView txtName;
    private TextView txtOpis;
    private TextView header;
    private EditText txtsearch;
 
 
    ListView userList;
    DatabaseHelper databaseHelper;
    SQLiteDatabase db;
    Cursor userCursor;
    SimpleCursorAdapter userAdapter;
 
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_bandit);
 
        databaseHelper = new DatabaseHelper(this);
        // создаем базу данных
        try {
            databaseHelper.updateDataBase();
        } catch (IOException ioe) {
            throw new Error("Не возможно инициализировать базу данных");
        }
 
        try {
            db = databaseHelper.getWritableDatabase();
        } catch (SQLException sqle) {
            throw sqle;
        }
 
 
        imgPhoto = (ImageView) findViewById(R.id.imgPhoto);
        txtName = (TextView) findViewById(R.id.txtName);
        txtOpis = (TextView) findViewById(R.id.txtOpis);
        userList = (ListView) findViewById(R.id.userList);
        header = (TextView) findViewById(R.id.header);
        txtsearch = (EditText) findViewById(R.id.txtsearch);
 
 
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
 
        FloatingActionButton fab = findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Intent intent = new Intent(BanditActivity.this, ActivityReg.class);
                startActivity(intent);
            }
        });
    }
 
 
    @Override
    public void onResume() {
        super.onResume();
try{
        // открываем подключение
        db = databaseHelper.getWritableDatabase();
        //получаем данные из бд в виде курсора
        userCursor = db.rawQuery("select * from " + DatabaseHelper.TABLE, null);
        // определяем, какие столбцы из курсора будут выводиться в ListView
        String[] headers = new String[]{DatabaseHelper.COLUMN_NAME, DatabaseHelper.COLUMN_INFO, DatabaseHelper.COLUMN_PICTURE};
        // создаем адаптер, передаем в него курсор
        userAdapter = new SimpleCursorAdapter(this, R.layout.adapter_item,
                userCursor, headers, new int[]{R.id.txtName, R.id.txtOpis, R.id.imgPhoto}, 0);
 
    // если в текстовом поле есть текст, выполняем фильтрацию
 
 
        if (!txtsearch.getText().toString().isEmpty())
            userAdapter.getFilter().filter(txtsearch.getText().toString());
 
    // установка слушателя изменения текста
 
        txtsearch.addTextChangedListener(new TextWatcher() {
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
 
            }
 
            @Override
            public void onTextChanged(CharSequence s, int start, int count, int after) {
                userAdapter.getFilter().filter(s.toString());
            }
 
            @Override
            public void afterTextChanged(Editable s) {
                userAdapter.getFilter().filter(s.toString());
 
            }
        });
 
    // устанавливаем провайдер фильтрации
 
        userAdapter.setFilterQueryProvider(new FilterQueryProvider() {
            @Override
            public Cursor runQuery(CharSequence constraint) {
                if (constraint == null || constraint.length() == 0) {
 
                    return db.rawQuery("select * from " + DatabaseHelper.TABLE, null);
                } else {
                    return db.rawQuery("select * from " + DatabaseHelper.TABLE + " where " +
                            DatabaseHelper.COLUMN_NAME + " like ?", new String[]{"%" + constraint.toString() + "%"});
                }
            }
        });
 
        header.setText("Количество элементов в базе: " + String.valueOf(userCursor.getCount()));
        userAdapter.setViewBinder(new YourViewBinder());
        userList.setAdapter(userAdapter);
}
        catch (SQLException ex){}
    }
 
    //Подключение картинки в базу
 
        public class YourViewBinder implements SimpleCursorAdapter.ViewBinder {
            public boolean setViewValue(View view, Cursor cursor, int columnIndex) {
 
                if (view.getId() == R.id.imgPhoto) {
                    ImageView iv = (ImageView) view;
                    //iv.setImageResource(R.drawable.kazakov);
                    try {
                        Bitmap bm = BitmapFactory.decodeStream(getAssets().open(cursor.getString(columnIndex)));
                        iv.setImageBitmap(bm);
                    } catch (IOException e) {
//                        e.printStackTrace();
                        byte[] imgByte = Base64.decode(cursor.getBlob(3), Base64.DEFAULT);
                        BitmapFactory.Options opt = new BitmapFactory.Options();
                        Bitmap bn = BitmapFactory.decodeByteArray(imgByte, 0, imgByte.length, opt);
                        Bitmap bitmapMini = Bitmap.createScaledBitmap(bn, 245, 311, false);
                        iv.setImageBitmap(bitmapMini);
                    }
                    return true;
                }
 
                return false;
            }
        }
 
 
 
    @Override
    public void onDestroy(){
        super.onDestroy();
        // Закрываем подключение и курсор
        db.close();
        userCursor.close();
    }
 
}
Всем спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.12.2019, 12:36
Помогаю со студенческими работами здесь

Emoji - сохранение и извлечение
Всем привет. Столкнулся с проблемой хранения и извлечения emoji. Проблему сохранения решил. Потребовалось преобразовать кодировку таблицы...

Извлечение картинки из бд в TImage
Есть у меня база данных, в ней есть таблица с товарами и у каждого товара есть картинка, я хочу сделать чтобы на форме динамически...

Извлечение гиперссылки из картинки
Здравствуйте, специалистам и всем помощникам ;) Я не специалист по написанию Макросов, но решил спросить здесь на форуме, может думаю...

Извлечение и сохранение вложений в почте
Помогите с извлечением вложений в маил почту, сами сообщения получаю с помощью POP3, на гитхабе нашел инфу про библиотеку MailKit но из...

Динамическое сохранение и извлечение параметров
Всем привет. При разработке в VS можно пройти Проект - Свойства - Параметры и там задаются параметры для работы программы, чтобы не писать...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru