如何在我的Android应用程序中使用SoundCloud?

时间:2012-01-05 12:07:52

标签: android soundcloud

我想在我的Android应用中使用soundcloud,如下所示: 我想在带有网址的soundcloud播放器上播放一首歌。 我在webview中使用了follow代码,但它没有正确运行。 我怎样才能做到这一点? 感谢。

<iframe width=\"100%\" height=\"166\" scrolling=\"no\" frameborder=\"no\" src=\"http://w.soundcloud.com/player/?url=http%3A%2F%2Fapi.soundcloud.com%2Ftracks%2F31416027&amp;auto_play=false&amp;show_artwork=false&amp;color=ff7700\"></iframe>

4 个答案:

答案 0 :(得分:5)

您是否考虑过使用SoundCloud's official Java wrapper

答案 1 :(得分:2)

我也尝试过使用webview的嵌入式播放器解决方案,但这不起作用。

现在我正在使用Soundcloud Java API Wrapper,这很好用。 按照GitHub仓库中的说明实施API:https://github.com/soundcloud/java-api-wrapper

然后代码非常简单。您只需要客户端ID和客户端密钥,两者都必须在soundcloud开发人员网站上获取。

然后代码非常简单:

        String id = getResources().getString(R.string.sc_client_id);
        String secret = getResources().getString(R.string.sc_client_secret);
        ApiWrapper wrapper = new ApiWrapper(id,secret, null, null);

        try {
            //Only needed for user-specific actions;
            //wrapper.login("<user>", "<pass>");
            //HttpResponse resp = wrapper.get(Request.to("/me"));
            //Get a track
            HttpResponse trackResp = wrapper.get(Request.to("/tracks/60913196"));
            //Track JSON response OK?
            if(trackResp.getStatusLine().getStatusCode() == HttpStatus.SC_OK)
            {
                JSONObject trackJSON = new JSONObject(EntityUtils.toString(trackResp.getEntity()));
                //If track is streamable, fetch the stream URL (mp3-https) and start the MediaPlayer
                if(trackJSON.getBoolean("streamable"))
                {
                    HttpResponse streamResp = wrapper.get(Request.to("/tracks/60913196/stream"));
                    JSONObject streamJSON = new JSONObject(EntityUtils.toString(streamResp.getEntity()));
                    String streamurl = streamJSON.getString("location");
                    Log.i("SoundCloud", trackJSON.getString("streamable"));
                    Log.i("SoundCloud", streamurl);
                    m_soundcloudPlayer.stop();
                    m_soundcloudPlayer = new MediaPlayer();
                    m_soundcloudPlayer.setDataSource(streamurl);
                    m_soundcloudPlayer.prepare();
                    m_soundcloudPlayer.start();
                }

            }
        }
        catch (IOException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }catch (ParseException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        catch (JSONException e)
        {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

对象m_soundcloudPlayerandroid.media.MediaPlayer

答案 2 :(得分:1)

我遇到了同样的问题。我发现标准嵌入代码不起作用的原因是因为Android浏览器不支持HTML5音频编解码器。最好的镜头是我猜的官方包装,但我不知道该怎么做(只是一个业余爱好者)。

答案 3 :(得分:1)

//In Activity_layout.xml

 <LinearLayout
              android:layout_width="match_parent"
              android:layout_height="match_parent"
              android:orientation="vertical">
        <WebView android:id="@+id/webview"
                     android:layout_width="match_parent"
                     android:layout_height="wrap_content"
                     />

    </LinearLayout>



// In ActivityClass.java

    mSoundCloudPlayer =(WebView) findViewById(R.id.webview);

    String VIDEO_URL = "Set Your Embedded URL";

    String html = "<!DOCTYPE html><html> <head> <meta charset=\"UTF-8\"><meta name=\"viewport\" content=\"target-densitydpi=high-dpi\" /> <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\"> <link rel=\"stylesheet\" media=\"screen and (-webkit-device-pixel-ratio:1.5)\" href=\"hdpi.css\" /></head> <body style=\"background:black;margin:0 0 0 0; padding:0 0 0 0;\"> <iframe id=\"sc-widget " +
                                    "\" width=\"100%\" height=\"50%\"" + // Set Appropriate Width and Height that you want for SoundCloud Player
                                    " src=\"" + VIDEO_URL   // Set Embedded url
                                    + "\" frameborder=\"no\" scrolling=\"no\"></iframe>" +
                                    "<script src=\"https://w.soundcloud.com/player/api.js\" type=\"text/javascript\"></script> </body> </html> ";

            mSoundCloudPlayer.setVisibility(View.VISIBLE);
            mSoundCloudPlayer.getSettings().setJavaScriptEnabled(true);
            mSoundCloudPlayer.getSettings().setLoadWithOverviewMode(true);
            mSoundCloudPlayer.getSettings().setUseWideViewPort(true);
            mSoundCloudPlayer.loadDataWithBaseURL("",html,"text/html", "UTF-8", "");