当前位置:首页 » 安卓系统 » android获取视频时长

android获取视频时长

发布时间: 2023-07-09 06:24:17

⑴ android mediaplayer 可以设置播放时间吗

MediaPlayer (1) 当一个MediaPlayer对象被创建或者调用reset()方法之后,它处于空闲状态,调用release()方法后处于结束状态 1,一个MediaPlayer对象调用了reset()方法后,再调用其它方法可能会触发OnErrorListener.onError()事件,未调用reset()方法则不会触发 2,当Mediaplayer对象不再被使用时,最好调用release()方法对其进行释放,使其处于结束状态,此时它不能被使用 3,Mediaplayer对象被创建时(调用构造方法)处于空闲状态,若使用create()方法创建后则处于准备状态。 (2) 一般情况下,一些常用的播放控制操作可能因为音频、视频的格式不被支持或者质量较差以及流超时,也有可能由于开发者的疏忽使得Mediaplayer对象处于无效状态等而导致错误。此时可通过注册setOnErrorListener方法实现监控。如果发生了错误,Mediaplayer对象将处于多雾状态,可以使用reset()方法来回复错误。 (3) 任何Mediaplayer对象都必须先处于准备状态,然后才开始播放 (4) 要开始播放Mediaplayer对象都必须成和陵卖功调用start()方法,可通过isPlaying()方法来检测是否正在播放 (5) 当Mediaplayer对象在播放时,可以进行暂停和停止操作,pause()方法暂停播放,stop()方法停止播放。处于暂停暂停时可通过start()方法恢复播放,但是处于停止状态时则必须先调用prepare()方法使其处于准备状态,再调用start()方法。 主要方法: Mediaplayer:构造方法 create: 创建一个要播放的多媒体 getCurrentPosition:得到当前播放位置 getDuration: 得到文件的时间 prepare: 准备(同唤逗步) prepareAsync:准备(异步) seekTo: 指定播放的位置(以毫秒为单位) setAudioStreamType: 设置流媒体的类型 setDataSource: 设置数据来源 setDisplay: 设置用SurfaceHolder来显示多媒体 setOnBufferingUpdateListener: 网络流媒体的缓冲监听 setOnErrorListener: 设置错误信息监听 setOnVideoSizeChangedListener:视频尺寸监听 setScreenOnWhilePlaying: 设置是否使用SurfaceHolder来显示 setVolume: 设置音量 //获取sd卡上的音频文件 setDataSource(“/sdcard/test.mp3”); //装载资源中的音乐 MediaPlayer.create(Activity01.this,R.raw.test); //目前存在问题,不能循环解析出音频文件 原因:.android_secure文件夹受保护,无法获取汪姿里面的文件信息 播放视频 相关类:VideoView 方法说明: getBufferPercentage:得到缓冲的百分比 getCurrentPosition:得到当前播放位置 getDuration:得到视频文件的时间 resolveAdjustedSize:调整视频显示大小 setMediaController:设置播放控制器模式(播放进度条) setOnCompletionListener:当视频文件播放完时触发事件 setVideoPath:设置视频源路径 setVideoURI:设置视频源地址 录音 相关类:MediaRecorder 方法说明: MediaRecorder:构造方法 getMaxAmplitude:得到最大幅度 setAudioEncoder:设置音频编码 setAudioSource:设置音频源 setCamera:设置摄像机 setMaxDuration:设置最长录音时间 setMaxFileSize:设置文件的最大尺寸 setOutputFile:设置输出文件 setOutputFormat:设置输出文件格式 setPreviewDisplay:设置预览 setVideoEncoder:设置视频编码 setVideoFrameRate:设置视频帧的频率 setVideoSize:设置视频的宽度和高度(分辨率) setVideoSource:设置视频源 File类下的方法: public static File createTempFile(String prefix, String suffix, File directory) Creates an empty temporary file in the given directory using the given prefix and suffix as part of the file name. 系统会自动在prefix和suffix之间加上一些数字来构建完整的文件名 实现录音的一般步骤: 1, 实例化MediaRecorder mr,调用构造方法 2, 初始化mr:mr.setAudioSource(MIC)/setVideoSource(CAMERA) 3, 配置DataSource:设置输出文件格式/路径,编码器等 4, 准备录制:mr.prepare() 5, 开始录制:mr.start() 6, 停止录制:mr.stop() 7, 释放资源:mr.release() 注:2,3不可调换顺序 添加许可: <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.RECORD_AUDIO"> 相机设置 相关类:Camera,它是专门用来连接和断开相机服务的类 Camera的几个事件: Camera.AutoFocusCallback: 自动调焦功能 Camera.ErrorCallback: 错误信息捕捉 Camera.Parameters: 相机的属性参数 Camera.PictureCallback: 拍照、产生图片时触发 Camera.PreviewCallback: 相机预览设置 Camera.ShutterCallback: 快门设置 Camera.Size: 图片的尺寸 Camera类没有构造方法,可通过open()方法来打开相机设备 Camera类的方法介绍: autoFocus: 设置自动对焦 getParameters: 得到相机参数 open: 启动相机服务 release: 释放相机服务 setParameters: 设置参数 setPreviewDisplay:设置预览 startPreview: 开始预览 stopPreview: 停止预览 takePicture: 拍照 注:takePicture方法要实现3个回调函数作为它的三个参数:Camera.ShutterCallback(快门),和两个Camera.Picture.Callback(图像数据)。 需要许可 <uses-permission android:name="android.permission.CAMERA" /> 若要将图片存储至sd卡中,则需要sd卡读写许可 目前存在问题:只能拍照一次,不能重新回到预览界面 闹钟设置 相关类:AlarmManager,它是专门用来设定在某个指定的时间去完成指定的事件。AlarmManager提供了访问系统警报的服务,只要在程序中设置了警报服务,AlarmManager就会通过onReceive()方法去执行这些事件,就算系统处于待机状态,同样不会影响运行。可通过Context.getSystemService(ALARM_SERVICE)方法来获得该服务。 方法说明: cancel: 取消AlarmManager服务 set: 设置AlarmManager服务 setInexactRepeating:设置不精确周期 setRepeating:设置精确周期 setTimeZone:设置时区 注:需创建一个BroadcastReceiver的子类,并覆盖onReceive()方法 铃声设置 系统自带的铃声都放在/system/medio/audio/文件夹中 铃音类型: TYPE_RINGTONE(来电铃音),TYPE_ALARM,TYPE_NOTIFICATION 相关类:RingtoneManager 方法介绍: getActualDefaultRingtoneUri:取得指定类型的铃声 getCursor:返回所有可用铃声的游标 getDefaultType:得到指定URI默认的铃声类型 getRingtone getRingtonePosition:得到铃声位置 getRingtoneUri getValidRingtoneUri:得到一个可用铃声的URI isDefault:得到指定的Uri是否为默认的铃声 setActualDefaultRingtoneUri:设置默认的铃声 获取的Cursor共有4列,列名依次为:_id,title,”content://media/internal/audio/media”,title_key 以设置手机铃音为例: if (isFolder(strRingtongFolder)) {//如果不存在该文件夹则创建一个 // 打开系统铃声设置 Intent intent = new Intent( RingtoneManager.ACTION_RINGTONE_PICKER); intent.putExtra(RingtoneManager.EXTRA_RINGTONE_PICKED_URI, true); // 类型为来电ringtong intent.putExtra(RingtoneManager.EXTRA_RINGTONE_TYPE, RingtoneManager.TYPE_RINGTONE); // 设置显示的题目 intent.putExtra(RingtoneManager.EXTRA_RINGTONE_TITLE, "设置来电的铃声"); // 当设置完成之后返回到当前的activity startActivityForResult(intent, RingtongButton); } 然后复写onActivityResult(int requestCode, int resultCode, Intent data)方法,resultCode就是点击设置dialog的按钮编号,需要判断是否点击了确认按钮 if (resultCode != RESULT_OK) { return; } try { // 得到我们选择的铃声 Uri pickedUri = data .getParcelableExtra(RingtoneManager.EXTRA_RINGTONE_PICKED_URI); // 将我们选择的铃声选择成默认 if (pickedUri != null) { RingtoneManager.setActualDefaultRingtoneUri( Media_RingTongActivity.this, RingtoneManager.TYPE_RINGTONE, pickedUri); } } catch (Exception e) { e.printStackTrace(); }

