메뉴 건너뛰기

조회 수 6017 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

안드로이드에서 이미지를 회전하는 방법은 여러가지가 있다. 

 

하지만, 네이버에서 나온 대부분의 방법은 

 

imgBoss2=BitmapFactory.decodeResource(.....);

 

imgBoss2=Bitmap.createScaledBitmap(....);


이것을 사용하는데,, 이것은 휴대폰으로 하여금 새로운 객체를 생성하기때문에 부담을 줄 수 밖에 없다. 

 

그래서 이미지 파일을 새로 만드는 것이 아닌 구성요소인 Matrix를 새로 리셋하여 

회전시키고 그것을 나중에 적용하는 방법에 대해서 알아 본다. 

 

그래픽스 시스템에 대해서 기본적으로 배우면 Matrix가 왜 회전과 이동에 관여 하는지 알 수 있다. 

 

궁금하신분은 컴퓨터 그래픽스 Matrix 에서 Transformation 파트를 찾아 보도록 한다. 

 

나는 아래의 소스는 게임을 만드는 소스중 같은이미지가 360도 돌아가면서 이동하는 것이다. 

 

코드가 너무 길어서 정리해서 써놓으면 

 

Matrix matrix = new Matrix();

.....으로 위에서 메트릭스를 선언하고 

루프 혹은 자신이 새로 설정하고 싶은 부분에서 매트릭스를 리셋시켜준다. 

 

matrix.reset();


//안드로이드는 좌상단부터 그림이 시작된다. 하지만 회전은 가운데를 기준으로 돌아가게되므로, 
//좌상단을 이용하여 그림의 가운데 지점을 찾아 내는 로직이다. 
centerX=(2*x+width)/2;

centerY=(2*y+height)/2;

 

//이것은 필요하신분만 사용하도록 하자 이것은 특정위치로 이미지를 이동시킨다. 

//다시말하지만 이것또한 좌상단부터 아래와 오른쪽으로 그림을 그리게 된다. 

matrix.setTranslate(x,y);

 

//이부분이 회전을 담당하는 부분이다. 매개변수는 처음부터 이미지, 그리고 x,y축만큼 회전이다. 

//아래와 같이하면 제자리에서 회전하게 된다. 

matrix.postRotate(imgRotate, centerX, centerY);

 

//그뒤에 그림을 그려주면 완성. 

canvas.drawBitmap(imgBoss, matrix, null);

 

 

 

 

안드로이드에서 이미지는 매우 민감하다. 휴대폰이 뜨거워지거나 렉이 걸릴 수 있기 때문이다.  

 

사진정도 가볍게 회전하는 것은 문제가 아니지만,, ,자주 회전해야 많은 이미지를 회전시켜야한다면

 

위와 같은 방법으로 메트릭스를 사용해야 할 것 이다. 


List of Articles
번호 제목 날짜 조회 수
57 JSON(JavaScript Object Notation) - jQuery Ajax - jQuery.getJSON() 메서드 (비동기적으로 JSON파일 로드) file 2014.10.16 6570
56 jQuery ajax post 요청 text 응답 2014.10.16 6708
55 jQuery Ajax - jQuery.load() 메서드 (동적으로 원격 페이지 로드) file 2014.10.16 6425
54 Java에서 XML 불러와서 동적 변화 주기 file 2021.03.31 290
53 JavaScript 맛보기 file 2014.09.04 6591
52 JAVA JDBC를 사용하여 MySQL과 연동 file 2015.11.21 8655
51 Java Applet과 javascript와의 통신 2015.06.29 7759
50 Invalid project description 문제 file 2015.07.01 7124
49 Intent (인텐트) 2016.06.07 7630
48 ImageVeiw의 현재 리소스 비교하기 2014.08.28 6756
47 HTML5로 비디오 보여주기 Video Tag file 2014.09.04 7063
46 HTML5로 나만의 비디오 플레이어 스킨 만들기 -3- JavaScript file 2014.09.04 6289
45 HTML5로 나만의 비디오 플레이어 스킨 만들기 -2- JavaScript file 2014.09.04 6313
44 HTML5로 나만의 비디오 플레이어 스킨 만들기 -1- CSS file 2014.09.04 6456
43 HTML5로 게임 만들기 워밍업 file 2014.09.04 6064
42 HTML5 시작하기 file 2014.09.04 5665
41 HTML5 드래그 앤 드롭 하기 Drag and Drop file 2014.09.04 7754
40 HTML5 Web Storage -01- file 2014.09.04 5588
39 HTML5 Speech Input (음성인식) API 2014.09.04 6454
38 HTML5 Geolocation (구글 지도에 현위치 표시하기) file 2014.09.04 6813
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved