Форум программистов, компьютерный форум CyberForum.ru

Программирование Android

Войти
Регистрация
Восстановить пароль
 
vitas199405
0 / 0 / 0
Регистрация: 04.03.2013
Сообщений: 36
#1

Дополнительный функционал paint (загрузка изображения) - Программирование Android

10.01.2015, 23:33. Просмотров 382. Ответов 2
Метки нет (Все метки)

Имеется код программы.
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
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Calendar;
 
import android.annotation.SuppressLint;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.Bitmap.CompressFormat;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.DashPathEffect;
import android.graphics.DiscretePathEffect;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PorterDuff.Mode;
import android.graphics.PorterDuffXfermode;
import android.net.Uri;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.SeekBar;
import android.widget.TextView;
import android.widget.Toast;
 
public class PaintActivity extends Activity implements ColorPickerDialog.OnColorChangedListener
{ 
    private Paint mPaint;
    private DashPathEffect mDashPathEffect;
    private DiscretePathEffect mDiscretePathEffect;
    
    
    @Override 
    protected void onCreate(Bundle savedInstanceState) 
    {
        super.onCreate(savedInstanceState);
        setContentView(new DrawView(this));
        mPaint = new Paint();
        mPaint.setAntiAlias(true);
        mPaint.setDither(true);
        mPaint.setColor(Color.BLACK);  
        mPaint.setStyle(Paint.Style.STROKE);
        mPaint.setStrokeJoin(Paint.Join.ROUND);
        mPaint.setStrokeCap(Paint.Cap.ROUND);
        mPaint.setStrokeWidth(1);  //толщина линии
 
} 
 
    @SuppressLint("ClickableViewAccessibility") public class DrawView extends View 
    {
        private Bitmap mBitmap;
        private Canvas mCanvas;
        private Path mPath;
        private Paint mBitmapPaint;
        
        public DrawView(Context c) 
        {
            super(c);
            mPath = new Path();
            setFocusable(true);
            setFocusableInTouchMode(true);
            float[] intervals = new float[] { 60.0f, 10.0f, 5.0f, 10.5f };
            float phase = 0;
            mDashPathEffect = new DashPathEffect(intervals, phase); //точка-тире
            mDiscretePathEffect = new DiscretePathEffect(10, 5);  //ломаная прямая линия
        } 
 
    @Override 
    protected void onSizeChanged(int w, int h, int oldw, int oldh) 
    {
        super.onSizeChanged(w, h, oldw, oldh);
        mBitmap = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888);
        mCanvas = new Canvas(mBitmap);
    } 
    
    @Override 
    protected void onDraw(Canvas canvas) 
    {
        canvas.drawColor(Color.WHITE);  //фон canvas белый
 
        canvas.drawBitmap(mBitmap, 0, 0, mBitmapPaint);
 
        canvas.drawPath(mPath, mPaint);
    } 
 
    private float mX, mY;
    private static final float TOUCH_TOLERANCE = 4; //погрешность касания
 
    private void touch_start(float x, float y) 
    {
        mPath.reset();  //очищает mPath
        mPath.moveTo(x, y);  //движение объекта mPath в указанную точку, с которой пойдёт новая линия
        mX = x;
        mY = y;
    } 
 
    private void touch_move(float x, float y) 
    {
        float dx = Math.abs(x - mX);  //вычисляется дистанция между точками X
        float dy = Math.abs(y - mY); //вычисляется дистанция между точками Y
        if (dx >= TOUCH_TOLERANCE || dy >= TOUCH_TOLERANCE) 
        {
            mPath.quadTo(mX, mY, (x + mX)/2, (y + mY)/2); //
            mX = x;
            mY = y;
            
        } 
    } 
    
    private void touch_up() 
    { 
        mPath.lineTo(mX, mY);   //проводит линию на нашем экране
        
        mCanvas.drawPath(mPath, mPaint); //рисование контура линии
        
        mPath.reset(); //очищает mPath
    } 
 
