반응형
[Gradle 설정]
1
|
id 'kotlin-android-extensions'
|
cs |
[AndroidManifest.xml]
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> 추가
<MainActivity>
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
|
package com.cookandroid.project8_2
import android.content.Context
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.os.Environment
import android.widget.Toast
import androidx.core.app.ActivityCompat
import com.cookandroid.project8_2.myPictureView
import kotlinx.android.synthetic.main.activity_main.*
import java.io.File
class MainActivity : AppCompatActivity() {
var imageFiles : Array<File>? = null
lateinit var imageFname : String
var curNum = 0
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
title = "간단한 이미지 뷰어"
ActivityCompat.requestPermissions(this, arrayOf(android.Manifest.permission.WRITE_EXTERNAL_STORAGE), Context.MODE_PRIVATE)
imageFiles = File(Environment.getExternalStorageDirectory().absolutePath + "/Pictures").listFiles()
imageFname = imageFiles!![0].toString()
myPictureView.imagePath = imageFname
tv.setText("1/${imageFiles!!.size - 1}")
btnPrev.setOnClickListener {
if(curNum <= 0){
curNum = imageFiles!!.size - 2
}else{
curNum--
}
tv.setText("${curNum + 1}/${imageFiles!!.size -1}")
imageFname = imageFiles!![curNum].toString()
myPictureView.imagePath = imageFname
myPictureView.invalidate()
}
btnNext.setOnClickListener {
if(curNum == imageFiles!!.size -2){
curNum = 0
}else{
curNum++
}
tv.setText("${curNum + 1}/${imageFiles!!.size -1}")
imageFname = imageFiles!![curNum].toString()
myPictureView.imagePath = imageFname
myPictureView.invalidate()
}
}
}
|
cs |
<myPictureView>
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
|
package com.cookandroid.project8_2
import android.content.Context
import android.graphics.BitmapFactory
import android.graphics.Canvas
import android.util.AttributeSet
import android.view.View
class myPictureView(context: Context, attrs: AttributeSet?): View(context, attrs) {
var imagePath : String? = null
override fun onDraw(canvas: Canvas?) {
super.onDraw(canvas)
try{
if(imagePath != null){
var bitmap = BitmapFactory.decodeFile(imagePath)
canvas!!.scale(2f, 2f, 0f, 0f)
canvas!!.drawBitmap(bitmap!!, 0f, 0f, null)
bitmap!!.recycle()
}
}catch(e :Exception){
}
}
}
|
cs |
<activity_main.xml>
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
|
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/btnPrev"
android:text="이전 그림"
android:layout_weight="1"/>
<TextView
android:layout_marginLeft="10dp"
android:layout_marginRight="10dp"
android:textSize="20dp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="0/0"
android:id="@+id/tv"/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/btnNext"
android:text="다음 그림"
android:layout_weight="1"/>
</LinearLayout>
<com.cookandroid.project8_2.myPictureView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/myPictureView"/>
</LinearLayout>
|
cs |
반응형
'안드로이드 프로그래밍 > 코틀린' 카테고리의 다른 글
[코틀린을 활용한 안드로이드 프로그래밍] 9장 직접 풀어보기 9-3 (0) | 2022.05.26 |
---|---|
[코틀린을 활용한 안드로이드 프로그래밍] 9장 직접 풀어보기 9-2 (0) | 2022.05.26 |
[코틀린을 활용한 안드로이드 프로그래밍] 8장 직접 풀어보기 8-1 (0) | 2022.05.25 |
[코틀린을 활용한 안드로이드 프로그래밍] 6장 직접 풀어보기 6-3 (0) | 2022.05.25 |
[코틀린을 활용한 안드로이드 프로그래밍] 6장 직접 풀어보기 6-2 (0) | 2022.05.22 |