⑵ android中怎么用SeekBar控制视频播放的进度

android中用SeekBar控制视频播放的进度其实现方法如下:

1:第一个类是自定义的一个类 也就是SeekBar上方会跟随其一块移动的控件,其实非常简单的一个类

package com.example.textmovebyseekbar;

import android.content.Context;
import android.util.AttributeSet;
import android.view.ViewGroup;

//import android.widget.AbsoluteLayout;

public class TextMoveLayout extends ViewGroup {

public TextMoveLayout(Context context) {
super(context);
// TODO Auto-generated constructor stub
}

public TextMoveLayout(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
// TODO Auto-generated constructor stub
}

public TextMoveLayout(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
}

@Override
protected void onLayout(boolean changed, int l, int t, int r, int b) {
// TODO Auto-generated method stub

}

}
?

2: 第二类就是MainActivity了,代码很简单!
package com.example.textmovebyseekbar;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.ViewGroup;
import android.widget.SeekBar;
import android.widget.TextView;

public class MainActivity extends Activity {

private SeekBar seekbar = null;

private String startTimeStr = "19:30:33";

private String endTimeStr = "21:23:21";

private TextView text, startTime, endTime;

/**
* 视频组中第一个和最后一个视频之间的总时长
*/
private int totalSeconds = 0;

/**
* 屏幕宽度
*/
private int screenWidth;

/**
* 自定义随着拖动条一起移动的空间
*/
private TextMoveLayout textMoveLayout;

private ViewGroup.LayoutParams layoutParams;
/**
* 托动条的移动步调
*/
private float moveStep = 0;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.video_fast_search);
screenWidth = getWindowManager().getDefaultDisplay().getWidth();
text = new TextView(this);
text.setBackgroundColor(Color.rgb(245, 245, 245));
text.setTextColor(Color.rgb(0, 161, 229));
text.setTextSize(16);
layoutParams = new ViewGroup.LayoutParams(screenWidth, 50);
textMoveLayout = (TextMoveLayout) findViewById(R.id.textLayout);
textMoveLayout.addView(text, layoutParams);
text.layout(0, 20, screenWidth, 80);
/**
* findView
*/
seekbar = (SeekBar) findViewById(R.id.seekbar);
startTime = (TextView) findViewById(R.id.start_time);
endTime = (TextView) findViewById(R.id.end_time);
/**
* setListener
*/
seekbar.setOnSeekBarChangeListener(new OnSeekBarChangeListenerImp());

