X-Git-Url: http://47.100.26.94:8080/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fai%2Fsuanzi%2Frtmpclient%2FCameraView.java;h=e4bc71c3763610af2ed12604f66c15403fc1aded;hb=d1a43ff97228c10a4eaef604bd40eb8be3fcf8f6;hp=5ddcb5ef73e001f1377be2d9d2bbcd5fe2f042cd;hpb=6aa3850f260161c015474faf68165158165afea8;p=rtmpclient.git diff --git a/app/src/main/java/ai/suanzi/rtmpclient/CameraView.java b/app/src/main/java/ai/suanzi/rtmpclient/CameraView.java index 5ddcb5e..e4bc71c 100644 --- a/app/src/main/java/ai/suanzi/rtmpclient/CameraView.java +++ b/app/src/main/java/ai/suanzi/rtmpclient/CameraView.java @@ -3,6 +3,7 @@ package ai.suanzi.rtmpclient; import android.content.Context; import android.view.SurfaceHolder; import android.view.SurfaceView; +import android.widget.FrameLayout; import org.apache.log4j.Logger; @@ -15,6 +16,8 @@ public class CameraView extends SurfaceView implements SurfaceHolder.Callback { private Context mContext; private SurfaceHolder mHolder; private Callback mCallback; + private int width; + private int height; public CameraView (Context context, Callback cb) { super(context); @@ -24,15 +27,38 @@ public class CameraView extends SurfaceView implements SurfaceHolder.Callback { this.mCallback = cb; } + public void setLayout(int width, int heitht){ + this.height = heitht; + this.width = width; + gLogger.error("setLayout, screen size w: " + SCREEN_WIDTH + ", h:" + SCREEN_HEIGHT + ". preview size, w: " + width + ", h: " + height); + + float ratio = (float) height / width; // 3/4,,, 640x480 1008x1344 + FrameLayout.LayoutParams lp = (FrameLayout.LayoutParams)getLayoutParams(); + gLogger.error("ratio = " + ratio + ". xxx=" + (float)(SCREEN_HEIGHT / SCREEN_HEIGHT)); + if(ratio > (float)(SCREEN_HEIGHT / SCREEN_WIDTH) ){ + lp.width = SCREEN_HEIGHT * width / height; + lp.height = SCREEN_HEIGHT; + lp.leftMargin = (SCREEN_WIDTH - lp.width ) / 2; + lp.topMargin = 0; + } else { + lp.width = SCREEN_WIDTH; + lp.height = SCREEN_WIDTH * height / width; + lp.leftMargin = 0; + lp.topMargin = (SCREEN_HEIGHT - lp.height) / 2; + } + gLogger.error("width=" + lp.width + ", height=" + lp.height + ". leftMargin=" + lp.leftMargin + ", topMargin=" + lp.topMargin); + this.setLayoutParams(lp); + } + // SurfaceHolder.Callback implementation @Override public void surfaceCreated(final SurfaceHolder holder){ - gLogger.error("SurfacedCreated"); + gLogger.debug("SurfacedCreated, screen size w: " + SCREEN_WIDTH + ", h:" + SCREEN_HEIGHT + ". preview size, w: " + width + ", h: " + height); } @Override public void surfaceChanged(SurfaceHolder holder, int format, int widht, int height){ - gLogger.error("surfaceChanged"); + gLogger.debug("surfaceChanged"); mHolder = holder; mCallback.onSurfaceChanged(holder, format, widht, height); }