首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在cameraX预览中设置预览大小?

如何在cameraX预览中设置预览大小?
EN

Stack Overflow用户
提问于 2020-04-23 20:36:57
回答 2查看 10.9K关注 0票数 4

我试图在纵向模式下创建一个预览,我希望预览和屏幕一样宽,并垂直包装内容。但是,当我这样做时,我总是得到预览大小1200x 1200,并且预览会被水平拉伸以填充屏幕。

但是,捕获的图像大小是正确的(1024x768 )。

换句话说,我希望预览大小与捕获的图像相同。

任何帮助都将不胜感激。

代码语言:javascript
复制
preview = new Preview.Builder()
            .setTargetAspectRatioCustom(new Rational(3, 4))
            .build();
代码语言:javascript
复制
<androidx.constraintlayout.widget.ConstraintLayout 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.molescope.CameraXActivity">

    <androidx.camera.view.PreviewView
        android:id="@+id/preview_view"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent" />

    <ImageButton
        android:id="@+id/capture_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        android:layout_marginBottom="@dimen/margin_vertical"/>


</androidx.constraintlayout.widget.ConstraintLayout>
代码语言:javascript
复制
    def camerax_version = "1.0.0-beta03"
    implementation "androidx.camera:camera-core:${camerax_version}"
    implementation "androidx.camera:camera-camera2:${camerax_version}"
    implementation "androidx.camera:camera-lifecycle:${camerax_version}"
    implementation "androidx.camera:camera-view:1.0.0-alpha10"
    implementation "androidx.camera:camera-extensions:1.0.0-alpha10"
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-04-24 03:39:20

如果希望预览符合屏幕的宽度,则可能需要测试将PreviewView的缩放类型设置为FIT_CENTER (或FIT_STARTFIT_END,具体取决于在屏幕上布局预览的方式)。

您可以通过编程方式设置比例类型:

代码语言:javascript
复制
previewView.setScaleType(PreviewView.ScaleType.FIT_CENTER);

或者在布局文件中:

代码语言:javascript
复制
<androidx.camera.view.PreviewView
   ...
   android:scaleType="fitCenter" />

FIT_*适合预览的宽度或高度,以匹配PreviewView容器的宽度或高度(或者两者都匹配,如果容器和预览分辨率具有相同的纵横比),该尺寸的匹配取决于两个因素,包括预览分辨率、设备的自然方向和显示器当前的方向。因此,这种方法可能无法在所有情况下工作,有时预览将填充其容器的宽度,而在其他情况下,它将填充容器的高度。

如果您关注显示预览的高宽比,那么解决问题的另一种方法是设置PreviewView的纵横比(在您的例子中,我假设它是4x3),并将PreviewView设置为使用FIT_CENTER比例类型。

票数 6
EN

Stack Overflow用户

发布于 2021-09-19 12:27:44

关于你对In other words I want the preview size to be same as image captured.的问题,这篇文章https://groups.google.com/a/android.com/g/camerax-developers/c/6GNMfHIDeAM似乎很有帮助。上面写着:

--您可以尝试使用ViewPort特性在WYSIWYG中生成相同的裁剪。在使用CameraXBasic示例代码时,可以用

代码语言:javascript
复制
val viewPort: ViewPort = ViewPort.Builder(
Rational(
viewFinder.width,
viewFinder.height
),
viewFinder.display.rotation
).setScaleType(ViewPort.FILL_CENTER).build()

val useCaseGroupBuilder: UseCaseGroup.Builder = UseCaseGroup.Builder().setViewPort(
viewPort
)

useCaseGroupBuilder.addUseCase(preview!!)
useCaseGroupBuilder.addUseCase(imageCapture!!)
useCaseGroupBuilder.addUseCase(imageAnalyzer!!)

camera = cameraProvider.bindToLifecycle(
this, cameraSelector,
useCaseGroupBuilder.build()
)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61396538

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档