当前位置: 首页 > wzjs >正文

网站开发中 html河北网站建设制作

网站开发中 html,河北网站建设制作,网站建设类的计入什么科目,标准个人简历模板免费下载在 Jetpack Compose 中实现 iOS 风格输入框 要在 Android Compose 中模仿 iOS 风格的输入框,我们需要关注几个关键特点:简洁的边框、圆角设计、特定的交互效果等。以下是完整的实现方案: 1. 基础 iOS 风格输入框 Composable fun IosStyleT…

在 Jetpack Compose 中实现 iOS 风格输入框

要在 Android Compose 中模仿 iOS 风格的输入框,我们需要关注几个关键特点:简洁的边框、圆角设计、特定的交互效果等。以下是完整的实现方案:

1. 基础 iOS 风格输入框

@Composable
fun IosStyleTextField(value: String,onValueChange: (String) -> Unit,modifier: Modifier = Modifier,label: String? = null,placeholder: String? = null
) {Column(modifier = modifier) {label?.let {Text(text = it,style = MaterialTheme.typography.bodyMedium,color = Color.Gray,modifier = Modifier.padding(bottom = 4.dp))}Box(modifier = Modifier.fillMaxWidth().background(color = Color.White,shape = RoundedCornerShape(10.dp)).border(width = 1.dp,color = Color(0xFFC7C7CC),shape = RoundedCornerShape(10.dp)).padding(horizontal = 16.dp, vertical = 12.dp)) {BasicTextField(value = value,onValueChange = onValueChange,modifier = Modifier.fillMaxWidth(),textStyle = MaterialTheme.typography.bodyMedium.copy(color = Color.Black),singleLine = true,decorationBox = { innerTextField ->if (value.isEmpty() && placeholder != null) {Text(text = placeholder,style = MaterialTheme.typography.bodyMedium.copy(color = Color(0xFFC7C7CC)))}innerTextField()})}}
}// 使用示例
var text by remember { mutableStateOf("") }
IosStyleTextField(value = text,onValueChange = { text = it },label = "用户名",placeholder = "请输入用户名",modifier = Modifier.padding(16.dp)
)

2. 带清除按钮的 iOS 风格输入框

@Composable
fun IosStyleTextFieldWithClear(value: String,onValueChange: (String) -> Unit,modifier: Modifier = Modifier,label: String? = null,placeholder: String? = null
) {Column(modifier = modifier) {label?.let {Text(text = it,style = MaterialTheme.typography.bodyMedium,color = Color.Gray,modifier = Modifier.padding(bottom = 4.dp))}Box(modifier = Modifier.fillMaxWidth().background(color = Color.White,shape = RoundedCornerShape(10.dp)).border(width = 1.dp,color = if (value.isNotEmpty()) Color(0xFF007AFF) else Color(0xFFC7C7CC),shape = RoundedCornerShape(10.dp)).padding(horizontal = 16.dp, vertical = 12.dp)) {Row(verticalAlignment = Alignment.CenterVertically,modifier = Modifier.fillMaxWidth()) {BasicTextField(value = value,onValueChange = onValueChange,modifier = Modifier.weight(1f),textStyle = MaterialTheme.typography.bodyMedium.copy(color = Color.Black),singleLine = true,decorationBox = { innerTextField ->if (value.isEmpty() && placeholder != null) {Text(text = placeholder,style = MaterialTheme.typography.bodyMedium.copy(color = Color(0xFFC7C7CC)))}innerTextField()})if (value.isNotEmpty()) {IconButton(onClick = { onValueChange("") },modifier = Modifier.size(20.dp)) {Icon(imageVector = Icons.Default.Close,contentDescription = "清除",tint = Color(0xFFC7C7CC),modifier = Modifier.size(16.dp))}}}}}
}

3. 搜索框样式

@Composable
fun IosStyleSearchField(value: String,onValueChange: (String) -> Unit,modifier: Modifier = Modifier,placeholder: String = "搜索"
) {Box(modifier = modifier.fillMaxWidth().height(36.dp).background(color = Color(0xFFF2F2F7),shape = RoundedCornerShape(10.dp)).padding(horizontal = 8.dp),contentAlignment = Alignment.CenterStart) {Row(verticalAlignment = Alignment.CenterVertically,modifier = Modifier.fillMaxWidth()) {Icon(imageVector = Icons.Default.Search,contentDescription = "搜索",tint = Color(0xFF8E8E93),modifier = Modifier.size(16.dp).padding(end = 4.dp))BasicTextField(value = value,onValueChange = onValueChange,modifier = Modifier.weight(1f),textStyle = MaterialTheme.typography.bodyMedium.copy(color = Color.Black,fontSize = 14.sp),singleLine = true,decorationBox = { innerTextField ->if (value.isEmpty()) {Text(text = placeholder,style = MaterialTheme.typography.bodyMedium.copy(color = Color(0xFF8E8E93),fontSize = 14.sp))}innerTextField()})if (value.isNotEmpty()) {IconButton(onClick = { onValueChange("") },modifier = Modifier.size(20.dp)) {Icon(imageVector = Icons.Default.Close,contentDescription = "清除",tint = Color(0xFF8E8E93),modifier = Modifier.size(16.dp))}}}}
}

4. 带分段的 iOS 风格表单

