이 글은 2014년 1월 5일 원래 제 다음 블로그에서 가져온 글입니다.

Long Live The Queen 프린세스메이커의 패러디 게임이라고 하는데 죽을일이 없는(가끔 가출은 하더만...) 프린세스 메이커와는 다르게 잘못된 선택은 곧 죽음인 살얼음판의 프린세스메이커라고 한다고해서 가격도 싸길래 냉큼 질러보았다.(사실 리눅스 지원인것도 한 몫했다. 리눅스 지원 게임이 그리 많지는 않으니..최근 개인프로젝트로 돌릴까 하는 클라우드게이밍도 스팀이 리눅스를 지원하면 그냥 클라우드 데스크탑에 스팀만 띄워주면 되니까 쉬워진다.)

일단 냉큼 지르고 영어의 압박을 간단히 떨친후(사실 영어로 되어있어서 반대로 게임하기 수월했다.) 뭐가뭔지 몰라(...) 공략을 찾던 중 이 게임이 Ren'Py라는 엔진으로 만들어졌다는 것을 알았다.

 Ren'Py... 이름에 왠지 Py가 들어가는데다가 MacOSX, Linux, Windows를 전부 지원한다? 혹시 이거 Python?하고 스팀설치 폴더에 들어가서 뜯어본결과 Python맞더만...그것도 PyGame이라는 엔진을 비주얼노벨용으로 만든게 Ren'Py고 PyGame이 안드로이드도 지원하기 때문에 Ren'Py도 안드로이드 지원이 가능하다고 되어있었다.

그러나. 이 게임은 스팀에서 판매하기에 안드로이드 지원이 될 턱이 없었고 스크립트 언어인 Python이라면 별 저항없이 안드로이드에 이식이 되지 않을까 하던중 RenPy SDK에서 안드로이드 지원이 가능하다는 것을 찾아내었다.

흐음...이걸 일단 안드로이드에 이식해 보기로 하고 결국 휴일에 삽을 들고 말았다...에라이.

 자 안드로이드 포팅(?)을 위한 준비물을 우선 말해보도록 하겠다. 여기서는 우분투같은 리눅스 환경에서 작업하는 것으로 되어있습니다. Mac이나 Windows는 스팀게임의 경로나 안드로이드폰 연결방법등이 다릅니다.

 http://baekansi.hosting.paran.com/doc/html/android.html

여기에 일단 안드로이드용으로 컴파일 하기위해 어떻게 해야할지 자세히 나와있다.

우선 필요한 것은

1. Ren'Py SDK http://www.renpy.org/latest.html

2. Oracle JDK http://www.oracle.com/technetwork/java/javase/downloads/index.html

3. Python 2.7 이건 뭐...알아서 검색하던가 sudo apt-get install python2.7

4. RAPT(렌파이 안드로이드 패키징 툴)http://www.renpy.org/dl/android/

5. 손을 댈 Ren'Py로 만들어진 게임(여기선 Long Live The Queen 되시겠다. 이건 Steam관련 스크립트가 있긴 하지만...스팀없이도 실행되는 것을 확인)

6. rpatool https://github.com/Shizmob/rpatool  rpa나 rpi등으로 이미지나 음악들이 압축 되어있는 경우 어쩔 수 없이 이 파일들을 풀어 해쳐놓아야 안드로이드에서 실행이 된다. 아니면 다른 방법이 있을 수도 있는데 방법을 잘 모르겠다.(...)

7. 삽질을 위한 안드로이드 기반 기기(에뮬레이터는 비추)

8. adb 안드로이드개발 홈페이지에서 다운로드 받던지 아니면 sudo apt-get install android-tools-adb

*. 당신의 삽질력


일단 되었으면 JDK와 Python을 설치하자.

그리고 Ren'Py SDK를 적당한곳에 압축을 풀고 RAPT를 Ren'Py SDK의 압축 푼곳에다가 같이 압축을 풀어넣자.

