zoukankan      html  css  js  c++  java
  • 流媒体开发之--直播实现

           可可工作室出品:

    欢迎使用可可直播视频播放器:

    http://pan.baidu.com/share/link?shareid=3291150676&uk=4111208708

        网上大多数直播软件都会提供一个功能就是自定义,这个由于版本问题,而为了让用户看到自己想看的频道,可以让用户自己添加找到的源,然后进行播放,俗话说法不责众,这个功能是如何实现的呢,其实也是很简单的,无法就是记录下用户添加的数据,然后保存下来,这里主要用到了数据库,用户点击自己添加的源,程序会从数据库取出链接,例如http,rtsp等开头的流媒体链接,具体的实现如下,我们是在之前流媒体开发之--直播实现的基础上继续完善。

          首先就是设计一个布局,里面使用ListView来填充,custom.xml,内容如下:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >
        
        <TextView 
            android:id="@+id/custom_title"
            android:layout_width="match_parent"
            android:layout_height="30dp"
            android:text="直播"
            android:textSize="27sp"
            android:gravity="center"
            />
    
        <ListView 
            android:id="@+id/custom_list"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            ></ListView>
    </LinearLayout>
    


    我们同时还需要一个ListView的一个Item和一个foot用来显示添加的源和实现添加功能,内容如下:

    custom_list_item.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal" >
        
        <TextView 
            android:id="@+id/custom_list_item_name"
            android:layout_width="100dp"
            android:layout_height="wrap_content"
            android:singleLine="true"
            android:text="频道"
            />
    	<TextView 
    	    android:id="@+id/custom_list_item_url"
    	    android:layout_width="match_parent"
    	    android:layout_height="30dp"
    	    android:text="视频源链接"
    	    />
    </LinearLayout>


    custom_list_foot.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >
        <TextView 
            android:layout_width="match_parent"
            android:layout_height="30dp"
            android:text="点击此处添加视频源"
            android:textSize="25sp"
            />
    
    </LinearLayout>
    


    我上面只是使用TextView来显示,如果需要美化,可以添加ImageView来实现图文并茂,布局写完后,我们就要添加一个数据库用来记录添加的视频源,为了方便起见,我们还需要定义一个自定义视频内容格式的类,内容如下:

    CustomVideo.java

    package com.jwzhangjie.live.type;
    
    import java.io.Serializable;
    
    public class CustomVideo implements Serializable{
    
    	private static final long serialVersionUID = 2166585200370610099L;
    
    	private String name;
    	private String url;
    	public String getName() {
    		return name;
    	}
    	public void setName(String name) {
    		this.name = name;
    	}
    	public String getUrl() {
    		return url;
    	}
    	public void setUrl(String url) {
    		this.url = url;
    	}
    }
    

    DBHelper.java

    package com.jwzhangjie.live.db;
    
    import android.content.Context;
    import android.database.sqlite.SQLiteDatabase;
    import android.database.sqlite.SQLiteDatabase.CursorFactory;
    import android.database.sqlite.SQLiteOpenHelper;
    
    public class DBHelper extends SQLiteOpenHelper{
    
    	public static final String DB_NAME = "custom.sqlite";
    	public static final String TABLE_NAME_VIDEO = "custom";
    	public static final String CAMERA_SQL = "CREATE TABLE video ('_id' INTEGER PRIMARY KEY  AUTOINCREMENT, 'name' VARCHAR, 'url' VARCHAR)";
    	public static int DB_VERSION = 1;
    	public DBHelper(Context context, String name, CursorFactory factory,
    			int version) {
    		super(context, DB_NAME, null, DB_VERSION);
    	}
    
    	@Override
    	public void onCreate(SQLiteDatabase db) {
    		db.execSQL(CAMERA_SQL);
    	}
    
    	@Override
    	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    		
    	}
    
    }
    

    当然有这个还不行,我们还需要创建一个实现数据库各种操作的类,定义如下:

    package com.jwzhangjie.live.utils;
    
    import java.util.ArrayList;
    import java.util.List;
    
    import android.content.ContentValues;
    import android.content.Context;
    import android.database.Cursor;
    import android.database.sqlite.SQLiteDatabase;
    
    import com.jwzhangjie.live.db.DBHelper;
    import com.jwzhangjie.live.type.CustomVideo;
    
    public class DBUtils {
    
    	private static DBHelper mDbHelper;
    	public DBUtils(Context context){
    		mDbHelper = new DBHelper(context);
    	}
    	
    	/**
    	 * insert custom video
    	 */
    	public void insertCustomVideo(CustomVideo customVideo){
    		SQLiteDatabase dbDatabase = null;
    		try {
    			dbDatabase = mDbHelper.getWritableDatabase();
    			if (dbDatabase == null) {
    				return;
    			}
    			ContentValues contentValues = new ContentValues();
    			contentValues.put("name", customVideo.getName());
    			contentValues.put("url", customVideo.getUrl());
    			dbDatabase.insertOrThrow("custom", null, contentValues);
    		} catch (Exception e) {
    		}finally{
    			dbDatabase.close();
    		}
    	}
    	
    	public void deleteOneCustomVideo(String name){
    		SQLiteDatabase dbDatabase = mDbHelper.getWritableDatabase();
    		try {
    			String sql = "DELETE FROM custom WHERE name = "+name;
    			dbDatabase.execSQL(sql);
    		} catch (Exception e) {
    		}finally{
    			dbDatabase.close();
    		}
    	}
    	
    	public List<CustomVideo> getAllCameras(){
    		List<CustomVideo> list = new ArrayList<CustomVideo>();
    		SQLiteDatabase dbDatabase = mDbHelper.getWritableDatabase();
    		String sql = "SELECT * FROM custom";
    		Cursor cursor = dbDatabase.rawQuery(sql, null);
    		while (!cursor.isLast()) {
    			cursor.moveToNext();
    			CustomVideo video = new CustomVideo();
    			video.setId(cursor.getInt(0));
    			video.setName(cursor.getString(1));
    			video.setUrl(cursor.getString(2));
    			list.add(video);
    		}
    		dbDatabase.close();
    		return list;
    	}
    	
    	public int getAllCustomVideoCount(){
    		SQLiteDatabase db = mDbHelper.getReadableDatabase();
    		Cursor cursor = db.rawQuery("select count(*) from custom", null);
    		cursor.moveToNext();
    		int count = cursor.getInt(0);
    		cursor.close();
    		db.close();
    		return count;
    	}
    	
    }
    


    做完上述事情后,我们就要设计显示界面操作,首先就是适配器的设计:

    package com.jwzhangjie.live.utils;

    import java.util.ArrayList; import java.util.List;

    import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase;

    import com.jwzhangjie.live.db.DBHelper; import com.jwzhangjie.live.type.CustomVideo;

    public class DBUtils {

     public static DBHelper mDbHelper;  public DBUtils(Context context){   mDbHelper = new DBHelper(context);  }    /**   * insert custom video   */  public void insertCustomVideo(CustomVideo customVideo){   SQLiteDatabase dbDatabase = null;   try {    dbDatabase = mDbHelper.getWritableDatabase();    if (dbDatabase == null) {     return;    }    ContentValues contentValues = new ContentValues();    contentValues.put("name", customVideo.getName());    contentValues.put("url", customVideo.getUrl());    dbDatabase.insertOrThrow("custom", null, contentValues);   } catch (Exception e) {   }finally{    dbDatabase.close();   }  }    public void deleteOneCustomVideo(String url){   SQLiteDatabase dbDatabase = mDbHelper.getWritableDatabase();   try {    String sql = "DELETE FROM custom WHERE url = "+url;    dbDatabase.execSQL(sql);   } catch (Exception e) {   }finally{    dbDatabase.close();   }  }    public List<CustomVideo> getAllCameras(){   List<CustomVideo> list = new ArrayList<CustomVideo>();   SQLiteDatabase dbDatabase = mDbHelper.getWritableDatabase();   String sql = "SELECT * FROM custom";   Cursor cursor = dbDatabase.rawQuery(sql, null);   while (!cursor.isLast()) {    cursor.moveToNext();    CustomVideo video = new CustomVideo();    video.setId(cursor.getInt(0));    video.setName(cursor.getString(1));    video.setUrl(cursor.getString(2));    list.add(video);   }   dbDatabase.close();   return list;  }    public int getAllCustomVideoCount(){   SQLiteDatabase db = mDbHelper.getReadableDatabase();   Cursor cursor = db.rawQuery("select count(*) from custom", null);   cursor.moveToNext();   int count = cursor.getInt(0);   cursor.close();   db.close();   return count;  }   }

    适配器设置完毕后,我们剩下显示界面了

    package com.jwzhangjie.live;
    
    import java.util.ArrayList;
    import java.util.List;
    
    import com.jwzhangjie.live.adapter.CustomVideoAdapter;
    import com.jwzhangjie.live.type.CustomVideo;
    import com.jwzhangjie.live.utils.DBUtils;
    
    import android.app.Activity;
    import android.content.Intent;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.AdapterView;
    import android.widget.AdapterView.OnItemClickListener;
    import android.widget.Button;
    import android.widget.EditText;
    import android.widget.ListView;
    
    public class CustomVideoList extends Activity implements OnItemClickListener, OnClickListener{
    
    	public ListView customVideoListView;
    	public CustomVideoAdapter listAdapter;
    	private List<CustomVideo> listVideos;
    	public Button addBtn;
    	public EditText addUrl;
    	DBUtils dbUtils = new DBUtils(this);
    	@Override
    	protected void onCreate(Bundle savedInstanceState) {
    		super.onCreate(savedInstanceState);
    		setContentView(R.layout.custom);
    		addBtn = (Button)findViewById(R.id.add);
    		addUrl = (EditText)findViewById(R.id.addurl);
    		customVideoListView = (ListView)findViewById(R.id.custom_list);
    		listAdapter = new CustomVideoAdapter(this);
    		customVideoListView.setAdapter(listAdapter);
    		customVideoListView.setOnItemClickListener(this);
    		addBtn.setOnClickListener(this);
    		addUrl.setText("http://74.82.62.53:1935/liverepeater/10.stream/playlist.m3u8");
    		int size = dbUtils.getAllCustomVideoCount();
    		if (size != 0) {
    			listVideos = dbUtils.getAllCameras();
    			listAdapter.setCustomVideoList(listVideos);
    		}else {
    			listVideos = new ArrayList<CustomVideo>();
    		}
    	}
    	@Override
    	protected void onResume() {
    		super.onResume();
    	}
    	@Override
    	public void onClick(View v) {
    		if (v == addBtn) {
    			if (addUrl.getText() != null) {
    				CustomVideo customVideo = new CustomVideo();
    				customVideo.setName("视频");
    				customVideo.setUrl(addUrl.getText().toString());
    				dbUtils.insertCustomVideo(customVideo);
    				listAdapter.insertCustomVideo(customVideo);
    				listVideos.add(customVideo);
    			}
    		}
    	}
    	@Override
    	public void onItemClick(AdapterView<?> parent, View view, int position,
    			long id) {
    		Intent intent = new Intent();
    		intent.setClass(CustomVideoList.this, JieVideoPlayer.class);
    		intent.putExtra("path", listVideos.get(position).getUrl());
    		startActivity(intent);
    	}
    	
    
    }
    


    效果如下:

    点击你选择的视频也能够播放视频,自定义功能就这些。

    欢迎使用可可直播视频播放器:

    http://pan.baidu.com/share/link?shareid=3291150676&uk=4111208708

  • 相关阅读:
    C# 异常处理
    UIElement 的DesiredSize 和 RenderSize
    删除集合中满足条件的元素
    C# 中的Property
    C# readonly 与 const
    C# 实例化类的执行顺序
    C# volatile 与 lock
    双重检查加锁机制
    定位问题
    EBS部分表整理
  • 原文地址:https://www.cnblogs.com/pangblog/p/3260505.html
Copyright © 2011-2022 走看看