searchVideos();

}

public void searchVideos() {
startTime.setText(startTimeStr);
endTime.setText(endTimeStr);
text.setText(startTimeStr);
totalSeconds = totalSeconds(startTimeStr, endTimeStr);
seekbar.setEnabled(true);
seekbar.setMax(totalSeconds);
seekbar.setProgress(0);
moveStep = (float) (((float) screenWidth / (float) totalSeconds) * 0.8);

}

private class OnSeekBarChangeListenerImp implements
SeekBar.OnSeekBarChangeListener {

// 触发操作,拖动
public void onProgressChanged(SeekBar seekBar, int progress,
boolean fromUser) {
text.layout((int) (progress * moveStep), 20, screenWidth, 80);
text.setText(getCheckTimeBySeconds(progress, startTimeStr));
}

// 表示进度条刚开始拖动,开始拖动时候触发的操作
public void onStartTrackingTouch(SeekBar seekBar) {

}

// 停止拖动时候
public void onStopTrackingTouch(SeekBar seekBar) {
// TODO Auto-generated method stub
}
}

/**
* 计算连个时间之间的秒数
*/

private static int totalSeconds(String startTime, String endTime) {

String[] st = startTime.split(":");
String[] et = endTime.split(":");

int st_h = Integer.valueOf(st[0]);
int st_m = Integer.valueOf(st[1]);
int st_s = Integer.valueOf(st[2]);

int et_h = Integer.valueOf(et[0]);
int et_m = Integer.valueOf(et[1]);
int et_s = Integer.valueOf(et[2]);

int totalSeconds = (et_h - st_h) * 3600 + (et_m - st_m) * 60
+ (et_s - st_s);

return totalSeconds;

}