압축 풀기가 완료되었다면 renpy.sh를 실행해서 Ren'Py런처가 실행이 잘 되는지 우선 보도록 하자. 되었다면 예시로 같이 들어있는 것도 실행해 보고 이것저것 하다가 일단 종료.

 이 제 스팀에서 Ren'Py게임을 구입하자. 아니면 조금 뒤적거리면 무료로 좋은 게임을 배포하기도 하니 잘 찾아보자. 걔중엔 지하철에서 하기에는 조금 엄한물건도 있기는 하지만....여기서는 아까 말했던 Long Live The Queen(이하 LLQ)을 이용하도록 하자. 그리고 꼭 한번 실행시켜주자. 가끔 스팀이 제대로 다운로드 안 하고 다 됐다고 사기치는 경우가 있어서 그런것이니  한번은 꼭 실행시켜보도록 하자.

실행이 확인 되었으면 ~/.local/share/Steam/SteamApps/common 로가면 당신이 그동안 스팀에다가 쏟아부은 결과물들이 들어가 앉아 있다. 여기서 Long Live The Queen이란 이름의 폴더째로 일단 복사하자.

 복사한 폴더는 위의 Ren'Py SDK와 RAPT의 압축을 풀어넣은 곳에다가 붙여넣기 하면 된다. 다시 한번 renpy.sh를 실행해보자. LongLifeTheQueen이 보이는가? 오른쪽에 Android라고 보이는가? 여기에 보면 Emulation으로 실행을 해볼 수 있다!!!! 그.러.나. 여기서 실행하면 당연하다는 듯이 에러난다. 이 에러를 잡는 것이 바로 이 삽질의 핵심이다.

삽질의 처음은 로그를 뜯어보는 것이다. 로그를 한번보자. glpatch.rpy가 에러가 났다고 나온다. 하지만 게임폴더를 아무리 뒤져도 rpy파일은 보이지 않는다. 사실 파이썬을 써보면 알겠지만 속도를 위해 한번 바이트코드로 컴파일하게 되는데 렌파이도 비슷한 원리로 스크립트를 컴파일 해 놓은 것이다. 즉 로그에서 rpy라고 나오는 파일이 사실 rpyc를 말하는 것으로 생각해도 좋다.
 

 암튼 glpatch라는 놈이 문제라고 되어있는데 이미 컴파일되어있는 스크립트를 어떻게 해볼 수는 없고 한번 제거해보도록 하자.즉 삭제! 그리고 빈파일을 하나 만들어서 glpatch.rpy라고 하나 만들어 놓자. 빈 파일이기 때문에 아무런 내용은 없지만 그렇다고 파일이 없으면 그건 그것대로 또 에러가 난다. 말그대로 patch라고 되어있는 걸로 봐서 OpenGL관련 문제를 해결한 패치로 보인다. 그러나 안드로이드에서는 저게 도리어 문제를 일으키니 패치를 없애도록 하자. 그리고 한번 게임을 실행해보면 glpatch.rpyc가 생성되어있는 것을 알 수 있다. rpy가 빈파일이므로 rpyc도 빈내용으로 만들어진 바이트코드가 된다. 이걸로 한 가지 알 수 있는 것은 저 패치는 PC에서만 통하는 것으로 보인다는 것. 아마 Nvidia나 ATI드라이버 호환내용이 아니었을까?

아까처럼 PC에서 renpy.sh를 실행하고 Android - Emulation - Phone 혹은 Tablet 를 실행해보자. 이번에는 타이틀 화면이 뜬다? 참고로 Translation.rpy를 작성한뒤 game폴더에 넣어주고 Translation.rpy에 폰트를 지정한다음 해당 폰트를 Game폴더에 같이 넣어주면 폰트도 맘대로 바꿀 수 있게 된다. 다만 은폰트나 나눔 폰트를 이용하는 것을 권한다. 맑은 고딕도 예쁘지만 이건 MS가 저작권을 지니고 있어서...Translation.rpy작성법은 http://www.renpy.org/wiki/Ren%27Py_%EC%97%90%EC%84%9C_%ED%95%9C%EA%B8%80_%EC%84%A4%EC%A0%95%EC%97%90_%EB%94%B0%EB%A5%B8_%EC%95%88%EB%82%B4

여기를 참조하시길

이제 안드로이드용으로 컴파일을 해보자. 해보기에 앞서서 터미널 사용법을 알고 있으리라 믿는다.

 renpy가 설치된 곳으로 가서 (RAPT의 압축을 푼 곳으로 가서)

./android.py installsdk

