| /* |
| * Copyright (C) 2019 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 com.android.settings.accessibility; |
| |
| import android.content.Context; |
| import android.text.Html; |
| import android.text.TextUtils; |
| import android.widget.TextView; |
| |
| import androidx.preference.PreferenceViewHolder; |
| |
| /** |
| * A custom {@link android.widget.TextView} preference that shows html text with a custom tag |
| * filter. |
| */ |
| public final class HtmlTextPreference extends StaticTextPreference { |
| |
| private int mFlag = Html.FROM_HTML_MODE_COMPACT; |
| private Html.ImageGetter mImageGetter; |
| private Html.TagHandler mTagHandler; |
| |
| HtmlTextPreference(Context context) { |
| super(context); |
| } |
| |
| @Override |
| public void onBindViewHolder(PreferenceViewHolder holder) { |
| super.onBindViewHolder(holder); |
| |
| final TextView summaryView = holder.itemView.findViewById(android.R.id.summary); |
| if (summaryView != null && !TextUtils.isEmpty(getSummary())) { |
| summaryView.setText( |
| Html.fromHtml(getSummary().toString(), mFlag, mImageGetter, mTagHandler)); |
| } |
| } |
| |
| /** |
| * Sets the flag to which text format to be applied. |
| * |
| * @param flag to indicate that html text format |
| */ |
| public void setFlag(int flag) { |
| if (flag != mFlag) { |
| mFlag = flag; |
| notifyChanged(); |
| } |
| } |
| |
| /** |
| * Sets image getter and help to load corresponding images when parsing. |
| * |
| * @param imageGetter to load image by image tag content |
| */ |
| public void setImageGetter(Html.ImageGetter imageGetter) { |
| if (imageGetter != null && !imageGetter.equals(mImageGetter)) { |
| mImageGetter = imageGetter; |
| notifyChanged(); |
| } |
| } |
| |
| /** |
| * Sets tag handler to handle the unsupported tags. |
| * |
| * @param tagHandler the handler for unhandled tags |
| */ |
| public void setTagHandler(Html.TagHandler tagHandler) { |
| if (tagHandler != null && !tagHandler.equals(mTagHandler)) { |
| mTagHandler = tagHandler; |
| notifyChanged(); |
| } |
| } |
| } |