성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] VT sequences to "CONOUT$" vs. STD_O...
[정성태] NetCoreDbg is a managed code debugg...
[정성태] Evaluating tail call elimination in...
[정성태] What’s new in System.Text.Json in ....
[정성태] What's new in .NET 9: Cryptography ...
[정성태] 아... 제시해 주신 "https://akrzemi1.wordp...
[정성태] 다시 질문을 정리할 필요가 있을 것 같습니다. 제가 본문에...
[이승준] 완전히 잘못 짚었습니다. 댓글 지우고 싶네요. 검색을 해보...
[정성태] 우선 답글 감사합니다. ^^ 그런데, 사실 저 예제는 (g...
[이승준] 수정이 안되어서... byteArray는 BYTE* 타입입니다...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>안드로이드용 Xamarin 개발 시 겪을 만한 시행 착오 정리</h1> <p> 이번에 <a target='tab' href='http://www.sysnet.pe.kr/2/0/1490'>C# 책을 쓰면서 마지막 장의 실습 프로그램</a>으로 PPT 제어 프로그램을 만들어 보았습니다. 일단, 윈도우 폰용 PPT 제어 앱은 쉽게 만들었는데요. 그다음 안드로이드용을 만들면서 Xamarin을 사용해 보았습니다.<br /> <br /> 사실, Xamarin을 처음으로 사용하다 보니 시행착오를 겪게 되었는데요. 어쩔 때는 왠지 Xamarin에 대한 신뢰가 떨어지기까지 했습니다. 그러다 결국 문제는 Mono/Android에 대한 이해가 부족해서 나온 문제임을 알게 되었는데요. 어쨌든, 끝까지 진행해서 기어이 C#으로 안드로이드 폰용 PPT 제어 앱을 만들었고 구글 플레이에 공개도 했습니다. (윈도우 폰용만큼 정교하지는 않습니다. ^^ 시간 나면 아이폰 앱으로도 공개하려 하는데... 휴~~~ ^^)<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Google Play - OfficePresenter ; <a target='tab' href='https://play.google.com/store/apps/details?id=kr.pe.sysnet.OfficePresenter'>https://play.google.com/store/apps/details?id=kr.pe.sysnet.OfficePresenter</a> </pre> <br /> 당연히 소스코드도 github에 공개되어 있고.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > PowerPoint controller by Windows Phone and Android ; <a target='tab' href='https://github.com/stjeong/OfficePresenter'>https://github.com/stjeong/OfficePresenter</a> </pre> <br /> 다른 분들은 저와 동일한 시행착오를 겪지 마시라고 정리해 놉니다. ^^<br /> <br /> <hr style='width: 50%' /><br /> <br /> <br /><div style='font-size: 12pt; font-family: Malgun Gothic, Consolas; color: #2211AA; text-align: left; font-weight: bold'>1. 반드시 aligned 배포</div> <br /> Xamarin으로 Release 빌드를 하면 /bin/Release 폴더에 apk 파일 2개가 생성됩니다.<br /> <br /> <ul> <li>kr.pe.sysnet.OfficePresenter.apk</li> <li>kr.pe.sysnet.OfficePresenter-Signed.apk</li> </ul> <br /> 어떤 것을 안드로이드 폰에 배포해야 할까요? ^^ 정답은 둘 다 아닙니다. 그보다는 csproj 프로젝트가 놓인 폴더에 보면 kr.pe.sysnet.OfficePresenter-Aligned.apk라는 파일을 배포해야 정상적으로 안드로이드 폰에서 동작합니다.<br /> <br /> 이 부분은 매뉴얼에도 나와있긴 한데, 당연히 Release 폴더의 것을 배포하면 되겠거니... 하면서 무심코 진행하게 되면 Xamarin 안드로이드 앱이 실행이 안되는 이상한 현상을 경험하게 됩니다. ^^<br /> <br /> <br /><div style='font-size: 12pt; font-family: Malgun Gothic, Consolas; color: #2211AA; text-align: left; font-weight: bold'>2. 릴리스 빌드의 link 옵션으로 인한 실행 오류</div> <br /> Xamarin의 장점이 하나 있다면 필요한 어셈블리만 링킹하는 기능이 있다는 것입니다. 사실 이것은 장점이라기보다는 제한된 자원을 가진 모바일 폰에 설치되는 앱의 크기를 최대한 줄이려는 노력에서 비롯되었을 뿐입니다.<br /> <br /> 아래의 문서에서 링킹에 대해 자세히 설명하고 있으니 참고하시고.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Linking ; <a target='tab' href='http://docs.xamarin.com/guides/android/advanced_topics/linking#15-custom-linking'>http://docs.xamarin.com/guides/android/advanced_topics/linking#15-custom-linking</a> </pre> <br /> 문제는 이것이 Debug 빌드에서는 꺼져 있고, Release에서는 켜진다는 것입니다. 그래서, 개발 시에 안드로이드 폰에서는 잘 동작하다가 배포하는 시점에 릴리스 빌드로 하면서 갑자기 응용 프로그램이 동작안하는 황당한 문제를 경험할 수 있습니다.<br /> <br /> 이유는 간단합니다. 링킹 과정에서 Xamarin은 최대한 Reflection으로 얻어낸 의존성을 기반으로 필요한 코드를 선택해서 포함시키는 과정을 거칩니다. 따라서, 사용자 코드에서 동적으로 로드하는 기능에 대해서는 Xamarin 측에서 알 수 없으므로 링킹 과정에서 누락시키게 됩니다.<br /> <br /> 당연히, 코드가 없는 앱을 배포하게 되니 실행 시에 오류가 발생하게 됩니다.<br /> <br /> 예를 들어, 다음의 구성 요소도 그 한 예입니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Cheesebaron.HorizontalListView ; <a target='tab' href='https://github.com/Cheesebaron/Cheesebaron.HorizontalListView'>https://github.com/Cheesebaron/Cheesebaron.HorizontalListView</a> </pre> <br /> 이 코드를 사용하게 되면 실행 시에 "An unhandled exception occured" 예외가 발생합니다. 내부적인 동적 의존 관계를 Xamarin에서 해석할 수 없기 때문입니다.<br /> <br /> 그래서 Cheesebaron.HorizontalListView 개발자는 내부에 구현된 동적 의존 관계를 밝히고 있는데요. 이에 따라 그 컨트롤을 사용하는 개발자는 Xamarin 프로젝트에 "FixAdapterLinking.xml"라는 이름으로 다음의 내용을 포함시켜야 합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > <?xml version="1.0" encoding="UTF-8" ?> <linker> <assembly fullname="Mono.Android"> <type fullname="Android.Widget.AdapterView" > <method name="GetGetAdapterHandler" /> <method name="GetSetAdapter_Landroid_widget_Adapter_Handler" /> </type> </assembly> </linker> </pre> <br /> Xamarin은 링킹 시에 FixAdapterLinking.xml 파일이 있는지 확인하고, 있다면 그것에 명시된 코드에 대한 의존성을 링킹 시에 참고해서 바이너리를 만들게 됩니다.<br /> <br /> 즉, 다른 컨트롤을 가져다 쓸 때는 반드시 내부적인 동적 의존 관계를 명시하고 있는지 확인해야 합니다.<br /> <br /> <br /><div style='font-size: 12pt; font-family: Malgun Gothic, Consolas; color: #2211AA; text-align: left; font-weight: bold'>3. Intent의 크기 제한</div> <br /> 윈도우 폰 같으면 Page끼리 데이터를 넘기는 것과 비교할 수 있는데요. 안드로이드에서는 Activity끼리 데이터를 넘기는 한 방법으로 Intent의 putExtra 메서드를 이용할 수 있습니다.<br /> <br /> 그런데, 웬일인지 다음과 같은 오류가 발생하는 것이었습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 09-30 01:03:45.992 E/JavaBinder( 4671): !!! FAILED BINDER TRANSACTION !!! 09-30 01:03:46.012 D/memalloc( 4671): ion: Mapped buffer base:0x608a1000 size:122880 offset:0 fd:70 The thread 0x2 has exited with code 0 (0x0). 09-30 01:03:47.994 D/memalloc( 4671): ion: Unmapping buffer base:0x608a1000 size:122880 </pre> <br /> 이에 대해서 검색을 해보니 다행히 원인이 밝혀졌습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > [android] Activity 호출 시 발생하는 !!! FAILED BINDER TRANSACTION !!! 해결법. ; <a target='tab' href='http://aroundck.tistory.com/1156'>http://aroundck.tistory.com/1156</a> </pre> <br /> Intent의 putExtra로는 100KB까지만 데이터를 전송할 수 있다는 제약이었던 것입니다. 윈도우 폰용 앱을 만들 때의 경험으로 안드로이드를 대하니 이런 시행 착오를 겪게 되는 것입니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 결론은, Xamarin은 충분히 안정적이라는 것입니다. 물론 ^^ 좀 더 복잡한 앱을 만들게 되면 어떨지 모르지만.<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
5211
(왼쪽의 숫자를 입력해야 합니다.)