라고 치면 이 녀석이 안드로이드 SDK를 다운로드 받으면서 이것저것 물어보게 된다. 그냥 yes 혹은 no라고 대답만 하면 알아서 잘 해주니 그냥 시키는대로 하자.

그다음

./android.py configure LongLiveTheQueen

이라 치면 configure 뒤에 붙은 게임의 안드로이드 설정을 하게 된다. 역시 묻는말에 꼬박꼬박 대답하면 된다. 개인적으로는 2.2기반보다 4.0기반으로 만드는 것을 추천한다. 3.0은 그냥 버리는 거다.

이제 설정이 끝났다면 드디어 APK빌드를 해보게 된다. 이에 앞서 안드로이드 폰을 PC에 연결하고 ADB설정을 하고 디버그모드를 허용까지 해주어야 편하다. ADB설정은 이 블로그 어딘가에 잘 써있으니 참고.

일단 안드로이드기기를 PC에 연결하고

./android.py build LongLiveTheQueen release install

이렇게 하면 안드로이드용으로 빌드도 하고 안드로이드기기에 알아서 설치까지 다 해준다.


이제 실행해보기전에

./android.py logcat

을 실행하고 기기에서 게임을 실행해보자. (Ren'Py기본 아이콘에 기본로딩화면이 뜬다. 이는 RAPT루트/res/drawable을 교체함으로써 바꿀 수 있다. 이건 그냥 참고사항


아마도 혹은 역시나 에러를 내뿜어 주실것이다.

 steam.rpy

결국 스팀이 일을 내주셨다. 아까처럼 steam.rpyc를 삭제하고 빈파일로 steam.rpy파일을 하나 만든 후에 게임을 한번 실행하고 다시 APK를 만들어주자.


그리고 bytecode.rpyb파일은 그때그때마다 삭제해놓길 바란다. 게임실행속도를 올리기위한 방법중 하나지만 APK의 용량증가의 원인중 하나이므로...


이제는 안드로이드기기에서 타이틀화면을 봐야 정상인데....

 안된다. 그럼 아까처럼 logcat을 한번 보자.

  왠 아이콘 이미지를 못 찾는다고 뜬다.(icon-big.png)ignore 버튼을 누르니 이번엔 배경이미지를 못찾는다고 하고 배경음악도 못찾는다고 하고..

이 파일들 아까 Game폴더에 없었는데?


 사실 이것의 경우는 안드로이드용 렌파이의 문제일것으로 보인다. 게임 개발자나 회사에서 감추고픈(?) 이미지나 음악들이 떠돌아다니는 것을 싫어하기에 Ren'Py에서는 rpa라는 파일로 압축+암호화를 하는데 이게 안드로이드 내에서 정상적으로 복호화가 진행이 되지 않은 것이다. 잘 뒤져보면 llq.rpa란 파일이 보인다. 아마 못찾는다고 뜬 파일들은 이 안에 다 있을 것이다. 그럼 이걸 풀어서 game폴더에 흩뜨려 놓으면 정상적으로 실행이 될 것이다.

그럼 무엇으로 복호화를 할까? 아주 간단하게도 rpatool을 이용하면 된다. 이 것도 하나의 파이썬 스크립트로 되어있는데 그냥 game폴더에 넣어주자. 그리고 cd명령으로 game폴더까지 들어간다음

./rpatool.py -x llq.rpa

이러면 암호화되었던 것들이 압축이 싹풀리면서 보이게 된다. 그럼 이제 rpatool하고 llq.rpa파일은 필요없어졌으니 삭제하자. 겸사겸사 bytecode.rpyb파일도 삭제해주고.

이제 다시 빌드하고 폰에 넣으면?

 타이틀화면 입성! 게임까지 입성이다!!!

오오..


힘든 사투였다.오오..근데 이 게임을 지하철에서 하는 건 좀 무리 아니려나...

2014. 7 .26 우선 안드로이드 포팅을 하는 방법을 올린 유튜브 영상이다. 본인이 찍었으며 이 방법을 통해서 만들어진 결과물을 마음대로 배포하지를 않기를 바란다. 만들어진 결과물은 개인적으로만 사용하고 꼭 스팀에서 구입한 것을 이용하자. 공식홈페이지에서 구입한 것은...잘 모르겠다.


댓글을 달아 주세요

  • linkmarker 2014.09.13 13:03  댓글주소  수정/삭제  댓글쓰기

    그냥안드로이드 앱개발하는것도 알려주시면 안되나요? ('@')

    • 우분투 사용 10년째 Moordev 2014.09.14 00:44 신고  댓글주소  수정/삭제

      렌파이로 안드로이드 버전 만드는 것을 말하시는 것이면 그냥 PC버전 만들듯이 만든다음 안드로이드 용으로 컴파일 하시면 됩니다.

      하지만 만약 일반적은 안드로이드 앱개발을 원하신다면... 제 글의 요지와는 좀 달라지네요.
      안드로이드 앱개발은 제가 굳이 글을 쓰지 않아도 워낙 좋은 글들이 많이서 제가 구태여 강좌를 쓸 이유가 없을 듯 합니다.

      인터넷 조금만 검색해도 상당히 좋은 글들이 많습니다.
      구글 검색 1번째 사이트로는
      http://www.tipssoft.com/bulletin/board.php?bo_table=old_bbs&wr_id=501

      여기가 있군요. 상당히 정리가 잘 되어있습니다.

      그리고 제대로 개발을 해보시려면 서점에 가서 책 한권 구입하셔서 보는 것이 좋을 듯 합니다. 특히 예제 많은 것을 사세요. 설명도 설명이지만 코드가 곧 기술이니까요.

  • ㅠㅠㅠ 2014.10.24 21:18  댓글주소  수정/삭제  댓글쓰기

    저 뭐좀 여쭤봐도 될까요ㅠㅠ?
    스팀에서 이 게임을 다운 받았는데 앱크러쉬가 나서 계속 실행이 안되네요..
    오류 모듈 보니까 'Python26.dll'이라고 돼있던데 혹시 해결할 방법이 있을까요?
    호환성도 바꿔보고 포맷도 해보고 인터넷 설정부터 해상도 조절까지 다해봤는데 안되네요ㅠㅠ 스팀이랑 게임은 스무번도 더 깔았다 지웠다 한 것 같아요.
    스팀쪽에 문의해서 하라는거 해봤지만 별다를 것 없었구요.
    저 파일이랑 관련 된 거 같은데 무슨 방법 없을까요ㅠㅠ?
    일주일째 이것만 붙잡고 있는데 노이로제 걸릴것 같아요..

    • 우분투 사용 10년째 Moordev 2014.10.25 01:16 신고  댓글주소  수정/삭제

      우선 Python 2.6을 설치해보세요.
      Python은 지금도 개발중인 인터프리터라 호환성 설정 하실 필요 없습니다. (물론 Python 2.x와 3.x는 호환이 안되는 것이 있어서 2.7과 3.x가 공존하는 경우가 많기는 합니다.)

      아무래도 Python이 엉킨 것 같으니 Python2.7이나 Python 2.6을 설치 해보시길 추천드립니다.

    • ㅠㅠㅠ 2014.11.01 00:49  댓글주소  수정/삭제

      답변 주신지 좀됐는데 이제서야 확인했네요ㅠㅠ.. 친절한 답변 진짜 감사드려요!! 말씀해주신대로 Python2.6을 깔았는데 별다른 변화가 없네요ㅠㅠ 혹시 Python 프로그램으로 어떻게 할 수 있는 방법은 없을까요? 귀찮게 해드려서 죄송해요ㅠㅠ

    • 우분투 사용 10년째 Moordev 2014.11.02 00:58 신고  댓글주소  수정/삭제

      32비트와 64비트 문제가 아닐까라는 생각이 드는군요. 저한테는 64비트 PC가 없어서 확인을 못합니다. 다만, http://moordev.tistory.com/38 여기의 엔진패치를 하시면 Python2.7을 내장하고 이를 이용해서 구동하기 때문에 구동이 될 것이라고 생각이 듭니다.

      C:\Program Files\Steam\steamapps\common\LongLiveTheQueen\renpy 폴더를 미리 날린뒤에 덮는 것을 잊지 마세요.

      만약 이래도 안 된다면 Python 2.6을 32비트버전으로 리눅스에서 하는 것 마냥 컴파일해서(...) 설치해야 할 지도 모릅니다.

    • ㅠㅠㅠ 2014.11.02 04:42  댓글주소  수정/삭제

      엔진패치를 했는데 전엔 앱크러쉬 뜨면서 오류 모듈이
      Python26.dll이라고 떴는데 엔진패치 후에는 python27.dll라고 뜨네요...제 컴이 python 프로그램 자체랑 안맞는건가요ㅠㅠ 그럴수도 있나요? 혹시 몰라서 백신 같은 프로그램 전부 끄고 시도 해봤지만 결과는 같아요ㅠㅠ...그래도 답변 정말 감사합니다!!

    • 우분투 사용 10년째 Moordev 2014.11.02 23:09 신고  댓글주소  수정/삭제

      오류 메시지 전체와 시스템 사양을 알려주시면 한번 제가 공식 포럼에 올려서 물어보도록 할게요. 아니면 영어가 되신다면 Hanakogames 포럼에 가서 물어보시는 것도 나쁘지는 않을 것이라 생각합니다.

      ...파이썬이 정상적으로 작동 안한다면 안드로이드로 포팅해서 모바일로 할 수도 없겠군요.(...)

  • ... 2015.03.30 22:02  댓글주소  수정/삭제  댓글쓰기

    아......
    끌리는구나......
    안도ㅐ.......
    지르면 안도ㅐ.....
    너는 그녀-game-와 헤어지기로 했잖아.........
    사나이 약속은 만근의 무게와도 같다구..............
    아.......
    ㅋㅋㅋㅋㅋㅋㅋㅋㅋ

  • 겨울비 2016.06.08 13:50  댓글주소  수정/삭제  댓글쓰기

    좋은 정보 잘보고 갑니다

  • leta 2017.04.01 03:13  댓글주소  수정/삭제  댓글쓰기

    Ren.py 런쳐에서 안드로이드들어가고 폰 태블릿 텔레비전때 태블릿눌러도 안되네요. 어찌하나요
    I'm sorry, but an uncaught exception occurred.

    While parsing C:\Users\qkr\Desktop\renpy\LongLiveTheQueen/game/steam.rpy.
    UnicodeDecodeError: 'utf8' codec can't decode byte 0x9c in position 1: invalid start byte

    -- Full Traceback ------------------------------------------------------------

    Full traceback:
    File "C:\Users\qkr\Desktop\renpy\renpy\bootstrap.py", line 295, in bootstrap
    renpy.main.main()
    File "C:\Users\qkr\Desktop\renpy\renpy\main.py", line 364, in main
    renpy.game.script.load_script() # sets renpy.game.script.
    File "C:\Users\qkr\Desktop\renpy\renpy\script.py", line 265, in load_script
    self.load_appropriate_file(".rpyc", ".rpy", dir, fn, initcode)
    File "C:\Users\qkr\Desktop\renpy\renpy\script.py", line 738, in load_appropriate_file
    data, stmts = self.load_file(dir, fn + source)
    File "C:\Users\qkr\Desktop\renpy\renpy\script.py", line 549, in load_file
    stmts = renpy.parser.parse(fullfn)
    File "C:\Users\qkr\Desktop\renpy\renpy\parser.py", line 2483, in parse
    lines = list_logical_lines(fn, filedata, linenumber)
    File "C:\Users\qkr\Desktop\renpy\renpy\parser.py", line 194, in list_logical_lines
    data = f.read()
    File "/home/tom/ab/x64lucid-deps/install/lib/python2.7/codecs.py", line 674, in read
    File "/home/tom/ab/x64lucid-deps/install/lib/python2.7/codecs.py", line 480, in read
    UnicodeDecodeError: 'utf8' codec can't decode byte 0x9c in position 1: invalid start byte

    Windows-8-6.2.9200
    Ren'Py 6.99.12.4.2187


    라고 trace txt가 뜨네요

  • leta 2017.04.02 00:38  댓글주소  수정/삭제  댓글쓰기

    말씀해주신대로 했더니 lltq 창이뜨면서 에러가 나네요.. ㅠㅠ 이런경우는 어떻게하죠..?

    • 우분투 사용 10년째 Moordev 2017.04.02 22:36 신고  댓글주소  수정/삭제

      에러 메시지 내용을 알려주셔야 해결 해 들리 수 있을 것 같습니다.

      제가 했을 때와 지금은 버전 차이도 많이 나고 LLTQ가 워낙 낮은 버전의 렌파이를 이용한 게임이라 호환 문제가 많이 발생합니다.