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

网站自己做自己的品牌好做做音乐相册的网站

网站自己做自己的品牌好做,做音乐相册的网站,企业建设电子商务网站的预期收益,厦门网站开发平台文章目录 需求概述效果展示实现思路代码实现总结 需求概述 我们经常能看到爱奇艺或者腾讯视频这类的视频APP在看电视剧的时候都会有一个选集的功能。如下图所示 这个功能其实很简单#xff0c;就是绘制一些方块#xff0c;在上面绘制上数字#xff0c;还有标签啥的。当用户… 文章目录 需求概述效果展示实现思路代码实现总结 需求概述 我们经常能看到爱奇艺或者腾讯视频这类的视频APP在看电视剧的时候都会有一个选集的功能。如下图所示 这个功能其实很简单就是绘制一些方块在上面绘制上数字还有标签啥的。当用户点击对应的数字式时可以切换到对应的剧集。如果剧集太多屏幕展示不完就可以滑动屏幕查看更多的剧集就这么一个很简单的UI小组件。我们使用Compose来实现下。 效果展示 如上图所示在UI的最上面是标题(选集)下面是我们绘制出的小方块。当小方块选中的时候会绘制一个指示器如果剧集太多就需要能上滑展示更多的剧集 如果剧集少的时候居左展示。如下 如果是横屏则如下展示 实现思路 可能很多读者会很容易的想到使用网格布局的控件LazyVerticalGrid实现如果说不需要透明背景的话这种方法是可行的而且性能也会很好但是如果要求背景可以设置透明度的话这种方式就不行了因为LazyVerticalGrid无法将背景设置成透明的如我们的效果展示图中可以看到我们的选集UI出现后还可以看到后面的背景如果使用LazyVerticalGrid则无法实现这个效果。所以我们采用的方式是直接通过for循环绘制。使用两个for循环分别负责绘制行和列然后再处理点击的回调和选中的指示器就行了我们可以使用Column,Box,Row,Text组件搭配使用这些组件都是可以设置透明度的能达到需求的效果。 代码实现 代码的实现很简单就是一个composable函数在代码中都做了注释所以就不多废话了原理也很简单就是通过两个for循环分别绘制行和列根据行和列之间的对应关系去计算显示的高度padding等。 /*** param row 需要展示的行数* param col 需要展示的列数* param contentPadding 内容的padding默认15dp* param displayRowCount 展示的函数比如这个值为7传入的row 为10那么只会展示7行多余的三行需要滑动查看,默认展示5行* param numberPadding 数字方块之间的padding默认11dp* param contentTopPadding 内容顶部的padding默认0dp* param currentNum 当前选中的数字需要根据它绘制指示器* param isPortrait 是否是竖屏需要根据横屏和竖屏来调整布局默认我是竖屏* param*/Composable fun ShowDramaSelectUI(row: Int,col: Int,contentPadding: Dp 15.dp,displayRowCount: Int 5,numberPadding: Dp 11.dp,contentTopPadding: Dp 0.dp,currentNum: Int 1,isPortrait: Boolean true,onNumSelect: (Int) - Unit ) {// 记录滚动的状态val scrollState rememberScrollState()val displayHeight // 根据显示的行数计算容器的高度下面的表达式不能换行否则根据kotlin的语法特性换行后的表达式不会参与计算// 这里的60dp是数字的方块的大小也可通过传参数指定(displayRowCount) * (60.dp).value (displayRowCount - 1) * numberPadding.value// 记录选中的数字var selectedNum by remember { mutableIntStateOf(currentNum) }Log.d(TAG, walt: selectedNum: $selectedNum)//背景蒙层Box(modifier Modifier.fillMaxSize().background(Color(0xCC000000)))Box(modifier Modifier.fillMaxSize().padding(top contentTopPadding,start contentPadding,end contentPadding),contentAlignment Alignment.TopCenter) {Column(modifier Modifier.wrapContentHeight().wrapContentWidth(),horizontalAlignment Alignment.CenterHorizontally) {Box(modifier Modifier.fillMaxWidth().padding(start 10.dp),contentAlignment Alignment.CenterStart) {Text(text 选集, style TextStyle(color Color(0xFF797F85),fontSize 14.sp,fontWeight FontWeight.Normal))} // 选集BoxSpacer(modifier Modifier.height(10.dp).fillMaxWidth())Column(modifier Modifier.height(displayHeight.dp).fillMaxWidth()// 让控件拥有滑动的能力.verticalScroll(scrollState),verticalArrangement Arrangement.Top,// 根据横竖屏设置对齐方式horizontalAlignment if ((isPortrait (col 5))|| (!isPortrait (col 10))) {Alignment.Start} else {Alignment.CenterHorizontally}) {// 绘制行for (i in 1..row) {Row(modifier Modifier.wrapContentWidth().wrapContentHeight()) {// 绘制列for (j in col * (i - 1) 1..(i - 1) * col col) {Box(modifier Modifier.size(60.dp).clip(RoundedCornerShape(6.dp)).background(Color(0x8031373D))// 回调选中的数字.clickable {selectedNum jonNumSelect(selectedNum)},contentAlignment Alignment.Center) {Text(text $j,style TextStyle(color Color.White,fontSize 20.sp,textAlign TextAlign.Center),)// 只有选中的数字和当前的数字相同时才会展示指示器if (j selectedNum) {Box(modifier Modifier.fillMaxSize(),contentAlignment Alignment.BottomCenter) {Divider(modifier Modifier.fillMaxWidth(),thickness 6.dp,color Color(0xFF037FF5))}}}// // 绘制两个列之间的间距如果不是最后一个item才加Spacerif ((j ! (i - 1) * col col)) {Spacer(modifier Modifier.height(60.dp).width(numberPadding))}}} // Row// 绘制行之前的间距Spacer(modifier Modifier.height(numberPadding).fillMaxWidth())}}}} }测试代码 class MainActivity : ComponentActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContent {MyComposeTheme {Box(modifier Modifier.fillMaxSize()){Image(painter painterResource(R.drawable.m10),modifier Modifier.fillMaxSize(),contentScale ContentScale.Crop,contentDescription null)ShowDramaSelectUI(row 10, col 10, isPortrait true, onNumSelect {num-Log.d(TAG,$num has selected1 !!!)})}}}} }总结 本文主要介绍的是一个剧集选集的功能这里只是介绍了实现的方式比较粗糙读者可以按照自己的需求修改有更好的实现方案也可以在评论区交流。本文主要起抛砖引玉的作用也是记录自己实现的一个小需求。给需要的小伙伴打个样欢迎交流指正。
http://www.w-s-a.com/news/876209/