    @Override 
    public boolean onTouchEvent(MotionEvent event) 
    {
        float x = event.getX();     //координаты рисования линий
        float y = event.getY();
        switch (event.getAction()) 
        {
        case MotionEvent.ACTION_DOWN: //палец опущен к экрану
            touch_start(x, y);
            invalidate();
            break;  
        case MotionEvent.ACTION_MOVE:  //движение пальца по экрану
            touch_move(x, y);
            invalidate();
            break; 
        case MotionEvent.ACTION_UP:  //палец поднят с экрана
            touch_up(); 
            invalidate();
            break; 
        }
        return true; 
    } 
   } 
 
    public void colorChanged(int color) //смена цвета происходит при нажатии на кнопку 
    {                                   //выбора в ColorPickerDialog
        mPaint.setColor(color);
    }
    
    @Override
    public boolean onCreateOptionsMenu(Menu menu) 
    {
        getMenuInflater().inflate(R.menu.menu, menu); //добавление элементов меню из файла menu.xml
        return true;
    }
 
    @Override
    public boolean onOptionsItemSelected(MenuItem item) 
    {
        
        switch (item.getItemId()) //обработка нажатия на разные элементы меню 
        {
        case R.id.Color_Draw:
            new ColorPickerDialog(this, this, mPaint.getColor()).show(); //вызов диалога выбора цвета
            return true;
        case R.id.Size:
            LayoutInflater inflater_size = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            View layout_size = inflater_size.inflate(R.layout.size,(ViewGroup) findViewById(R.id.root));
            AlertDialog.Builder builder_size = new AlertDialog.Builder(this).setView(layout_size);
            final AlertDialog alertDialog_size = builder_size.create();
            alertDialog_size.show();
            SeekBar sb = (SeekBar) layout_size.findViewById(R.id.seekBar_size);
            sb.setProgress(1);
            final Button done = (Button) layout_size.findViewById(R.id.select_size);
            final TextView txt = (TextView) layout_size.findViewById(R.id.size_value);
            txt.setText("Размер по умолчанию: 1");
            sb.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() 
            {
                public void onProgressChanged(SeekBar seekBar, final int progress, boolean fromUser) 
                {
                    txt.setText("Вы выбрали размер: " + progress);
                    mPaint.setStrokeWidth(progress);
                    done.setOnClickListener(new OnClickListener() 
                    {
                        public void onClick(View v) 
                        {
                            if (progress == 0) 
                            {
                                Toast.makeText(getApplicationContext(),"Выберите размер не меньше 1",
                                        Toast.LENGTH_LONG).show();
                            } 
                            else 
                            {
                                alertDialog_size.dismiss(); //закрытие диалога
                            }
                        }
                    });
                }
                public void onStartTrackingTouch(SeekBar seekBar) 
                {
 
                }
                public void onStopTrackingTouch(SeekBar seekBar) 
                {
 
                }
            });
            return true;
        case R.id.Save:
            takeScreenshot(true);
            break;
        case R.id.DashPathEffect:
            mPaint.setPathEffect(mDashPathEffect);
            mPaint.setXfermode(null);
            return true;
        case R.id.DiscretePathEffect:
            mPaint.setPathEffect(mDiscretePathEffect);
            mPaint.setXfermode(null);
            return true;
        case R.id.Pen:
            mPaint.setPathEffect(null);
            mPaint.setMaskFilter(null);
            mPaint.setXfermode(null);
            return true;
        case R.id.Eraser:
            mPaint.setMaskFilter(null);
            mPaint.setPathEffect(null);
            mPaint.setXfermode(new PorterDuffXfermode(Mode.CLEAR));
            return true;
        case R.id.Clear:
            setContentView(new DrawView(this));
            Toast.makeText(getApplicationContext(), "Чисто", Toast.LENGTH_LONG).show();
            return true;
        case R.id.Load:
            
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
 
    private File takeScreenshot(boolean showToast) //сохранение картики,которую рисуем в приложении
    {
        View v = getWindow().getDecorView();
        v.setDrawingCacheEnabled(true);
        Bitmap cachedBitmap = v.getDrawingCache();
        Bitmap copyBitmap = cachedBitmap.copy(Bitmap.Config.RGB_565, true);
        FileOutputStream output = null;
        File file = null;
        try 
        {
            File path = Places.getScreenshotFolder();
            Calendar cal = Calendar.getInstance();
            file = new File(path,
            cal.get(Calendar.YEAR) + "_" + (1 + cal.get(Calendar.MONTH)) + "_"
                    + cal.get(Calendar.DAY_OF_MONTH) + "_"
                    + cal.get(Calendar.HOUR_OF_DAY) + "_"
                    + cal.get(Calendar.MINUTE) + "_" + cal.get(Calendar.SECOND)
                    + ".png");
            output = new FileOutputStream(file);
            copyBitmap.compress(CompressFormat.PNG, 100, output);
        } 
        catch (FileNotFoundException e) 
        {
            file = null;
            e.printStackTrace();
        } 
        finally 
        {
            if (output != null) 
            {
                try 
                {
                    output.close();
                } 
                catch (IOException e) 
                {
                    e.printStackTrace();
                }
            }
        }
        if (file != null) 
        {
            if (showToast)
                Toast.makeText(getApplicationContext(),"Сохранён: " + file.getAbsolutePath(),Toast.LENGTH_LONG).show(); 
            Intent requestScan = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE);
            requestScan.setData(Uri.fromFile(file));
            sendBroadcast(requestScan);
            return file;
        } 
        else 
        {
            return null;
        }
    }
}
В месте
Java
1
 case R.id.Load:
