|
|
|
@ -14,6 +14,7 @@ import android.widget.ImageView; |
|
|
|
|
import android.widget.LinearLayout; |
|
|
|
|
import android.widget.TextView; |
|
|
|
|
|
|
|
|
|
import androidx.annotation.NonNull; |
|
|
|
|
import androidx.annotation.Nullable; |
|
|
|
|
import androidx.constraintlayout.widget.ConstraintLayout; |
|
|
|
|
import androidx.lifecycle.Observer; |
|
|
|
@ -25,6 +26,8 @@ import com.blankj.utilcode.util.StringUtils; |
|
|
|
|
import com.blankj.utilcode.util.ToastUtils; |
|
|
|
|
import com.bumptech.glide.Glide; |
|
|
|
|
import com.bumptech.glide.request.RequestOptions; |
|
|
|
|
import com.chad.library.adapter.base.BaseQuickAdapter; |
|
|
|
|
import com.chad.library.adapter.base.listener.OnItemClickListener; |
|
|
|
|
import com.hjq.http.EasyHttp; |
|
|
|
|
import com.hjq.http.listener.OnHttpListener; |
|
|
|
|
import com.unionmed.unionmedtv.R; |
|
|
|
@ -38,6 +41,9 @@ import com.unionmed.unionmedtv.livedatas.LiveDataBus; |
|
|
|
|
import com.unionmed.unionmedtv.network.ApiResponse; |
|
|
|
|
import com.unionmed.unionmedtv.utils.CacheUtil; |
|
|
|
|
import com.unionmed.unionmedtv.utils.Constants; |
|
|
|
|
import com.unionmed.unionmedtv.utils.OnChildClickListener; |
|
|
|
|
|
|
|
|
|
import org.jetbrains.annotations.NotNull; |
|
|
|
|
|
|
|
|
|
import java.util.ArrayList; |
|
|
|
|
import java.util.HashMap; |
|
|
|
@ -104,13 +110,17 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
this.usetInfo = usetInfo; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//本地视频全屏数据
|
|
|
|
|
private String imgPath = ""; |
|
|
|
|
private String name = ""; |
|
|
|
|
private String localId = ""; |
|
|
|
|
private SurfaceView surfaceView = null; |
|
|
|
|
private boolean cameraDisabled = false; |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* idle 通话结束 |
|
|
|
|
* Calling 电话拨出 |
|
|
|
|
* BeCall 代接听 |
|
|
|
|
* BeCall 等待接听 |
|
|
|
|
* OnCall 已接通 |
|
|
|
|
*/ |
|
|
|
|
public enum CallStatus { |
|
|
|
@ -141,7 +151,32 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
tv_time = findViewById(R.id.tv_time); |
|
|
|
|
recyclerView = findViewById(R.id.recyclerView); |
|
|
|
|
recyclerView.setLayoutManager(new LinearLayoutManager(VideoCallActivity.this)); |
|
|
|
|
remoteAdapter = new RemoteAdapter(R.layout.item_remote_layout); |
|
|
|
|
remoteAdapter = new RemoteAdapter(R.layout.item_remote_layout, new OnChildClickListener() { |
|
|
|
|
@Override |
|
|
|
|
public <T> void onChildClick(View view, int position, T data) { |
|
|
|
|
RemoteBean newRemoteBean = new RemoteBean(); |
|
|
|
|
newRemoteBean.setPath(imgPath); |
|
|
|
|
newRemoteBean.setName(name); |
|
|
|
|
((RCRTCVideoView) surfaceView).setScalingType(RendererCommon.ScalingType.SCALE_ASPECT_FILL); |
|
|
|
|
newRemoteBean.setSurfaceView(surfaceView); |
|
|
|
|
newRemoteBean.setUserId(localId); |
|
|
|
|
newRemoteBean.setCameraDisabled(cameraDisabled); |
|
|
|
|
|
|
|
|
|
((FrameLayout) ((RemoteBean) data).getView()).removeAllViews(); |
|
|
|
|
RemoteBean remoteBean = (RemoteBean) data; |
|
|
|
|
imgPath = remoteBean.getPath(); |
|
|
|
|
name = remoteBean.getName(); |
|
|
|
|
localId = remoteBean.getUserId(); |
|
|
|
|
cameraDisabled = remoteBean.isCameraDisabled(); |
|
|
|
|
surfaceView = remoteBean.getSurfaceView(); |
|
|
|
|
surfaceView.setZOrderOnTop(false); |
|
|
|
|
clearViews(); |
|
|
|
|
addLocalView(surfaceView); |
|
|
|
|
remoteAdapter.getData().set(position, newRemoteBean); |
|
|
|
|
remoteAdapter.notifyDataSetChanged(); |
|
|
|
|
chageCamera(!cameraDisabled); |
|
|
|
|
} |
|
|
|
|
}); |
|
|
|
|
recyclerView.setAdapter(remoteAdapter); |
|
|
|
|
lin_put_through = findViewById(R.id.lin_put_through); |
|
|
|
|
lin_put_through.setOnClickListener(this); |
|
|
|
@ -157,6 +192,7 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
initIRongCallListener(); |
|
|
|
|
type = getIntent().getStringExtra("type"); |
|
|
|
|
targetId = getIntent().getStringExtra("targetId"); |
|
|
|
|
localId = targetId; |
|
|
|
|
groupId = getIntent().getStringExtra("groupId"); |
|
|
|
|
if (type.equals("1")) { |
|
|
|
|
if (!TextUtils.isEmpty(targetId)) { |
|
|
|
@ -170,8 +206,10 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
} |
|
|
|
|
getUserInfoByServer(targetId); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private long time = 0; |
|
|
|
|
Handler handler; |
|
|
|
|
|
|
|
|
|
private void reckonByTime() { |
|
|
|
|
handler = new Handler(); |
|
|
|
|
Runnable updateTask = new Runnable() { |
|
|
|
@ -193,10 +231,10 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
// 延迟执行任务
|
|
|
|
|
handler.postDelayed(updateTask, 1000); |
|
|
|
|
} |
|
|
|
|
public void initIRongCallListener() { |
|
|
|
|
RongCallClient.getInstance().setVoIPCallListener(new IRongCallListener() { |
|
|
|
|
|
|
|
|
|
private void addLocalView(SurfaceView view) { |
|
|
|
|
local.removeAllViews(); |
|
|
|
|
((RCRTCVideoView) view).setScalingType(RendererCommon.ScalingType.SCALE_ASPECT_FILL); |
|
|
|
|
local.addView(view); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -204,6 +242,10 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
local.removeAllViews(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public void initIRongCallListener() { |
|
|
|
|
RongCallClient.getInstance().setVoIPCallListener(new IRongCallListener() { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* 电话已拨出。 |
|
|
|
|
* 主叫端拨出电话后,通过回调 onCallOutgoing 通知当前 call 的详细信息。 |
|
|
|
@ -231,11 +273,13 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
currentStatus = CallStatus.OnCall; |
|
|
|
|
changeUi(null); |
|
|
|
|
RemoteBean remoteBean = new RemoteBean(); |
|
|
|
|
remoteBean.setUserId(targetId); |
|
|
|
|
remoteBean.setUserId(CacheUtil.getImUserAccount()); |
|
|
|
|
((RCRTCVideoView) localVideo).setScalingType(RendererCommon.ScalingType.SCALE_ASPECT_FILL); |
|
|
|
|
remoteBean.setSurfaceView(localVideo); |
|
|
|
|
remoteAdapter.addData(remoteBean); |
|
|
|
|
remoteBean.setPath(CacheUtil.getToken().getHeadImg()); |
|
|
|
|
remoteBean.setName(CacheUtil.getToken().getName()); |
|
|
|
|
remoteAdapter.addData(remoteBean); |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
@ -294,23 +338,28 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
@Override |
|
|
|
|
public void success(ImUserInfoBean imUserInfoBean) { |
|
|
|
|
if (userId.equals(targetId)) { |
|
|
|
|
surfaceView = remoteVideo; |
|
|
|
|
((RCRTCVideoView) remoteVideo).setScalingType(RendererCommon.ScalingType.SCALE_ASPECT_FILL); |
|
|
|
|
addLocalView(remoteVideo); |
|
|
|
|
imgPath = imUserInfoBean.getHeadImg(); |
|
|
|
|
name = imUserInfoBean.getName(); |
|
|
|
|
localId = targetId; |
|
|
|
|
} else { |
|
|
|
|
RemoteBean remoteBean = new RemoteBean(); |
|
|
|
|
remoteBean.setUserId(userId); |
|
|
|
|
((RCRTCVideoView) remoteVideo).setScalingType(RendererCommon.ScalingType.SCALE_ASPECT_FILL); |
|
|
|
|
remoteBean.setSurfaceView(remoteVideo); |
|
|
|
|
remoteAdapter.addData(remoteBean); |
|
|
|
|
remoteBean.setPath(imUserInfoBean.getHeadImg()); |
|
|
|
|
remoteBean.setName(imUserInfoBean.getName()); |
|
|
|
|
remoteAdapter.addData(remoteBean); |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public void fail() { |
|
|
|
|
if (userId.equals(targetId)) { |
|
|
|
|
surfaceView = remoteVideo; |
|
|
|
|
addLocalView(remoteVideo); |
|
|
|
|
} else { |
|
|
|
|
RemoteBean remoteBean = new RemoteBean(); |
|
|
|
@ -361,7 +410,8 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public void onRemoteCameraDisabled(String userId, boolean disabled) { |
|
|
|
|
if (userId.equals(targetId)) { |
|
|
|
|
if (userId.equals(localId)) { |
|
|
|
|
cameraDisabled = disabled; |
|
|
|
|
if (disabled) { |
|
|
|
|
local.setVisibility(View.GONE); |
|
|
|
|
iv_icon.setVisibility(View.VISIBLE); |
|
|
|
@ -493,9 +543,10 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
.api(new GetImUserInfoApi(CacheUtil.getToken().getToken(), userId)) |
|
|
|
|
.request(new OnHttpListener<ApiResponse<ApiResponse<ImUserInfoBean>>>() { |
|
|
|
|
@Override |
|
|
|
|
public void onSucceed(ApiResponse<ApiResponse<ImUserInfoBean>> result) { |
|
|
|
|
public void onHttpSuccess(ApiResponse<ApiResponse<ImUserInfoBean>> result) { |
|
|
|
|
if (null != result.getData() && result.getData().isInnerRequestSucceed() |
|
|
|
|
&& null != result.getData().getData()) { |
|
|
|
|
if (currentStatus != CallStatus.OnCall) { //等待接听状态
|
|
|
|
|
Glide.with(VideoCallActivity.this) |
|
|
|
|
.load(result.getData().getData().getHeadImg()) |
|
|
|
|
.apply(new RequestOptions() |
|
|
|
@ -508,6 +559,7 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
} else { |
|
|
|
|
tv_tip.setText("对方邀请您进行通话"); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if (usetInfo != null) { |
|
|
|
|
usetInfo.success(result.getData().getData()); |
|
|
|
|
} |
|
|
|
@ -520,9 +572,11 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public void onFail(Exception e) { |
|
|
|
|
public void onHttpFail(Exception e) { |
|
|
|
|
ToastUtils.showLong(e.getMessage()); |
|
|
|
|
LogUtils.e("用户信息失败", "失败:" + e); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -561,14 +615,36 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
iv_camera.setImageDrawable(getResources().getDrawable(R.mipmap.icon_camera_on)); |
|
|
|
|
tv_camera.setText("摄像头已开"); |
|
|
|
|
} |
|
|
|
|
if (localId.equals(CacheUtil.getImUserAccount())) {//本地大屏用户id==当前账号id
|
|
|
|
|
cameraDisabled = !lin_turn_off_camera.isSelected(); |
|
|
|
|
chageCamera(!cameraDisabled); |
|
|
|
|
} else { |
|
|
|
|
for (int i = 0; i < remoteAdapter.getData().size(); i++) { |
|
|
|
|
if (remoteAdapter.getData().get(i).getUserId().equals(targetId)) { |
|
|
|
|
if (remoteAdapter.getData().get(i).getUserId().equals(CacheUtil.getImUserAccount())) { |
|
|
|
|
remoteAdapter.getData().get(i).setCameraDisabled(!lin_turn_off_camera.isSelected()); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
remoteAdapter.notifyDataSetChanged(); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//本地视频图像显示
|
|
|
|
|
public void chageCamera(boolean cameraDisabled) { |
|
|
|
|
if (!cameraDisabled) { |
|
|
|
|
local.setVisibility(View.GONE); |
|
|
|
|
iv_icon.setVisibility(View.VISIBLE); |
|
|
|
|
Glide.with(VideoCallActivity.this) |
|
|
|
|
.load(imgPath) |
|
|
|
|
.apply(new RequestOptions() |
|
|
|
|
.placeholder(R.mipmap.rc_default_portrait) |
|
|
|
|
) |
|
|
|
|
.into(iv_icon); |
|
|
|
|
} else { |
|
|
|
|
local.setVisibility(View.VISIBLE); |
|
|
|
|
iv_icon.setVisibility(View.GONE); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
protected void onDestroy() { |
|
|
|
@ -577,4 +653,11 @@ public class VideoCallActivity extends BaseActivity implements View.OnClickListe |
|
|
|
|
handler.removeCallbacksAndMessages(null); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
|
public void onBackPressed() { |
|
|
|
|
if (RongCallClient.getInstance() != null && RongCallClient.getInstance().getCallSession() != null) { |
|
|
|
|
RongCallClient.getInstance().hangUpCall(RongCallClient.getInstance().getCallSession().getCallId()); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|