홈으로 홈으로 | 무료회원가입 | 아이디/비번찾기 | 즐겨찾기
추천음악방송메인홈1대1상담음악방송청취
okTrot(구독해주세요)
전통가요(구독해주세요)
뽕짝아가씨(구독해주세요)
음악가사 검색
온라이브스토어(앱다운로드)
온라이브(방송등록및청취)
비디오 베스트 50
금영노래방
TJ노래방
유튜브 동영상 다운로드
POP Player
신나는 고스톱
컴퓨터 오목
작은 음악다방
운.영.자.1대1.상담
FAQ\지원.프로그램
Q&A\고.객.지.원

자동러시 웹플레이어신청

보안∵서버∵쿠키
윈도우∵프레임
이미지∵배경
시간∵달력∵계산
상태바∵타이틀바
음악∵영상
폼∵전송∵테이블
키보드∵마우스
효과∵링크∵메뉴
Script∵php
기타
PHP 강좌
윈도우관련팁
웹관련팁
홈페이지제작팁
기본강좌
레지스트리
윈도우서버
리눅스서버
Android
Media Player를 이용한 음악 재생
1년 전
public class MusicPlayer extends ListActivity {
    private static final String MEDIA_PATH = new String("/sdcard/");
// ROOT 경로를 지정합니다.
    private List<String> songs = new ArrayList<String>();
    private MediaPlayer mp = new MediaPlayer();
    private int currentPosition = 0;
// 재생할 곡의 위치입니다.
            /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        updateSongList();
// SD카드로부터 파일 목록을 불러오는 역할을 합니다.
    }
}


위의 코드에서, 일일이 /sdcard/를 파일 경로에 넣어주는 불편함을 최소화하기 위해 MEDIA_PATH로 SD카드의 루트 경로를 지정해주었습니다. 그 아래에서는 songs라는 리스트를 생성해주고 있는데, 여기에 우리가 재생할 파일의 목록이 들어가게 됩니다. currentPosition은 ArrayList에서의 배열 인덱스값으로, 어떤 곡을 재생할지 선택해주는 역할을 합니다.

onCreate함수로 오게 되면, updateSongList() 메소드를 보실 수 있습니다. 이 updateSongList()메소드에서는 sd카드로부터 파일을 읽어들여 songs 리스트에 넣어 주는 역할을 합니다.

public void updateSongList() {
    File home = new File(MEDIA_PATH);
// home으로 sd카드의 root를 지정합니다.
    if (home.listFiles(new Mp3Filter()).length > 0) {
        for (File file : home.listFiles(new Mp3Filter())) {
            songs.add(file.getName());
// 재생목록 리스트에 파일 이름을 추가합니다.
        }
                    ArrayAdapter&;lt;String> songList = new ArrayAdapter<String>(this,
                R.layout.song_item, songs);
// ListView의 레이아웃 및 참조할 리스트를 설정합니다.
        setListAdapter(songList);
// ListView와 ArrayList를 연결합니다.
                }
}
여기에서 sd카드의 파일들을 하나씩 거쳐가면서 mp3 확장자를 가지고 있는 파일들을 찾아서 리스트에 넣어주게 됩니다.
이 부분은 저도 처음 보는 것이라 자세하게 설명하기가 어렵네요. 일단은 이 예제를 발전시켜서 다음 에제에서도 계속 써먹을테니, 이 쪽에 대해서 공부를 더 하게 되면 설명을 추가하도록 하겠습니다.

Mp3Filter 클래스는 다음과 같이 구성되어 있습니다.


위에서 보시면, ListView의 레이아웃으로 song_item을 추가해주는 것을 볼 수 있는데, song_item의 내용은 다음과 같습니다.

class Mp3Filter implements FilenameFilter {
    public boolean accept(File dir, String name) {
        return (name.endsWith(".mp3"));
    }}

<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_height="wrap_content" id="@+id/song_item_layout" android:layout_width="fill_parent" android:textSize="15px"/>


크게 어려운 것은 없고, 15px의 크기를 가지는 TextView입니다. 리스트에서 항목은 이곳에 지정된 레이아웃처럼 표시될 것입니다.

이제, 목록을 클릭하면 다음 곡을 재생할 수 있도록 만들어보겠습니다.
ListView의 OnListItemClick 메소드를 오버라이드하여 구현합니다.

protected void onListItemClick(ListView l, View v, int position, long id) {
    currentPosition = position;
    playSong(MEDIA_PATH + songs.get(position));
}

클릭한 항목의 index를 재생할 항목을 나타내는 currentPosition에 저장하고, playSong()메소드로 파일의 경로를 넘겨주면서 재생을 하게끔 되어있습니다. 아까 MEDIA_PATH에서 SD카드의 root 주소를 저장하고 있었고, 파일 이름을 담고 있는 songs리스트에서 선택한 항목을 받아오는 get()메소드를 통해 하나의 완성된 주소가 되어 playSong()메소드로 넘겨지게 됩니다.

