我正在尝试使用SVG和react-native-vision相机在相机屏幕上渲染一个姿势。它在正常的16:9宽高比下工作正常,但在我的朋友iPhone Pro Max上,它是19.5:9,然后姿势与身体不匹配。
它的形状是正确的,只是看起来不像身体。
渲染姿态函数
const [frameWidth, setFrameWidth] = React.useState(Dimensions.get('screen').width);
const [frameHeight, setFrameHeight] = React.useState(Dimensions.get('screen').height);
const getFrameSize = (): number[] => {
let width: number, height: number;
if (Platform.OS === "android") {
if (
frameWidth > frameHeight &&
Dimensions.get("window").width > Dimensions.get("window").height
) {
width = frameWidth;
height = frameHeight;
} else {
width = frameHeight;
height = frameWidth;
}
} else {
width = frameWidth;
height = frameHeight;
}
return [width, height];
};
const getViewBox = () => {
const frameSize = getFrameSize();
const viewBox = "0 0 " + frameSize[0] + " " + frameSize[1];
return viewBox;
};
const renderPose = () => {
if (poses != null && poses.length > 0) {
const selectedJoints = [
poses[0].LeftShoulder,
poses[0].RightShoulder,
poses[0].LeftHip,
poses[0].RightHip,
poses[0].RightKnee,
poses[0].LeftKnee,
poses[0].RightAnkle,
poses[0].LeftAnkle,
poses[0].RightShoulder,
poses[0].LeftToe,
poses[0].RightToe,
poses[0].RightElbow,
poses[0].LeftElbow,
poses[0].RightThumb,
poses[0].LeftThumb,
]
.filter((k) => (k.inFrameLikelihood ?? 0) > 0.3)
.map((k, index) => {
// Flip horizontally on android or when using back camera on iOS.
return (
<Svg >
<Circle
key={`skeletonkp_${k.type}`}
cx={k.position.x}
cy={k.position.y}
r={25}
strokeWidth="2"
fill="transparent"
stroke={Theme.COLORS.WHITE}
/>
{/* <Circle
key={`skeletonkp_${k.type}${index}`}
cx={k.position.x}
cy={k.position.y}
r={10}
strokeWidth="0"
fill="#FAF9F6"
stroke="transparent"
/> */}
</Svg>
);
});
return (
<Svg
viewBox={getViewBox()}
>
{selectedJoints}
</Svg>
);
} else {
return <View></View>;
}
};
摄像头组件
<PinchGestureHandler onGestureEvent={onPinchGesture} enabled={isActive}>
<Reanimated.View style={StyleSheet.absoluteFill}>
<ReanimatedCamera
ref={camera}
style={StyleSheet.absoluteFill}
device={device}
format={format}
fps={30}
hdr={enableHdr}
lowLightBoost={device.supportsLowLightBoost && enableNightMode}
isActive={isActive}
onInitialized={onInitialized}
onError={onError}
enableZoomGesture={false}
animatedProps={cameraAnimatedProps}
photo={true}
video={true}
audio={hasMicrophonePermission}
frameProcessor={
device.supportsParallelVideoProcessing && isActive
? frameProcessor
: undefined
}
orientation="portrait"
frameProcessorFps={30}
/>
</Reanimated.View>
</PinchGestureHandler>
1条答案
按热度按时间g6ll5ycj1#
对于任何遇到同样问题的人,我需要找到正确的相机格式可用,然后样式相机组件为16:9。在iPhone Pro max为19.5:9的情况下,绝对填充使图像拉伸并扰乱了姿势放置。