/**
* 根据当前选择的秒数还原时间点
*
* @param args
*/

private static String getCheckTimeBySeconds(int progress, String startTime) {

String return_h = "", return_m = "", return_s = "";

String[] st = startTime.split(":");

int st_h = Integer.valueOf(st[0]);
int st_m = Integer.valueOf(st[1]);
int st_s = Integer.valueOf(st[2]);

int h = progress / 3600;

int m = (progress % 3600) / 60;

int s = progress % 60;

if ((s + st_s) >= 60) {

int tmpSecond = (s + st_s) % 60;

m = m + 1;

if (tmpSecond >= 10) {
return_s = tmpSecond + "";
} else {
return_s = "0" + (tmpSecond);
}

} else {
if ((s + st_s) >= 10) {
return_s = s + st_s + "";
} else {
return_s = "0" + (s + st_s);
}

}

if ((m + st_m) >= 60) {

int tmpMin = (m + st_m) % 60;

h = h + 1;

if (tmpMin >= 10) {
return_m = tmpMin + "";
} else {
return_m = "0" + (tmpMin);
}

} else {
if ((m + st_m) >= 10) {
return_m = (m + st_m) + "";
} else {
return_m = "0" + (m + st_m);
}

}

if ((st_h + h) < 10) {
return_h = "0" + (st_h + h);
} else {
return_h = st_h + h + "";
}

return return_h + ":" + return_m + ":" + return_s;
}
}

3: 接下来这个就是布局文件了,其中会用到一些色值!

<?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:background="@color/bg_whitef5"
android:orientation="vertical" >

<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >

<com.example.textmovebyseekbar.TextMoveLayout
android:id="@+id/textLayout"
android:layout_width="fill_parent"
android:layout_height="40dp" />

<SeekBar
android:id="@+id/seekbar"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:focusable="true"
android:maxHeight="4dp"
android:minHeight="4dp"
android:paddingLeft="5dp"
android:paddingRight="5dp"
android:progressDrawable="@drawable/po_seekbar"
android:thumb="@drawable/seekbar_thumb" />
</LinearLayout>

<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content" >

<TextView
android:id="@+id/start_time"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_marginLeft="14dp"
android:textColor="@color/bg_lin_95" />

<TextView
android:id="@+id/end_time"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_marginRight="14dp"
android:textColor="@color/bg_lin_95" />
</RelativeLayout>

</LinearLayout>

4: android:progressDrawable="@drawable/po_seekbar"这句会引用一个xml文件

<?xml version="1.0" encoding="utf-8"?>
<layer-list
xmlns:android="http://schemas.android.com/apk/res/android">
<item android:id="@*android:id/background">
<shape>
<solid android:color="#c6c6c6" />
</shape>
</item>
<item android:id="@*android:id/secondaryProgress">
<clip>
<shape>
<solid android:color="#c6c6c6" />
</shape>
</clip>
</item>
<item android:id="@*android:id/progress">
<clip>
<shape>
<solid android:color="#06a7fa" />
</shape>
</clip>
</item>
</layer-list>

5:android:thumb="@drawable/seekbar_thumb"也会引用一个xml文件 这其中又有用到两张图片

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

<item android:drawable="@drawable/video_fast_search_nomal" android:state_focused="true" android:state_pressed="false"/>
<item android:drawable="@drawable/video_fast_search_press" android:state_focused="true" android:state_pressed="true"/>
<item android:drawable="@drawable/video_fast_search_press" android:state_focused="false" android:state_pressed="true"/>
<item android:drawable="@drawable/video_fast_search_nomal"/>

</selector>

⑶ android获取视频每一帧