ex)
두번째 항목을 선택한 경우
position : 1
currentPosition : 1
songs.get(position) : 13_piano_solo.mp3

private void playSong(String songPath) {
    try {
             mp.reset();
// mp객체를 초기화합니다.
        mp.setDataSource(songPath);
        mp.prepare();
        mp.start();
        Toast.makeText(this, "재생 : " + songPath, Toast.LENGTH_SHORT).show();
        TextView status = (TextView)findViewById(R.id.playStatus);
        status.setText("재생중 : " + songPath);
            
// 한 곡의 재생이 끝나면 다음 곡을 재생하도록 합니다.
        mp.setOnCompletionListener(new OnCompletionListener() {
                 public void onCompletion(MediaPlayer arg0) {
                nextSong();
            }
             });
         } catch (IOException e) {
        Toast.makeText(this, e.getMessage(), Toast.LENGTH_SHORT).show();
    }
}

playSong()메소드에서는 파일을 재생해주는 역할을 합니다.
reset()메소드를 통해 다른 곡을 재생할 수 있게끔 mp객체를 초기화시켜주고, 그 다음 과정들을 통해 객체를 초기화하고, 경로를 지정한 후 음악을 재생합니다.

setOnCompletionListener()를 통해, 한 음악이 끝났을 경우 다음 음악을 불러오는 기능을 제공합니다.

private void nextSong() {
    if (++currentPosition >= songs.size()) {
        
// 마지막 곡이 끝나면, 재생할 곡을 초기화합니다.
        currentPosition = 0;
        TextView status = (TextView)findViewById(R.id.playStatus);
        status.setText("준비됨");
    } else {
        
// 다음 곡을 재생합니다.
        Toast.makeText(getApplicationContext(), "다음 곡을 재생합니다.", Toast.LENGTH_SHORT).show();
        playSong(MEDIA_PATH + songs.get(currentPosition));
    }
}


만약, 한 곡의 재생이 끝나 다음 곡으로 넘어가야 하는데 현재 곡이 마지막일 경우는 재생을 멈추고 재생할 곡의 index를 나타내는 currentPosition을 0으로 초기화하고, 재생 상태를 나타내는 TextView에 "준비됨" 메시지를 표시합니다.
재생할 곡이 있다면, 다음 곡의 정보를 불러와 다시 playSong()메소드로 넘겨줌으로써 재생을 계속합니다.

완성된 소스는 다음과 같습니다.

package com.androidhuman.MusicPlayer;
import java.io.File;import java.io.FilenameFilter;
import java.io.IOException;import java.util.ArrayList;
import java.util.List;import android.app.ListActivity;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnCompletionListener;
import android.os.Bundle;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

public class MusicPlayer extends ListActivity {
    private static final String MEDIA_PATH = new String("/sdcard/");
// ROOT 경로를 지정합니다.
    private List<String> songs = new ArrayList<String>();
    private MediaPlayer mp = new MediaPlayer();
    private int currentPosition = 0;
// 재생할 곡의 위치입니다.
            /** Called when the activity is first created. */
    @Override    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        updateSongList();
// SD카드로부터 파일 목록을 불러오는 역할을 합니다.
    }      public void updateSongList() {
        File home = new File(MEDIA_PATH);
        if (home.listFiles(new Mp3Filter()).length > 0) {
            for (File file : home.listFiles(new Mp3Filter())) {
                songs.add(file.getName());
            }
                        ArrayAdapter<String> songList = new ArrayAdapter<String>(this,                    R.layout.song_item, songs);
            setListAdapter(songList);
                    }
    }
        
// List 아이템을 클릭했을 때의 event를 처리합니다.
    protected void onListItemClick(ListView l, View v, int position, long id) {
        currentPosition = position;
        playSong(MEDIA_PATH + songs.get(position));
    }
        private void playSong(String songPath) {
        try {
                 mp.reset();
            mp.setDataSource(songPath);
            mp.prepare();
            mp.start();
            Toast.makeText(this, "재생 : " + songPath, Toast.LENGTH_SHORT).show();
            TextView status = (TextView)findViewById(R.id.playStatus);
            status.setText("재생중 : " + songPath);
                
// 한 곡의 재생이 끝나면 다음 곡을 재생하도록 합니다.
            mp.setOnCompletionListener(new OnCompletionListener() {
                     public void onCompletion(MediaPlayer arg0) {
                    nextSong();
                }
                 });
             } catch (IOException e) {
            Toast.makeText(this, e.getMessage(), Toast.LENGTH_SHORT).show();
        }    }        private void nextSong() {
        if (++currentPosition >= songs.size()) {
            
// 마지막 곡이 끝나면, 재생할 곡을 초기화합니다.
            currentPosition = 0;
           TextView status = (TextView)findViewById(R.id.playStatus);
            status.setText("준비됨");
        } else {
            
// 다음 곡을 재생합니다.
            Toast.makeText(getApplicationContext(), "다음 곡을 재생합니다.", Toast.LENGTH_SHORT).show();
            playSong(MEDIA_PATH + songs.get(currentPosition));
        }
    }
}