相关文章:

  • 微信里的网站怎么做电子商务网站开发平台
  • 易企秀网站怎么做轮播图网站建设张世勇
  • 网站备案幕布尺寸建立网页的几个步骤
  • pc网站页面找出网站所有死链接
  • 专业做seo的网站网站内连接
  • 阿里云网站开发服务器想开网站建设公司
  • 网站开发不足之处茶叶seo网站推广与优化方案
  • 响应式网站建设系统网站优化怎么做 有什么技巧
  • 班级网站做哪些方面wordpress标签 扩展
  • 如何在电商上购物网站Wordpress 域名授权插件
  • 网站建设后台怎么弄昆明如何做好关键词推广
  • 自己怎么做个网站优酷视频网站开发
  • 2015做网站前景电子商务营销的发展现状
  • 官方网站建设情况说明电子商务网站开发的形式有
  • 网站建设玖金手指排名11专业建站公司建站系统
  • 全球排名前十网站百度网站官网网址
  • 商家在携程旅游网站怎样做宣传做网站公司苏州
  • 芜湖做网站都有哪些广州音乐制作公司
  • 青岛好的网站制作推广注册公司流程步骤
  • 怎么制作营销网站模板wordpress苗木模板
  • 手机网站样例wordpress 排序
  • 济南网站建设手机网站开发人员需要去做原型吗
  • 动易网站模板下载微信支付 wordpress
  • 学校建设外文网站情况阿里云 建设网站怎么样
  • 网站建设与网页设计制作深圳网站建设首选上榜网络
  • 网站浏览成交指标计算机应用是做什么的
  • 企业网站建设的要求wordpress 404页面模板
  • 公司怎么注册官方网站wordpress花园网站
  • 一般网站的建设步骤有哪些企业网站建设应该注意什么事项问题
  • 枣庄市建设局网站建设工程合同交底的内容包括