您好,登錄后才能下訂單哦!
小編給大家分享一下android如何實現仿QQ動態背景、視頻背景,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
效果如下:
如上圖類似效果圖:
1, 自定義視頻類 繼承VideoView
public class CustomVideoView extends VideoView { public CustomVideoView(Context context) { super(context); } public CustomVideoView(Context context, AttributeSet attrs) { super(context, attrs); } public CustomVideoView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { //我們重新計算高度 int width = getDefaultSize(0, widthMeasureSpec); int height = getDefaultSize(0, heightMeasureSpec); setMeasuredDimension(width, height); } @Override public void setOnPreparedListener(MediaPlayer.OnPreparedListener l) { super.setOnPreparedListener(l); } @Override public boolean onKeyDown(int keyCode, KeyEvent event) { return super.onKeyDown(keyCode, event); } }
MainActivity 中:
public class MainActivity extends AppCompatActivity implements View.OnClickListener { private CustomVideoView videoview; private Button btn_enter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); initView(); } /** * 初始化 */ private void initView() { btn_enter = (Button) findViewById(R.id.btn_enter); btn_enter.setOnClickListener(this); videoview = (CustomVideoView) findViewById(R.id.videoview); videoview.setVideoURI(Uri.parse("android.resource://"+getPackageName()+"/"+R.raw.shipin2)); //播放 videoview.start(); //循環播放 videoview.setOnCompletionListener(new MediaPlayer.OnCompletionListener() { @Override public void onCompletion(MediaPlayer mediaPlayer) { videoview.start(); mediaPlayer.setOnInfoListener(new MediaPlayer.OnInfoListener() { @Override public boolean onInfo(MediaPlayer mp, int what, int extra) { return false; } }); } }); } @Override public void onClick(View view) { switch (view.getId()){ case R.id.btn_enter: Toast.makeText(this,"登錄成功了",Toast.LENGTH_SHORT).show(); break; } } //返回重啟加載 @Override protected void onRestart() { super.onRestart(); initView(); } //防止鎖屏或者切出的時候,音樂在播放 @Override protected void onStop() { super.onStop(); videoview.stopPlayback(); } }
讀取視頻的問題: 把視頻放到和res/raw文件夾里面了
布局文件中:
<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" > <!--CustomVideoView 自定義視頻類的位置--> <application1.applicationlong.CustomVideoView android:id="@+id/videoview" android:layout_width="match_parent" android:layout_height="match_parent" /> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="top" android:orientation="vertical"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="38dp" android:layout_marginRight="38dp" android:layout_marginTop="70dp" android:orientation="vertical"> <EditText android:id="@+id/et_phone" android:layout_width="match_parent" android:layout_height="40dp" android:layout_gravity="center_vertical" android:background="@null" android:digits="0123456789" android:gravity="center_vertical" android:hint="請輸入手機號" android:inputType="number" android:maxLength="11" android:maxLines="1" android:paddingLeft="5dp" android:textColor="@android:color/white" android:textColorHint="@android:color/white" android:textSize="18sp"/> <View android:layout_width="match_parent" android:layout_height="1dp" android:layout_alignParentBottom="true" android:background="@color/black"/> <EditText android:id="@+id/et_pwd" android:layout_width="match_parent" android:layout_height="40dp" android:layout_marginTop="20dp" android:background="@null" android:gravity="center_vertical" android:hint="請輸入密碼" android:inputType="textPassword" android:maxLength="11" android:maxLines="1" android:paddingLeft="5dp" android:textColor="@android:color/white" android:textColorHint="@android:color/white" android:textSize="18sp"/> <View android:layout_width="match_parent" android:layout_height="1dp" android:layout_alignParentBottom="true" android:background="@color/black"/> </LinearLayout> <RelativeLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginLeft="23dp" android:layout_marginRight="23dp" android:orientation="horizontal"> <TextView android:id="@+id/tv_register" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="15dp" android:text="快速注冊" android:textColor="@color/green"/> <TextView android:id="@+id/tv_find_pwd" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentEnd="true" android:layout_alignParentRight="true" android:layout_alignParentTop="true" android:gravity="right" android:padding="15dp" android:text="忘記密碼?" android:textColor="@color/green"/> </RelativeLayout> <Button android:id="@+id/btn_enter" android:layout_width="match_parent" android:layout_height="45dp" android:layout_gravity="center_horizontal" android:layout_marginLeft="30dp" android:layout_marginRight="30dp" android:layout_marginTop="20dp" android:background="@color/darkseagreen" android:text="登錄" android:textColor="@color/white" android:textSize="18dp"/> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" android:paddingBottom="30dp" android:orientation="vertical"> <TextView android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="90dp" android:gravity="center" android:text="使用第三方登錄" android:textColor="@color/white" android:textSize="16dp" android:visibility="visible"/> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_horizontal" android:orientation="horizontal"> <ImageView android:id="@+id/iv_wechat" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="10dp" android:padding="10dp" android:src="@drawable/qq"/> <ImageView android:id="@+id/iv_qq" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="20dp" android:layout_marginTop="10dp" android:padding="10dp" android:src="@drawable/weixin"/> </LinearLayout> </LinearLayout> </FrameLayout>
注意:
視頻資源要添加res文件夾下創建raw文件夾
需要在onRestart()方法里重新加載視頻,防止退出返回時視頻黑屏
以上是“android如何實現仿QQ動態背景、視頻背景”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。