自定义textFeild

部署运行你感兴趣的模型镜像

#import <UIKit/UIKit.h>


@interface NDTextFieldPadding : UITextField

{

    BOOL isEnablePadding;

    float paddingLeft;

    float paddingRight;

    float paddingTop;

    float paddingBottom;

}


+ (NDTextFieldPadding *) createRightAngleRectTextFieldWithFont:(UIFont *)font;

+ (NDTextFieldPadding *) createRightAngleRectTextFieldWithFont:(UIFont *)font textAlignment:(NSTextAlignment)textAlignment;


+ (NDTextFieldPadding *) createRoundTextFieldWithFont:(UIFont *)font;

+ (NDTextFieldPadding *) createRoundTextFieldWithFont:(UIFont *)font textAlignment:(NSTextAlignment)textAlignment;


- (void)setPadding:(BOOL)enable top:(float)top right:(float)right bottom:(float)bottom left:(float)left;


@end

#import "NDTextFieldPadding.h"


@implementation NDTextFieldPadding

#pragma mark - 类方法


+ (NDTextFieldPadding *) createRightAngleRectTextFieldWithFont:(UIFont *)font

{

    return [NDTextFieldPadding createRightAngleRectTextFieldWithFont:font textAlignment:NSTextAlignmentNatural];

}


+ (NDTextFieldPadding *) createRightAngleRectTextFieldWithFont:(UIFont *)font textAlignment:(NSTextAlignment)textAlignment

{

    NDTextFieldPadding *tf = [[NDTextFieldPadding alloc] init];

    tf.textColor = [UIColor blackColor];

    tf.borderStyle = UITextBorderStyleNone;

    tf.clearButtonMode = UITextFieldViewModeWhileEditing;

    tf.textAlignment = textAlignment;

    tf.font = font;

    tf.layer.borderWidth = kSeparatorLineWidth;

    tf.layer.borderColor = kSubColor.CGColor;

    return tf;

}


+ (NDTextFieldPadding *) createRoundTextFieldWithFont:(UIFont *)font

{

    return [NDTextFieldPadding createRoundTextFieldWithFont:font textAlignment:NSTextAlignmentNatural];

}


+ (NDTextFieldPadding *) createRoundTextFieldWithFont:(UIFont *)font textAlignment:(NSTextAlignment)textAlignment;

{

    NDTextFieldPadding *tf = [[NDTextFieldPadding alloc] init];

    tf.backgroundColor = kTextFieldFillColor;

    tf.textColor = kLoginHeavyColor;

    tf.borderStyle = UITextBorderStyleNone;

    tf.clearButtonMode = UITextFieldViewModeWhileEditing;

    tf.textAlignment = textAlignment;

    tf.font = font;

    tf.layer.masksToBounds = YES;

    tf.layer.borderWidth = kSeparatorLineWidth;

    tf.layer.borderColor = kLoginColor.CGColor;

    return tf;

}


#pragma mark - 实例方法

- (void)setPadding:(BOOL)enable top:(float)top right:(float)right bottom:(float)bottom left:(float)left {

    isEnablePadding = enable;

    paddingTop = top;

    paddingRight = right;

    paddingBottom = bottom;

    paddingLeft = left;

}


#pragma mark - 重写

- (CGRect)textRectForBounds:(CGRect)bounds {

    if (isEnablePadding) {

        return CGRectMake(bounds.origin.x + paddingLeft,

                          bounds.origin.y + paddingTop,

                          bounds.size.width - paddingRight, bounds.size.height - paddingBottom);

    } else {

        return CGRectMake(bounds.origin.x, bounds.origin.y, bounds.size.width, bounds.size.height);

    }

}


- (CGRect)editingRectForBounds:(CGRect)bounds {

    return [self textRectForBounds:bounds];

}


@end




您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

