android - 如何在 cameraX 预览中设置预览大小?
问题描述
我正在尝试以纵向模式创建预览,并且我希望预览与屏幕一样宽并垂直包装内容。但是,当我这样做时,我总是会获得预览大小1200x 1200
,并且预览会水平拉伸以填满屏幕。
捕获的图像大小正确(1024x768
.
换句话说,我希望预览大小与捕获的图像相同。
任何帮助将不胜感激。
preview = new Preview.Builder()
.setTargetAspectRatioCustom(new Rational(3, 4))
.build();
<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>
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"
解决方案
如果您希望预览适合屏幕的宽度,您可能需要测试将比例类型设置PreviewView
为FIT_CENTER
(或FIT_START
或FIT_END
,具体取决于您希望如何在屏幕上布局预览)。
您可以通过编程方式设置比例类型:
previewView.setScaleType(PreviewView.ScaleType.FIT_CENTER);
或者在布局文件中:
<androidx.camera.view.PreviewView
...
android:scaleType="fitCenter" />
FIT_*
适合预览的宽度或高度以匹配PreviewView
' 容器的宽度或高度(或两者,如果容器和预览分辨率具有相同的纵横比),匹配的尺寸取决于几件事,包括预览分辨率、设备的自然方向和显示器的当前方向。因此,这种方法可能不适用于所有情况,有时,预览会填充其容器的宽度,有时,它将填充容器的高度。
如果您关心的是显示预览的纵横比,另一种解决问题的方法是设置PreviewView
的纵横比(在您的情况下,我假设它是 4x3),并设置PreviewView
为使用FIT_CENTER
比例类型。
推荐阅读
- python - 试图在按钮的命令参数中声明一个 lambda 函数,但它不起作用(Tkinter)
- string - 替换字符串中的单词而不替换重复项
- google-chrome - 使用 nginx 反向代理,url 适用于 curl 但不适用于 chrome
- php - Yii2 - 获取未知属性:yii\console\Request::userAgent 和 Class db 不存在
- python - Django Rest Framework - 减少查询并提高 SerializerMethodField() 的性能
- r - 创建一个递归函数来计算所有列组合之间的归一化差异
- reactjs - TypeError:s.indexOf 不是函数 Function.e.fromString node_modules/@firebase/firestore/dist/esm5/prebuilt
- snmp - SNMP 传递命令返回 OID 错误但显然在服务器上运行
- salesforce - 如何在 Lightning Buttons 中应用 CSS 来更改颜色
- javascript - 对 json 数组进行排序,首先按搜索文本和剩余结果按字母顺序排列