Rabbit-R1/switch port/java/sources/com/airbnb/lottie/parser/ShapeDataParser.java

74 lines
2.9 KiB
Java
Raw Normal View History

2024-05-21 21:08:36 +00:00
package com.airbnb.lottie.parser;
import android.graphics.PointF;
import androidx.media3.exoplayer.upstream.CmcdHeadersFactory;
import com.airbnb.lottie.model.CubicCurveData;
import com.airbnb.lottie.model.content.ShapeData;
import com.airbnb.lottie.parser.moshi.JsonReader;
import com.airbnb.lottie.utils.MiscUtils;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/* loaded from: classes2.dex */
public class ShapeDataParser implements ValueParser<ShapeData> {
public static final ShapeDataParser INSTANCE = new ShapeDataParser();
private static final JsonReader.Options NAMES = JsonReader.Options.of("c", "v", CmcdHeadersFactory.OBJECT_TYPE_INIT_SEGMENT, "o");
private ShapeDataParser() {
}
/* JADX WARN: Can't rename method to resolve collision */
@Override // com.airbnb.lottie.parser.ValueParser
public ShapeData parse(JsonReader jsonReader, float f) throws IOException {
if (jsonReader.peek() == JsonReader.Token.BEGIN_ARRAY) {
jsonReader.beginArray();
}
jsonReader.beginObject();
List<PointF> list = null;
List<PointF> list2 = null;
List<PointF> list3 = null;
boolean z = false;
while (jsonReader.hasNext()) {
int selectName = jsonReader.selectName(NAMES);
if (selectName == 0) {
z = jsonReader.nextBoolean();
} else if (selectName == 1) {
list = JsonUtils.jsonToPoints(jsonReader, f);
} else if (selectName == 2) {
list2 = JsonUtils.jsonToPoints(jsonReader, f);
} else if (selectName == 3) {
list3 = JsonUtils.jsonToPoints(jsonReader, f);
} else {
jsonReader.skipName();
jsonReader.skipValue();
}
}
jsonReader.endObject();
if (jsonReader.peek() == JsonReader.Token.END_ARRAY) {
jsonReader.endArray();
}
if (list == null || list2 == null || list3 == null) {
throw new IllegalArgumentException("Shape data was missing information.");
}
if (list.isEmpty()) {
return new ShapeData(new PointF(), false, Collections.emptyList());
}
int size = list.size();
PointF pointF = list.get(0);
ArrayList arrayList = new ArrayList(size);
for (int i = 1; i < size; i++) {
PointF pointF2 = list.get(i);
int i2 = i - 1;
arrayList.add(new CubicCurveData(MiscUtils.addPoints(list.get(i2), list3.get(i2)), MiscUtils.addPoints(pointF2, list2.get(i)), pointF2));
}
if (z) {
PointF pointF3 = list.get(0);
int i3 = size - 1;
arrayList.add(new CubicCurveData(MiscUtils.addPoints(list.get(i3), list3.get(i3)), MiscUtils.addPoints(pointF3, list2.get(0)), pointF3));
}
return new ShapeData(pointF, z, arrayList);
}
}