/* * Copyright (C) 2020 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ package androidx.media3.common.text; import static androidx.media3.common.util.Assertions.checkNotNull; import android.os.Bundle; import androidx.media3.common.util.UnstableApi; import androidx.media3.common.util.Util; /** * A styling span for ruby text. * *

The text covered by this span is known as the "base text", and the ruby text is stored in * {@link #rubyText}. * *

More information on ruby characters * and span styling. */ // NOTE: There's no Android layout support for rubies, so this span currently doesn't extend any // styling superclasses (e.g. MetricAffectingSpan). The only way to render these rubies is to // extract the spans and do the layout manually. // TODO: Consider adding support for parenthetical text to be used when rendering doesn't support // rubies (e.g. HTML tag). @UnstableApi public final class RubySpan implements LanguageFeatureSpan { /** The ruby text, i.e. the smaller explanatory characters. */ public final String rubyText; /** The position of the ruby text relative to the base text. */ public final @TextAnnotation.Position int position; private static final String FIELD_TEXT = Util.intToStringMaxRadix(0); private static final String FIELD_POSITION = Util.intToStringMaxRadix(1); public RubySpan(String rubyText, @TextAnnotation.Position int position) { this.rubyText = rubyText; this.position = position; } public Bundle toBundle() { Bundle bundle = new Bundle(); bundle.putString(FIELD_TEXT, rubyText); bundle.putInt(FIELD_POSITION, position); return bundle; } public static RubySpan fromBundle(Bundle bundle) { return new RubySpan( /* rubyText= */ checkNotNull(bundle.getString(FIELD_TEXT)), /* position= */ bundle.getInt(FIELD_POSITION)); } }