本周给大家分享如何获取视频的每一帧的信息,说到这个那就得看我们的谷歌官方给我们的提供的api接口类:MediaMetadataRetriever,这个类是提供给我们用来获取视频信息的,
官方文档:
https://developer.android.google.cn/reference/android/media/MediaMetadataRetriever
通过文档我们知道,我们可以通过它提供的extractMetadata()方法获取视频基本信息,
例如:视频宽、高,时长,作者等,还有通过getFrameAtTime()方法获取对应时长位置的视频帧信息,返回的是一个bitmap对象
通过实践知道,这个方法好是好,但是获取视频帧的速度太慢了,我自己做的实验是,获取一个4分多钟的视频,每隔10秒取一帧,开了4个线程去取,时间大概在10秒左右,这样对于我们来说是不可以忍受的,所以最后在github上找到了一个很好的库推荐给大家:
https://github.com/wseemann/FFmpegMediaMetadataRetriever
这个库是基于ffmpeg实现的,同样的实验获取视频帧信息的速度在1秒左右,只开了一个线程,ffmpeg还是依旧的强大啊。
通过本周的学习,自己对于ffmpeg是越来越赶兴趣了,所以买了一本书来研究一下,但是本书讲的都是c语言,所以没办法又把我大学学习的c语言的书找了出来,继续开始着自己的爬坑之旅。

⑷ 【Android音视频】MediaMetadataRetriever使用

MediaMetadataRetriever是Android原生提供的获取音视频文件信息的一个类,我们可以通过这个类的相关方法获取一些基本信息,如视频时长、宽高、帧率、方向、某一帧的图片等。

我们可以通过MediaMetadataRetriever的extractMetadata(int keyCode)的方法获取一些视频的基本信息,以下列出一些常用的:

可以通过getFrameAtTime(long timeUs)获取某一时刻附近的帧图片;API>=28,可以准确获取帧图片,相关方法getFrameAtIndex(...);获取帧图可以应用在 视频封面图 视频裁剪的缩略图 等。

MediaMetadataRetriever还是比较常用的,以上只是简略的列出了MediaMetadataRetriever的一些用法,具体可自行查阅源文件。

⑸ Android中如何截获第三方媒体播放器中正在播放的音乐或视频的当前播放时间进度和总时间求高手指点

java">//音乐的总长卖滑度
intmax=media.getDuration();
//获取吵配胡当前音乐播放升拦位置
intcurrent=media.getCurrentPosition();

⑹ Android录制视频,可限制时长,限大小

Android 录制视频:

public static voidrecordVideo(Context context, intlimit_time, intsize) {    

    Intent intent =newIntent();

    intent.setAction(MediaStore. ACTION_VIDEO_CAPTURE );

    intent.putExtra(MediaStore. EXTRA_VIDEO_QUALITY ,1);

    intent.addCategory(Intent. CATEGORY_DEFAULT );

    if(size !=0) {        

      //大小限制是long型,int 型无效,所以后边要写一个L

        intent.putExtra(MediaStore. EXTRA_SIZE_LIMIT ,size *1024*1024L);//限制录制大小(10M=10 * 1024 * 1024L)

    }

    if(limit_time !=0) {      

          intent.putExtra(MediaStore. EXTRA_DURATION_LIMIT ,limit_time);//限制录制时间(10秒=10)

    }    

    File videoFile =createVideoFile(context);

    if(videoFile !=null) {        

        intent.putExtra(MediaStore. EXTRA_OUTPUT ,Uri.fromFile(videoFile));

        context.startActivityForResult(intent, CAPTURE_VIDEO_CODE );

    }

}

⑺ uc浏览器Android版,如何缓存<1min的短视频

不是所有的手机视频都能使用uc浏览器缓存的,微博视频来说,直接发布的秒拍是不可以缓存只能在线观看的,如果是通过秒拍的软件或者哔哩哔哩动画的软件等分享到微博的就可以用uc缓存。

如果你要下载的视频是通过其他的视频软件比如秒拍app发布的,就可以下载,这类视频的正文中有一个视频图标。点击该图标进入秒拍视频界面。

进入秒拍后,右上方有分享按钮(“…”图标),此时出现菜单,选择复制链接,复制链接后进入uc浏览器,长按粘贴链接,下面出现粘贴并进入,进入后uc浏览器界面显示视频。