class Mp3Filter implements FilenameFilter {
    public boolean accept(File dir, String name) {
        return (name.endsWith(".mp3"));
    }
}

main.xml 의 구성은 다음과 같습니다.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/playStatus"
android:gravity="center"
android:text="준비됨"
android:textSize="13pt"></TextView>

<ListView
android:id="@id/android:list"
android:layout_height="fill_parent"
android:layout_width="fill_parent"
android:layout_weight="1"
android:drawSelectorOnTop="false"
>
</ListView>

<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="SD카드에 음악이 없습니다!"
android:layout_gravity="center"
android:id="@+id/android:empty"></TextView>
</LinearLayout>


위의 구성을 보면, 맨 아래에 android:empty라는 id를 가진 TextView를 보실 수 있습니다.
이는, 만약 list에 표시할 항목이 하나도 없을 경우 표시되는 화면입니다.

android:empty라는 id는 안드로이드 자체에서 만들어져 있는 id이므로, id를 입력하면 해당 상황에 맞게끔 화면이 보이게 됩니다.
추천추천 : 92 추천 목록
번호 제목
1,314
 윈도 10 최신 업데이트 후 인터넷 속도의 저하가 발생할 때 조치 사항
1,313
 Autotuning level 해제 (윈도우비스타 이상 윈도우)인터넷 속도 빠르게 하는 방법
1,312
 윈도우에서 특정프로세스를 일괄 종료하는법
1,311
 MediaPlayer 클래스 사용법
1,310
 안드로이드에서 audio player 실행하기
1,309
 [Android] MediaPlayer 음악재생기 만들기
1,308
 Eclipse와 Android NDK 연동하기
1,307
 Android Sliding Drawer Functionality 안드로이드 슬라이딩 드로우 예제 sample
1,306
 Android Speech To Text
1,305
 Android WebPageLoader with progress-bar
1,304
 Android Text To Speech(TTS)
1,303
 Android Playing Audio from a web url
1,302
 Button height different from background height in Android image design
1,301
 Android Getting Started with Material Design
1,300
 Using toast inside timertask perfect
1,299
 네트워크 상태 [Android]
1,298
 Webview source [Android]
1,297
 공유 Intent [Android]
1,296
 intent uri 모음 [Android]
1,295
 http requestWebViewClient [Android]
1,294
 캐시 삭제
1,293
 캐시 지우기 [Android]
1,292
 바로풀어(수학 문제 질의응답 SNS) 에 사용된 오픈소스 라이브러리 [Android]
1,291
 Webviw [Android]
1,290
 오픈소스 라이브러리 모음 [Android]
1,289
 Android webview 개발시 알아둬야 할 것들 [Android]
1,288
 webview 동영상 재생 [Android]
1,287
 [Android] Webview 404 에러 처리
1,286
 [Android] webview ssl 문제
1,285
 [Android] Webview url 숨기기
1,284
 [Android] AlarmManager 일정시간 이벤트 실행
1,283
 안드로이드 오픈소스 끝판
1,282
 android studio DefaultHttpClient, HttpClient import 에러
1,281
 [Android] Webview 메소드
1,280
 안드로이드: 서비스 Service 예제
목록
추천음악방송
인기절정뽕짝파티
인기트로트모음
지루박디스코메들리
밤무대애창곡
전자올겐경음악
앵콜트로트
뽕짝아가씨
KBS가요무대
작은 음악다방
종합성인가요방
카바레 음악
트롯디스코팡팡
관광 메들리
트롯카페
가요감상실
추억의옛노래
스페셜가요광장
BillBoard Free
Dance&Remix
추천가요모음
경음악.전자올겐
스페셜음악여행
WOLRD POPs
K-POP\BillBoard
JP\CN
POP TOP BEST
K.R.노래방

추천가요\인기
F뮤직 인기\발라드
F뮤직 애창\트로트
트로트성인가요
인기가요
프리미엄 POP
경음악\기타
프리미엄 최신가요
프리미엄 성인가요
가요1번지(종합)
뮤직하우스
동요\연변\반주\기타
가요축제\트롯1번지
댄스\메들리\리믹스
카페\명상\경음악\기타
추천가요\POP\기타
최신가요\인기가요
뮤직트로트 부산광역시부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.