멀티미디어 재생(StreamingMedia) 가이드 프로그램은 디바이스 API 실행환경을 활용하여 하이브리드 앱을 개발 시 참고 및 활용될 수 있도록 구현된 전자정부 디바이스 API에 대한 가이드 앱으로써, 모바일 스마트 디바이스의 Streaming Media관련 기능을 JavaScript기반으로 구성 된 StreamingMedia DeviceAPI를 통하여 멀티미디어(동영상)을 실시간으로 볼수 있도록 내장 미디어 플레이어로 연동하는 기능을 지원한다.
본 가이드 프로그램의 주요 기능으로 웹 서버와 연동하여 멀티미디어 목록 조회, 멀티미디어 재생 등의 기능을 제공하고 있다.
구분 | 내용 |
---|---|
Local 디바이스 개발 환경 | 전자정부표준프레임워크 개발환경3.6, Android SDK API 23(version 6.0 Marshmallow) |
서버 사이드 개발 환경 | 전자정부표준프레임워크 개발환경3.6 |
Mash up Open API 연계 | N/A |
테스트 디바이스 | Galaxy S3, G5 |
테스트 플랫폼 | Android 2.3, Android 6.0 |
추가 라이브러리 적용 | N/A |
구분 | 내용 |
---|---|
지원 디바이스 및 플랫폼 | N/A |
크로스 도메인 사용 | 폰갭에서 특정 외부 도메인이나 외부 도메인의 하위 도메인을 사용해야할 경우, Res/xml/config.xml에서 <access origin=”” />에 외부 도메인 주소를 추가 설정해야 외부 도메인에 접속할 수 있다. |
라이선스 | N/A |
스트리밍 파일 포멧 | 본 가이드의 Streaming Media Plug-in은 Android의 내장 VideoView와 MediaPlayer 사용하므로 플레이 할 수 있는 미디어 제한사항 있다. 다음 링크로 각 Android별 지원하는 미디어의 포멧과 codec을 확인 할 수 있다. Android Supported Media Formats |
멀티미디어 재생(StreamingMedia) 디바이스API 가이드 프로그램은 스트리밍 미디어 목록보기, 미디어 재생(클릭 시 내장 미디어 플레이어 연동), 미디어 재생 횟수 업데이트 등의 기능으로 구성되어 있다.(관련기능 부분참조)
유형 | 대상소스명 | 비고 |
---|---|---|
Activity | kr.go.egovframework.hyb.streamingmediaapp.MainActivity | 멀티미디어 재생 API 가이드 프로그램 Activity Class |
CSS | assets/www/css/egovframwork/mbl/hyb/StreamingMedia.css | 멀티미디어 재생 API 가이드 프로그램 주요 Cascading Style Sheets |
IMAGE | assets/www/images/egovframwork/mbl/hyb/ | 멀티미디어 재생 API 가이드 프로그램 주요 Image 폴더 |
JS | assets/www/js/egovframwork/mbl/hyb/StreamingMediaAPI.js | 멀티미디어 재생 API 가이드 프로그램 주요 JavaScript |
RES | assets/www/res/ | 멀티미디어 재생 API 가이드 프로그램 주요 Resource 폴더 |
XML | AndroidManiFest.xml | 안드로이드 어플리케이션 설정 XML |
HTML | assets/www/StreamingMedia.html | 멀티미디어 재생 API 메인 페이지 |
HTML | assets/www/intro.html | 멀티미디어 재생 API Intro 페이지 |
HTML | assets/www/license.html | 멀티미디어 재생 API 라이센스 페이지 |
HTML | assets/www/overview.html | 멀티미디어 재생 API 기능설명 페이지 |
window.plugins.EgovInterface.request(url, params, onSuccess);
파라미터 | 설명 | 비고 |
---|---|---|
url | 웹서버로 요청 할 URI | 서버 URL 설정은 환경설정 참조 |
parames | 입력 파라미터 | json Object 타입으로 입력 |
onSuccess | POST Method에 대한 성공시 리턴되는 함수 | json타입 데이터 처리 |
window.plugins.streamingMedia.playVideo(resultURL, options);
파라미터 | 설명 | 비고 |
---|---|---|
URL | 멀티미디어 URL | |
options | 콜백 함수 설정등의 option 설정 |
유형 | 대상소스명 | 비고 |
---|---|---|
Controller | egovframework.hyb.mbl.stm.web.EgovStreamingMediaAPIController.java | 멀티미디어 재생 API 가이드 프로그램 Controller Class |
Service | egovframework.hyb.mbl.stm.service.EgovStreamingMediaAPIService.java | 멀티미디어 재생 API 가이드 프로그램 Service Class |
ServiceImpl | egovframework.hyb.mbl.stm.service.impl.EgovStreamingMediaAPIServiceImpl.java | 멀티미디어 재생 API 가이드 프로그램 ServiceImpl Class |
VO | egovframework.hyb.mbl.stm.service.StreamingMediaAPIVO.java | 멀티미디어 재생 API 가이드 프로그램 VO Class |
DAO | egovframework.hyb.mbl.stm.service.impl.StreamingMediaAPIDAO.java | 멀티미디어 재생 API 가이드 프로그램 Dao Class |
QUERY XML | resources/egovframework/sqlmap/hyb/mbl/stm/EgovStreamingMediaDeviceAPIGuide_SQL_xxx.xml | 멀티미디어 재생 API 가이드 프로그램 QUERY XML |
테이블명 | 테이블명(영문) | 비고 |
---|---|---|
미디어 | media | 미디어 정보 관리 |
파일상세정보 | file_detail_info | 파일의 상세정보 |
No | 컬럼ID | 컬럼명 | 타입 | 길이 | NULL | KEY |
---|---|---|---|---|---|---|
1 | SN | 일련번호 | NUMERIC | 6 | NotNull | pk |
2 | UUID | UUID | VARCHAR | 50 | NotNull | pk |
3 | MD_CODE | 확장자 | VARCHAR | 40 | Null | |
4 | MD_SJ | 파일명 | VARCHAR | 255 | Null | |
5 | USEYN | 사용유무 | VARCHAR | 1 | Null | |
6 | REVIV_CO | 재생횟수 | VARCHAR | 40 | Null | |
7 | FILE_SN | 파일상세정보 테이블의 일련번호 | NUMERIC | 20 | Null | fk |
No. | 컬럼 | 컬럼명 | 타입 | 길이 | Null | KEY |
---|---|---|---|---|---|---|
1 | FILE_SN | 파일연번 | NUMERIC | 20 | NotNull | pk |
2 | FILE_STRE_COURS | 파일저장경로 | VARCHAR | 2000 | Null | |
3 | STRE_FILE_NM | 저장파일명 | VARCHAR | 255 | Null | pk |
4 | ORIGNL_FILE_NM | 원파일명 | VARCHAR | 255 | Null | |
5 | FILE_EXTSN | 파일확장자 | VARCHAR | 20 | Null | |
6 | FILE_CN | 파일내용 | BLOB | Null | ||
7 | FILE_SIZE | 파일크기 | NUMERIC | 8 | Null |
멀티미디어 재생(Streaming Media) 디바이스API 가이드 프로그램에서 제공하는 멀티미디어 재생(실시간) 등의 기능을 활용하기 위하여 필요한 항목 및 그 환경 설정은 다음과 같다.
<!--전자정부 Interface 디바이스 API를 사용하기 위한 Phonegap Plugin 클래스--> <feature name="EgovInterfacePlugin" > <param name="android-package" value="kr.go.egovframework.hyb.plugin.EgovInterfacePlugin" /> </feature> <feature name="StreamingMedia"> <param name="android-package" value="com.hutchind.cordova.plugins.streamingmedia.StreamingMedia" /> </feature>
<!--전자정부 Interface 디바이스 API에서 사용하기 위한 서버경로 설정--> <?xml version="1.0" encoding="utf-8"?> <resources> <string name="SERVER_URL">http://192.168.100.222:8080/DeviceAPIGuideTotal_Web</string> </resources>
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" /> <permission android:name="kr.go.egovframework.hyb.streamingmediaapp.permission.C2D_MESSAGE" android:protectionLevel="signature" /> <uses-permission android:name="kr.go.egovframework.hyb.streamingmediaapp.permission.C2D_MESSAGE" />
<sqlMap resource="egovframework/sqlmap/hyb/mbl/stm/EgovStreamingMediaDeviceAPIGuide_SQL_[DB명].xml"/>
멀티미디어 재생(StreamingMedia) API 가이드 프로그램은 크게 미디어 목록 조회, 해당 미디어 재생(실시간) 및 재생횟수 업데이트 기능으로 구성되어 있다.
function fn_egov_medialist() { console.log(">> media List"); var url = "/stm/mediaInfoList.do"; var params = {}; fileSN =""; window.plugins.EgovInterface.request(url, params, function(jsondata) { resultJson = jsondata; if(resultJson.resultState == "OK"){ var strhtml=""; $(resultJson.resultSet).each(function(){ var sn = this.sn; var mdSj = this.mdSj; var revivCo = this.revivCo; var mdcode = this.mdCode; strhtml += '<li>'; strhtml += ' <a href="#" onclick="javascript:fn_egov_filelist_go(\'' + sn + '\')">'; strhtml += ' <h3>제목: ' + mdSj + '</h3>'; strhtml += ' <h3>파일타입: ' + mdcode + '</h3>'; strhtml += ' <h3>재생횟수: ' + revivCo + '</h3>'; strhtml += ' </a>'; strhtml += '</li>'; }); var theList = $('#theList'); theList.html(strhtml); $.mobile.changePage("#mediaInfo", "slide", false, false); theList.listview("refresh"); infoScroll.refresh(); }else{ $("#alert_dialog").click( function() { jAlert('데이터 전송 중 오류가 발생 했습니다.', '전송 오류', 'c'); }); } }, function(result){ alert("error > "+result); }); }
function fn_egov_filelist_go(input) { console.log(">>> sn: " + input); jConfirm('동영상을 재생하시겠습니까?', '알림', 'c', function(r) { if (r == true) { var url = "/stm/getMediaURL.do"; var params = {sn : input}; window.plugins.EgovInterface.request(url, params, function(jsondata) { resultJson = jsondata; if(resultJson.resultState == "OK"){ fn_egov_playMedia(resultJson.resultURL, input); console.log("RevivCo Update OK."); }else{ console.log("RevivCo Update Error."); } }, function(result){ alert("error > "+result); }); } }); }
function fn_egov_filelist_go(input) { jConfirm('동영상을 재생하시겠습니까?', '알림', 'c', function(r) { if (r == true) { var resultURL = server_url + "/stm/getMediaStreaming.do?sn=" + input; fn_egov_playMedia(resultURL, input); } }); } function fn_egov_playMedia(resultURL, input){ var options = { successCallback: function() { console.log("Video was closed without error."); $.mobile.changePage("#main", "slide", false, false); }, errorCallback: function(errMsg) { console.log("Error! " + errMsg); }, orientation: '' // 'landscape' }; fn_egov_updateMediaInfoRevivCo(input); window.plugins.streamingMedia.playVideo(resultURL, options); }
function fn_egov_updateMediaInfoRevivCo(inputSn){ var url = "/stm/updateMediaInfoRevivCo.do"; var params = {sn : inputSn}; console.log(">>> inputSn:" + inputSn); window.plugins.EgovInterface.request(url, params, function(jsondata) { resultJson = jsondata; if(resultJson.resultState == "OK"){ console.log("RevivCo Update OK."); }else{ console.log("RevivCo Update Error."); } }, function(result){ alert("error > "+result); }); }
Action | URL | Controller method | QueryID |
---|---|---|---|
미디어 목록 조회 | /stm/mediaInfoList.do | selectMediaInfoList | “streamingMediaAPIDAO.selectMediaInfoList” |
미디어 요청 | /stm/getMediaStreaming.do | getStreamMediaURL | “streamingMediaAPIDAO.selectMediaFileInfo” |
재생횟수 업데이트 | /stm/updateMediaInfoRevivCo.do | updateMediaInfoRevivCo | “streamingMediaAPIDAO.updateMediaInfoRevivCo” |
미디어 재생 확인 | 미디어 재생 (내장 플레이어 연동) | 미디어 재생 횟수 업데이트 |
---|---|---|
디바이스 어플리케이션에서 발생한 오류 내용 확인 및 디버깅을 위해서는 폰갭 프레임워크에서 제공하는 console.log를 이용할 수 있다. console.log 함수는 자바스크립트 구문에서 사용할 수 있는 디버그 코드로 이클립스 및 Xcode에서 확인 할 수 있다.
console.log의 작성 방법의 예시는 다음과 같다.
function fn_egov_network_check(doCheck) { console.log('DeviceAPIGuide fn_egov_network_check'); var networkState = navigator.network.connection.type; ... }
디버깅 코드가 실행 되면 아래와 같은 메시지를 개발도구의 콘솔 메시지 창에서 볼 수 있다.
멀티미디어 재생(Streaming Media) 디바이스 API 가이드 다운로드 : Click