中间的视频播放小窗口出现下载按钮,点击下载按钮后会出现添加到缓存任务,此时,点击手机屏幕左键出现“菜单—我的视频”,正在缓存中出现该视频。

打开秒拍视频后也可以采用直接浏览器打开的方式,同样点击分享图标,点击“浏览器打开”

对于不是秒拍的其他视频app,例如b站有的可以选择浏览器打开,选择uc浏览器打开,此时在uc界面显示其他网页,同样点击下载图标进行下载操作。

因为这种情况下很多视频名称无法自动识别,在视频很多的情况下,大家在已经缓存的视频中找到视频进行重命名,短按视频,出现重命名,修改名称。

如果是不需要从外部链接打开的视频,直接在uc上打开的视频,点开后是直接可以下载的,专辑是有下载菜单的,点击下载即可。很方便的。缓存完成是视频是.vdat格式的。

⑻ Android实现视频播放的几种方式

Android提供了常见的视频编码,解码机制,使用Android自带的MediaPlayer,MediaController等类可以很方便的实现视频播放的功能。支持的视频格式有MP4和3GP等。这些多媒体数据可以来自于Android应用的资源文件,也可以来自于外部存储器上的文件,甚至可以是来自于网络上的文件流。

1、MediaController+VideoView实现方式

这种方式是最简单的实现方式。VideoView继承了SurfaceView同时实现了MediaPlayerControl接口,MediaController则是安卓封装的辅助控制器,带有暂停,播放,停止,进度条等控件。通过VideoView+MediaController可以很轻松的实现视频播放、停止、快进、快退等功能。

布局文件如下:

使用此实现方式的步骤:

1.加载指定的视频文件

2.建立VideoView和MediaController之间的关联,这样就不需要自己去控制视频的播放、暂停等。让MediaController控制即可。

3.VideoView获取焦点。

2、MediaPlayer+SurfaceView+自定义控制器

虽然VideoView的实现方式很简单,但是由于是自带的封装好的类,所以无论是播放器的大小、位置以及控制都不受我们控制。

这种实现方式步骤如下:

1.创建MediaPlayer对象,并让它加载指定的视频文件。可以是应用的资源文件、本地文件路径、或者URL。

2.在界面布局文件中定义SurfaceView组件,并为SurfaceView的SurfaceHolder添加Callback监听器。

3.调用MediaPlayer对象的setDisplay(SurfaceHolder sh)将所播放的视频图像输出到指定的SurfaceView组件。

4.调用MediaPlayer对象的prepareAsync()或prepare()方法装载流媒体文件

5.调用MediaPlayer对象的start()、stop()和pause()方法来控制视频的播放。

在实现第二步之前需要先给surfaceHolder设置一个callback,callback的3个回调函数如下:

3、MediaPlayer+SurfaceView+MediaController

第二种实现方式使用的是自定义控件,MediaPlayer+SurfaceView也可以使用系统自带的MediaController控制器。

使用这个方式实现,布局文件只需一个SurfaceView即可,其他的控件都交给MediaController控制器,布局文件如下:

实际过程中推荐大家使用B站的播放器ijkplayer非常好用!

热点内容
开源库编译管理员 发布:2025-02-06 09:39:14 浏览:914
脸书怎么注册安卓 发布:2025-02-06 09:36:47 浏览:381
车用安卓导航无线打不开什么原因 发布:2025-02-06 09:27:50 浏览:790
安卓与苹果如何互相传送文件 发布:2025-02-06 09:27:40 浏览:26
华为服务器盘符如何分配 发布:2025-02-06 09:26:41 浏览:560
传奇h5源码下载 发布:2025-02-06 09:26:06 浏览:78
编译uclibc 发布:2025-02-06 09:09:04 浏览:152
用gcc编译16位汇编 发布:2025-02-06 09:06:07 浏览:823
什么低端安卓手机不卡 发布:2025-02-06 09:03:32 浏览:14
我的世界服务器卡领地 发布:2025-02-06 08:50:45 浏览:256