@Composable
fun IosStyleForm(items: List<Pair<String, @Composable () -> Unit>>,modifier: Modifier = Modifier
) {Column(modifier = modifier.background(Color.White).clip(RoundedCornerShape(10.dp))) {items.forEachIndexed { index, (title, content) ->Column {if (index > 0) {Divider(color = Color(0xFFC6C6C8),thickness = 0.5.dp,modifier = Modifier.padding(horizontal = 16.dp))}Row(modifier = Modifier.fillMaxWidth().padding(horizontal = 16.dp, vertical = 12.dp),verticalAlignment = Alignment.CenterVertically,horizontalArrangement = Arrangement.SpaceBetween) {Text(text = title,style = MaterialTheme.typography.bodyMedium.copy(color = Color.Black),modifier = Modifier.weight(1f))Box(modifier = Modifier.weight(1f)) {content()}}}}}
}// 使用示例
var username by remember { mutableStateOf("") }
var password by remember { mutableStateOf("") }IosStyleForm(items = listOf("账号" to {BasicTextField(value = username,onValueChange = { username = it },modifier = Modifier.fillMaxWidth(),textStyle = MaterialTheme.typography.bodyMedium.copy(textAlign = TextAlign.End))},"密码" to {BasicTextField(value = password,onValueChange = { password = it },modifier = Modifier.fillMaxWidth(),textStyle = MaterialTheme.typography.bodyMedium.copy(textAlign = TextAlign.End),visualTransformation = PasswordVisualTransformation())}),modifier = Modifier.padding(16.dp)
)

5. 动画效果增强

@Composable
fun AnimatedIosTextField(value: String,onValueChange: (String) -> Unit,modifier: Modifier = Modifier,label: String,placeholder: String
) {val animatedBorderColor by animateColorAsState(targetValue = if (value.isNotEmpty()) Color(0xFF007AFF) else Color(0xFFC7C7CC),label = "borderColorAnimation")Column(modifier = modifier) {Text(text = label,style = MaterialTheme.typography.bodyMedium,color = Color.Gray,modifier = Modifier.padding(bottom = 4.dp))Box(modifier = Modifier.fillMaxWidth().background(color = Color.White,shape = RoundedCornerShape(10.dp)).border(width = 1.dp,color = animatedBorderColor,shape = RoundedCornerShape(10.dp)).padding(horizontal = 16.dp, vertical = 12.dp)) {BasicTextField(value = value,onValueChange = onValueChange,modifier = Modifier.fillMaxWidth(),textStyle = MaterialTheme.typography.bodyMedium.copy(color = Color.Black),singleLine = true,decorationBox = { innerTextField ->Box {if (value.isEmpty()) {Text(text = placeholder,style = MaterialTheme.typography.bodyMedium.copy(color = Color(0xFFC7C7CC)))}innerTextField()}})}}
}

关键 iOS 风格特点实现

  1. 圆角设计

    shape = RoundedCornerShape(10.dp)
    
  2. 边框颜色

    borderColor = if (focused) Color(0xFF007AFF) else Color(0xFFC7C7CC)
    
  3. 占位符样式

    color = Color(0xFFC7C7CC)
    
  4. 清除按钮

    Icon(Icons.Default.Close, contentDescription = "清除")
    
  5. 分段列表样式

    Divider(color = Color(0xFFC6C6C8), thickness = 0.5.dp)
    

这些组件可以根据你的具体需求进一步定制,调整颜色、尺寸和动画效果,以达到更接近 iOS 设计风格的效果。

http://www.dtcms.com/wzjs/521200.html

相关文章:

  • 新网站没有死链接怎么做新闻发布最新新闻
  • 大大福利站网站建设不死鸟分享友情链接
  • 政府网站开发建设方案百度号码认证平台首页
  • 沈丘做网站yooker十大营销手段
  • 广州白云学校网站建设上海网络seo
  • 新疆哪里做网站百度网址提交入口
  • 深圳做响应式网站企业网站的推广方法有哪些
  • 做盗版小说网站能赚钱不2345浏览器网页版
  • WordPress和微信同步seo搜索引擎优化薪资
  • 如何做网站策划域名检测
  • 做网站兼容性如何处理重庆seo培训
  • 公司网站制做培训网站
  • 企业展示型网站信息流广告是什么
  • 建设银行信用卡网站是多少钱历下区百度seo
  • 国内精品在线网站建设windows优化大师官方下载
  • 做一个网站完整的网页百度知道app官方下载
  • 租车网站模板下载快速排名软件案例
  • 网站广告动态图怎么做如何自己制作一个网站
  • 云南做网站公司百度链接提交入口
  • 网站开发毕业设计ppt百度在线
  • 做酷炫网站能卖钱吗黑科技引流软件是真的吗
  • 大理中小企业网站建设武汉seo创造者
  • 枝江网站建设seo关键词优化外包
  • 短视频广告接单平台百度优化培训
  • 建设婚恋网站基本功能有哪些湖南做网站的公司
  • 中国证券监督管理委员会网站逆冬黑帽seo培训
  • 护肤品网站建设环境分析百度推广费用预算表
  • 网站开发实训的心得软文广告发布平台
  • 长沙建网站设计公司网络整合营销理论
  • 小程序端aso优化服务站