/** * 住所選択 * @param stateData 画面の状態データ */ @Composable private fun AddressSelect( stateData: JAFRSHO10010UiStateData, ) { // 住所選択 入庫先区分 Row( modifier = Modifier .height(66.dp) .fillMaxWidth() .padding(start = 20.dp, top = 10.dp) .background(MaterialTheme.colorScheme.tabContentSelectedText), horizontalArrangement = Arrangement.Start, verticalAlignment = Alignment.CenterVertically ) { JAFRSHO10010TextFeild( label = stringResource(R.string.label_nyuko_place_cls), labelModifier = Modifier .width(190.dp) .height(50.dp) .padding(start = 10.dp), isShowUnderline = false, isShowFilter = false, isRequired = true, isTextEdit = false ) JAFRSHO10010DropText( item = Item( key = stateData.lstboxAddressNyukoPlaceCls.selectCode ?: "", value = stateData.lstboxAddressNyukoPlaceCls.selectName ?: "" ), modifier = Modifier .width(179.dp) .height(46.dp) .padding(start = 10.dp) ) } // 住所選択 住所 Row( modifier = Modifier .height(125.dp) .fillMaxWidth() .padding(start = 20.dp), horizontalArrangement = Arrangement.Start, verticalAlignment = Alignment.CenterVertically ) { JAFRSHO10010TextFeild( label = stringResource(R.string.label_address), labelModifier = Modifier .width(190.dp) .height(50.dp) .padding(start = 10.dp), value = stateData.lblAddress ?: "", textModifier = Modifier .width(458.dp) .height(109.dp), isShowUnderline = false, maxDisplayLength = 80, isTextEdit = false ) } // 都道府県 Row( modifier = Modifier .height(66.dp) .fillMaxWidth() .padding(start = 20.dp) .background(MaterialTheme.colorScheme.tabContentSelectedText), horizontalArrangement = Arrangement.Start, verticalAlignment = Alignment.CenterVertically ) { JAFRSHO10010TextFeild( label = stringResource(R.string.label_todofuken), labelModifier = Modifier .width(190.dp) .height(50.dp) .padding(start = 10.dp), value = stateData.txtboxTodofuken ?: "", textModifier = Modifier .width(458.dp) .height(46.dp), isShowFilter = false, isRequired = true, activeEnabled = ActiveInactive.ACTIVE ) } // 市区町村 Row( modifier = Modifier .height(66.dp) .fillMaxWidth() .padding(start = 20.dp), horizontalArrangement = Arrangement.Start, verticalAlignment = Alignment.CenterVertically ) { JAFRSHO10010TextFeild( label = stringResource(R.string.label_shikugun), labelModifier = Modifier .width(190.dp) .height(50.dp) .padding(start = 10.dp), value = stateData.txtboxShikugun ?: "", textModifier = Modifier .width(458.dp) .height(46.dp), isRequired = true, activeEnabled = stateData.stateActive.isShikugunEnabled ) } // 大字 Row( modifier = Modifier .height(66.dp) .fillMaxWidth() .padding(start = 20.dp) .background(MaterialTheme.colorScheme.tabContentSelectedText), horizontalArrangement = Arrangement.Start, verticalAlignment = Alignment.CenterVertically ) { JAFRSHO10010TextFeild( label = stringResource(R.string.label_oaza), labelModifier = Modifier .width(190.dp) .height(50.dp) .padding(start = 10.dp), value = stateData.txtboxOaza ?: "", textModifier = Modifier .width(458.dp) .height(46.dp), activeEnabled = stateData.stateActive.isOazaEnabled ) } // 丁目 Row( modifier = Modifier .height(66.dp) .fillMaxWidth() .padding(start = 20.dp), horizontalArrangement = Arrangement.Start, verticalAlignment = Alignment.CenterVertically ) { JAFRSHO10010TextFeild( label = stringResource(R.string.label_chome), labelModifier = Modifier .width(190.dp) .height(50.dp) .padding(start = 10.dp), value = stateData.txtboxChome ?: "", textModifier = Modifier .width(458.dp) .height(46.dp), activeEnabled = stateData.stateActive.isChomeEnabled ) } /*********************************************************** * Copyright NEC Corporation 2025. All rights reserved * No permission to use, copy, modify and distribute this * software and its documentation for any purpose is granted. * This software is provided under applicable license * agreement only. * * システム名 : JAF RSシステム * サブシステム名 : 車業アプリ * クラス名 : JAFRSHO10010TextFeild * * @author NEC * ***********************************************************/ package jp.or.jaf.syg.feature.jafrsho10.jafrsho10010.components import androidx.compose.foundation.background import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxHeight import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.size import androidx.compose.foundation.layout.width import androidx.compose.foundation.layout.wrapContentHeight import androidx.compose.foundation.layout.wrapContentWidth import androidx.compose.foundation.shape.RoundedCornerShape import androidx.compose.foundation.text.BasicTextField import androidx.compose.foundation.text.KeyboardOptions import androidx.compose.material3.LocalTextStyle import androidx.compose.material3.MaterialTheme import androidx.compose.material3.Text import androidx.compose.runtime.* import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.draw.clip import androidx.compose.ui.focus.onFocusChanged import androidx.compose.ui.graphics.Color import androidx.compose.ui.graphics.SolidColor import androidx.compose.ui.text.TextStyle import androidx.compose.ui.text.font.FontWeight import androidx.compose.ui.text.input.VisualTransformation import androidx.compose.ui.text.style.TextAlign import jp.or.jaf.syg.core.designsystem.theme.FigmaDesign.dp import jp.or.jaf.syg.core.designsystem.theme.FigmaDesign.sp import jp.or.jaf.syg.core.designsystem.theme.font.LocalNotoSansJPFontFamily import jp.or.jaf.syg.core.designsystem.theme.jafTextColor import jp.or.jaf.syg.core.designsystem.theme.requiredMark import jp.or.jaf.syg.core.designsystem.theme.textFieldLabel import jp.or.jaf.syg.core.designsystem.theme.textFieldUnderLine import jp.or.jaf.syg.core.ui.components.JafRefrenceButton import jp.or.jaf.syg.domain.model.common.ActiveInactive /** * 指令確認画面_牽引・伴走開始ポップアップのカスタムテキストフィールドコンポーネント * * @param label ラベルテキスト * @param value テキスト値 * @param onValueChange 値変更時のコールバック * @param maxDisplayLength 最大文字数を表す * @param isRequired 必須ボタンを表示するかどうか * @param labelModifier labelスタイル * @param textModifier textModifier * @param isShowUnderline 下線を表示するかどうか * @param isSingleLine 単一行にするかどうか * @param underlineColor 下線の色 * @param textAlign 入力ボックスtextAlign * @param unitString 入力ボックス単位 * @param visualTransformation VisualTransformation * @param keyboardOptions KeyboardOptions * @param isTextClick text(click) * @param isTextEdit text(edit) * @param isShowFilter 変換アイコンを表示するかどうか * @param onFilterClick 変換アイコンクリック * @param onClick コールバックをクリック * @param content カスタムコンテンツ * */ @Composable fun JAFRSHO10010TextFeild( label: String = "", value: String = "", onValueChange: (String) -> Unit = {}, maxDisplayLength: Int = 20, isRequired: Boolean = false, labelModifier: Modifier = Modifier, textModifier: Modifier = Modifier, isShowUnderline: Boolean = true, isSingleLine: Boolean = true, underlineColor: Color = MaterialTheme.colorScheme.textFieldUnderLine, textAlign: TextAlign? = TextAlign.Center, unitString: String? = null, visualTransformation: VisualTransformation = VisualTransformation.None, keyboardOptions: KeyboardOptions = KeyboardOptions.Default, activeEnabled: ActiveInactive = ActiveInactive.ACTIVE, isTextClick: Boolean = false, isTextEdit: Boolean = true, isShowFilter: Boolean = true, onFilterClick: () -> Unit = {}, onClick: () -> Unit = {}, content: (@Composable () -> Unit)? = null ) { // 色の定義 val labelColor = MaterialTheme.colorScheme.textFieldLabel val textColor = MaterialTheme.colorScheme.jafTextColor // ステータス管理 var displayText by remember(value) { mutableStateOf(value) } // 焦点状態追跡 var isFocused by remember { mutableStateOf(false) } LaunchedEffect(isFocused) { if (!isFocused && displayText != value) { onValueChange(displayText) } } LaunchedEffect(value) { if (!isFocused) { displayText = value } } Row( verticalAlignment = Alignment.CenterVertically, horizontalArrangement = Arrangement.SpaceBetween, modifier = Modifier.width(240.dp).fillMaxHeight() ) { Text( text = label, modifier = labelModifier.wrapContentHeight(align = Alignment.CenterVertically), style = MaterialTheme.typography.bodyMedium.copy( color = labelColor, fontSize = 22.sp, fontWeight = FontWeight.Bold, lineHeight = 26.sp, fontFamily = LocalNotoSansJPFontFamily.current ) ) // マークが必要(赤の背景付き) if (isRequired) { Text( text = "必須", color = Color.White, fontSize = 16.sp, modifier = Modifier .padding(start = 4.dp) .background( color = MaterialTheme.colorScheme.requiredMark, shape = RoundedCornerShape(4.dp) ) .width(42.dp) .padding(horizontal = 4.dp, vertical = 2.dp) ) } if (content != null) { content() } if (isTextClick || isTextEdit) { Column( modifier = textModifier .clip(MaterialTheme.shapes.medium) ) { if (isTextClick) { Text( text = value.let { if (it.length > maxDisplayLength) { it.take(maxDisplayLength - 1) } else { it } }, fontSize = 22.sp, modifier = textModifier .clickable(enabled = activeEnabled == ActiveInactive.ACTIVE) { onClick() } .wrapContentHeight(Alignment.CenterVertically) .padding(horizontal = 10.dp), textAlign = textAlign, color = textColor ) } if (isTextEdit) { BasicTextField( value = displayText.let { if (it.length > maxDisplayLength) { it.take(maxDisplayLength - 1) } else { it } }, onValueChange = { newText -> displayText = newText }, textStyle = LocalTextStyle.current.merge( TextStyle( fontFamily = LocalNotoSansJPFontFamily.current, fontWeight = FontWeight.Medium, fontSize = 22.sp, lineHeight = 26.4.sp, letterSpacing = 22.sp * 0.02f, color = textColor ) ), enabled = activeEnabled == ActiveInactive.ACTIVE, cursorBrush = SolidColor(MaterialTheme.colorScheme.primary), visualTransformation = visualTransformation, keyboardOptions = keyboardOptions, singleLine = isSingleLine, modifier = textModifier .padding(start = 10.dp) .wrapContentHeight(align = Alignment.CenterVertically) .onFocusChanged { focusState -> val wasFocused = isFocused isFocused = focusState.isFocused if (wasFocused && !isFocused && displayText != value) { onValueChange(displayText) } }, ) } // ダイナミックカラー下線 if (isShowUnderline) { Spacer( modifier = Modifier .height(1.dp) .fillMaxWidth() .background(underlineColor) ) } } if (isShowFilter && displayText.length > maxDisplayLength) { JafRefrenceButton( modifier = Modifier .size(28.dp) .wrapContentWidth(Alignment.End) .wrapContentHeight(Alignment.Bottom), enabled = true, onClick = onFilterClick ) } if (unitString != null) { Text( text = unitString, modifier = labelModifier, style = MaterialTheme.typography.bodyMedium.copy( color = labelColor, fontSize = 22.sp ) ) } } } } 以上代码中为什么都道府県的JAFRSHO10010TextFeild,不能输入文字?不是设置了activeEnabled = ActiveInactive.ACTIVE吗?
最新发布
09-30
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值