нужна загрузка изображений из галереи для того чтобы можно было на них рисовать. (Без использования xml, т.к. вся работа заключается именно в этом файле).
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.01.2015, 23:33
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Дополнительный функционал paint (загрузка изображения) (Программирование Android):

Загрузка изображения - Программирование Android
Привет всем, народ помогите пожалуйста, нужно загрузить изображения из произвольного место на устройстве, как это можно сделать? может кто...

Загрузка изображения - Программирование Android
Здравствуйте уважаемые форумчане, столкнулся с такой бедой, дело в том, что на сервере лежит изображение в формате blob, написал когда для...

Загрузка изображения - Программирование Android
сейчас загружаю так BitmapFactory.decodeResource(context.getResources(), R.drawable.angle_ld) и прорисовываю так ...

Загрузка изображения jpg.to - Программирование Android
Есть такой сервис — jpg.to. Про ссылке любое_слово.jpg.to отдает изображение. Как загрузить это изображение с помощью universal image...

Загрузка изображения в imageview - Программирование Android
Всем привет. Возникла проблема, распарсил сайт в arraylist, сохранил в БД, далее мне нужно вывести сайт на активность. Делаю так: ...

RecyclerView.Adapter загрузка изображения - Программирование Android
При прокрутке RecycleView в ImageView загружается необходимая фотография.. Но при прокрутке почему то начинаются не состыковки.. (как...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
contedevel
57 / 55 / 8
Регистрация: 07.10.2012
Сообщений: 596
11.01.2015, 03:00 #2
Цитата Сообщение от vitas199405 Посмотреть сообщение
нужна загрузка изображений из галереи для того чтобы можно было на них рисовать. (Без использования xml, т.к. вся работа заключается именно в этом файле).
Не очень понял, в смысле, как сам путь к файлу получить для работы с ним? Или как копию сделать?

Добавлено через 6 минут
Не знаю, то ты имел в виду или нет, но там все просто загружаешь из галереи файл как Bitmap, работаешь с ним, потом выгружаешь, можешь старый заменить, но это плохой вариант, лучше копию сделать.
Да, если планируется обработка очень больших файлов, то все применяемые модификации лучше как-то хранить, и отображать только на размер и участок, видимый на экране, (уменьшенную копию картинки загрузить или лишь часть с небольшой буферизацией за пределы экрана для более плавной навигации), а не загружать весь графический файл в память.
vitas199405
0 / 0 / 0
Регистрация: 04.03.2013
Сообщений: 36
11.01.2015, 12:17  [ТС] #3
Просто у меня задействован только один xml файл и это не основной.
вот код основного (activity_paint.xml)
Java
1
2
3
4
5
6
7
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="${relativePackage}.${activityClass}" >
 
</RelativeLayout>
А вот который задействован.
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
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/root"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
 
    <SeekBar
        android:id="@+id/seekBar_size"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginTop="70dp"
        android:max="30" />
 
    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="34dp"
        android:text="@string/Choose" />
 
    <Button
        android:id="@+id/select_size"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/seekBar_size"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="68dp"
        android:text="@string/Select" />
 
    <TextView
        android:id="@+id/size_value"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/seekBar_size"
        android:layout_centerHorizontal="true" />
 
</RelativeLayout>
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.01.2015, 12:17
Привет! Вот еще темы с ответами:

Загрузка изображения из интернета в imageview - Программирование Android
Доброго, передаю из одной активити в другую ссылку на картинку, она прямая, как мне ее вывести в imageview?

Android Загрузка изображения на стену vkontakte - Программирование Android
Здравствуйте всем, возникла необходимость загрузить фотографию на стену вконтакте. На сайте разработчиков есть статья Загрузка файлов ...

Добавить в скрипт для копирования папки дополнительный функционал - CMD/BAT
Всем привет! Уважаемые форумчане! Требуется ваша помощь в дописании скрипта бэкапов.. Сейчас скрипт умеет копировать последнюю...

Как сделать перерисовку изображения в обработке условий Paint? - C++/CLI WinForms
private: System::Void button2_Click(System::Object^ sender, System::EventArgs^ e) { gr=pictureBox1-&gt;CreateGraphics(); ...


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru