Skip to content

Commit

Permalink
feat(android): fontWeight support number for TextInput
Browse files Browse the repository at this point in the history
  • Loading branch information
iPel committed Nov 17, 2023
1 parent e674d8c commit 2b9be72
Show file tree
Hide file tree
Showing 4 changed files with 82 additions and 62 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,17 @@
import android.graphics.BlendMode;
import android.graphics.BlendModeColorFilter;

import android.graphics.Paint;
import android.graphics.Typeface;
import androidx.annotation.Nullable;
import com.tencent.mtt.hippy.common.HippyMap;
import com.tencent.mtt.hippy.uimanager.HippyViewBase;
import com.tencent.mtt.hippy.uimanager.NativeGestureDispatcher;
import com.tencent.mtt.hippy.uimanager.RenderManager;
import com.tencent.renderer.NativeRender;
import com.tencent.renderer.NativeRendererManager;
import com.tencent.renderer.component.text.FontAdapter;
import com.tencent.renderer.component.text.TypeFaceUtil;
import com.tencent.renderer.node.RenderNode;
import com.tencent.mtt.hippy.utils.ContextHolder;
import com.tencent.mtt.hippy.utils.LogUtils;
Expand Down Expand Up @@ -57,6 +64,7 @@
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;

@SuppressWarnings({"deprecation", "unused"})
public class HippyTextInput extends AppCompatEditText implements HippyViewBase,
Expand All @@ -75,6 +83,11 @@ public class HippyTextInput extends AppCompatEditText implements HippyViewBase,
private int mLastRootViewVisibleHeight = -1; //当前RootView的上一次大小
private boolean mIsKeyBoardShow = false; //键盘是否在显示
private ReactContentSizeWatcher mReactContentSizeWatcher = null;
private boolean mItalic = false;
private int mFontWeight = TypeFaceUtil.WEIGHT_NORMAL;
@Nullable
private String mFontFamily;
private Paint mTextPaint;

public HippyTextInput(Context context) {
super(context);
Expand Down Expand Up @@ -639,4 +652,53 @@ public void refreshSoftInput() {
}
}
}

public void setFontStyle(String style) {
if (TypeFaceUtil.TEXT_FONT_STYLE_ITALIC.equals(style) != mItalic) {
mItalic = !mItalic;
updateTypeface();
}
}

public void setFontFamily(String family) {
if (!Objects.equals(mFontFamily, family)) {
mFontFamily = family;
updateTypeface();
}
}

public void setFontWeight(String weight) {
int fontWeight;
if (TextUtils.isEmpty(weight) || TypeFaceUtil.TEXT_FONT_STYLE_NORMAL.equals(weight)) {
// case normal
fontWeight = TypeFaceUtil.WEIGHT_NORMAL;
} else if (TypeFaceUtil.TEXT_FONT_STYLE_BOLD.equals(weight)) {
// case bold
fontWeight = TypeFaceUtil.WEIGHT_BOLE;
} else {
// case number
try {
fontWeight = Math.min(Math.max(1, Integer.parseInt(weight)), 1000);
} catch (NumberFormatException ignored) {
fontWeight = TypeFaceUtil.WEIGHT_NORMAL;
}
}
if (fontWeight != mFontWeight) {
mFontWeight = fontWeight;
updateTypeface();
}
}

private void updateTypeface() {
if (mTextPaint == null) {
mTextPaint = new Paint();
} else {
mTextPaint.reset();
}
NativeRender nativeRenderer = NativeRendererManager.getNativeRenderer(getContext());
FontAdapter fontAdapter = nativeRenderer == null ? null : nativeRenderer.getFontAdapter();
TypeFaceUtil.apply(mTextPaint, mItalic, mFontWeight, mFontFamily, fontAdapter);
setTypeface(mTextPaint.getTypeface(), mTextPaint.isFakeBoldText() ? Typeface.BOLD : Typeface.NORMAL);
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -208,66 +208,19 @@ public void setKeyboardType(HippyTextInput hippyTextInput, String keyboardType)
hippyTextInput.refreshSoftInput();
}

private static int parseFontWeight(String fontWeightString) {
// This should be much faster than using regex to verify input and Integer.parseInt
return fontWeightString.length() == 3 && fontWeightString.endsWith("00")
&& fontWeightString.charAt(0) <= '9'
&& fontWeightString.charAt(0) >= '1' ? 100 * (fontWeightString.charAt(0) - '0')
: -1;
}

@HippyControllerProps(name = NodeProps.FONT_STYLE, defaultType = HippyControllerProps.STRING, defaultString = "normal")
@HippyControllerProps(name = NodeProps.FONT_STYLE, defaultType = HippyControllerProps.STRING)
public void setFontStyle(HippyTextInput view, String fontStyleString) {
if (TextUtils.isEmpty(fontStyleString)) {
return;
}
int fontStyle = -1;
if ("italic".equals(fontStyleString)) {
fontStyle = Typeface.ITALIC;
} else if ("normal".equals(fontStyleString)) {
fontStyle = Typeface.NORMAL;
}

Typeface currentTypeface = view.getTypeface();
if (currentTypeface == null) {
currentTypeface = Typeface.DEFAULT;
}
if (fontStyle != currentTypeface.getStyle()) {
view.setTypeface(currentTypeface, fontStyle);
}
view.setFontStyle(fontStyleString);
}

@HippyControllerProps(name = NodeProps.FONT_WEIGHT, defaultType = HippyControllerProps.STRING, defaultString = "normal")
@HippyControllerProps(name = NodeProps.FONT_WEIGHT, defaultType = HippyControllerProps.STRING)
public void setFontWeight(HippyTextInput view, String fontWeightString) {
int fontWeightNumeric = fontWeightString != null ? parseFontWeight(fontWeightString) : -1;
int fontWeight = -1;
if (fontWeightNumeric >= 500 || "bold".equals(fontWeightString)) {
fontWeight = Typeface.BOLD;
} else //noinspection ConstantConditions
if ("normal".equals(fontWeightString) || (fontWeightNumeric != -1
&& fontWeightNumeric < 500)) {
fontWeight = Typeface.NORMAL;
}
Typeface currentTypeface = view.getTypeface();
if (currentTypeface == null) {
currentTypeface = Typeface.DEFAULT;
}
if (fontWeight != currentTypeface.getStyle()) {
view.setTypeface(currentTypeface, fontWeight);
}
view.setFontWeight(fontWeightString);
}

@HippyControllerProps(name = NodeProps.FONT_FAMILY, defaultType = HippyControllerProps.STRING, defaultString = "normal")
@HippyControllerProps(name = NodeProps.FONT_FAMILY, defaultType = HippyControllerProps.STRING)
public void setFontFamily(HippyTextInput view, String fontFamily) {
if (TextUtils.isEmpty(fontFamily)) {
return;
}
int style = Typeface.NORMAL;
if (view.getTypeface() != null) {
style = view.getTypeface().getStyle();
}
Typeface newTypeface = Typeface.create(fontFamily, style);
view.setTypeface(newTypeface);
view.setFontFamily(fontFamily);
}

private static final InputFilter[] EMPTY_FILTERS = new InputFilter[0];
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ public class TypeFaceUtil {

public static final int WEIGHT_NORMAL = 400;
public static final int WEIGHT_BOLE = 700;
public static final String TEXT_FONT_STYLE_ITALIC = "italic";
public static final String TEXT_FONT_STYLE_BOLD = "bold";
public static final String TEXT_FONT_STYLE_NORMAL = "normal";
private static final String TAG = "TypeFaceUtil";
private static final String[] EXTENSIONS = {"", "_bold", "_italic", "_bold_italic"};
private static final String[] FONT_EXTENSIONS = {".ttf", ".otf"};
Expand Down Expand Up @@ -174,7 +177,9 @@ public static void apply(Paint paint, boolean italic, int weight, String familyN
} else {
typeface = getTypeface(familyName, weight, italic, fontAdapter);
}
paint.setFakeBoldText(weight >= WEIGHT_BOLE && typeface != null && !typeface.isBold());
if (weight >= WEIGHT_BOLE && typeface != null && !typeface.isBold()) {
paint.setFakeBoldText(true);
}
paint.setTypeface(typeface);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Objects;

public class TextVirtualNode extends VirtualNode {

Expand All @@ -69,9 +70,6 @@ public class TextVirtualNode extends VirtualNode {
public final static String V_ALIGN_BOTTOM = "bottom";

private static final int TEXT_SHADOW_COLOR_DEFAULT = 0x55000000;
private static final String TEXT_FONT_STYLE_ITALIC = "italic";
private static final String TEXT_FONT_STYLE_BOLD = "bold";
private static final String TEXT_FONT_STYLE_NORMAL = "normal";
private static final String TEXT_DECORATION_UNDERLINE = "underline";
private static final String TEXT_DECORATION_LINE_THROUGH = "line-through";
private static final String MODE_HEAD = "head";
Expand Down Expand Up @@ -137,7 +135,7 @@ public TextVirtualNode(int rootId, int id, int pid, int index,
@SuppressWarnings("unused")
@HippyControllerProps(name = NodeProps.FONT_STYLE, defaultType = HippyControllerProps.STRING)
public void setFontStyle(String style) {
if (TEXT_FONT_STYLE_ITALIC.equals(style) != mItalic) {
if (TypeFaceUtil.TEXT_FONT_STYLE_ITALIC.equals(style) != mItalic) {
mItalic = !mItalic;
markDirty();
}
Expand Down Expand Up @@ -172,18 +170,20 @@ public void setFontSize(float size) {
@SuppressWarnings("unused")
@HippyControllerProps(name = NodeProps.FONT_FAMILY, defaultType = HippyControllerProps.STRING)
public void setFontFamily(String family) {
mFontFamily = family;
markDirty();
if (!Objects.equals(mFontFamily, family)) {
mFontFamily = family;
markDirty();
}
}

@SuppressWarnings("unused")
@HippyControllerProps(name = NodeProps.FONT_WEIGHT, defaultType = HippyControllerProps.STRING)
public void setFontWeight(String weight) {
int fontWeight;
if (TextUtils.isEmpty(weight) || TEXT_FONT_STYLE_NORMAL.equals(weight)) {
if (TextUtils.isEmpty(weight) || TypeFaceUtil.TEXT_FONT_STYLE_NORMAL.equals(weight)) {
// case normal
fontWeight = TypeFaceUtil.WEIGHT_NORMAL;
} else if (TEXT_FONT_STYLE_BOLD.equals(weight)) {
} else if (TypeFaceUtil.TEXT_FONT_STYLE_BOLD.equals(weight)) {
// case bold
fontWeight = TypeFaceUtil.WEIGHT_BOLE;
} else {
Expand Down

0 comments on commit 2b9be72

Please sign in to comment.