Flutter:商品多规格内容总结,响应式数据,高亮切换显示。
如图所示:
代码为练习时写的项目,写的一般,功能实现了,等以后再来优化。
自己模拟的数据结构
var data = {'id':1,'name':'精品小米等多种五谷杂粮精品小等多种五谷杂粮','logo':'https://cdn.uviewui.com/uview/swiper/1.jpg','price':100.5,'old_price':200.0,'stock':998,'images':[{'id':1,'src':'https://cdn.uviewui.com/uview/swiper/1.jpg',},{'id':2,'src':'https://cdn.uviewui.com/uview/swiper/2.jpg',},{'id':3,'src':'https://cdn.uviewui.com/uview/swiper/3.jpg',}],'sku':[{'name':'颜色','list':[{'id':8,'name':'红色',},{'id':9,'name':'蓝色'},{'id':10,'name':'白加黑'},{'id':11,'name':'紫色'},{'id':12,'name':'绿色'},]},{'name':'尺码','list':[{'id':13,'name':'S'},{'id':14,'name':'M'},{'id':15,'name':'L'},{'id':16,'name':'XL'},{'id':17,'name':'XXL'},]},]
};
GoodsModel
import 'package:get/get.dart';class GoodsModel {final int id;final String name;final String logo;final double price;final double oldPrice;final int stock;final List<Image> images;final List<Sku> sku;GoodsModel({required this.id,required this.name,required this.logo,required this.price,required this.oldPrice,required this.stock,required this.images,required this.sku,});// 从JSON对象创建GoodsModel实例factory GoodsModel.fromJson(Map<String, dynamic> json) {return GoodsModel(id: json['id'] as int,name: json['name'] as String,logo: json['logo'] as String,price: json['price'] as double,oldPrice: json['old_price'] as double,stock: json['stock'] as int,images: List.from(json['images'] as List).map((e) => Image.fromJson(e)).toList(),sku: List.from(json['sku'] as List).map((e) => Sku.fromJson(e)).toList(),);}// 将GoodsModel实例转换为JSON对象Map<String, dynamic> toJson() {return {'id': id,'name': name,'logo': logo,'price': price,'old_price': oldPrice,'stock': stock,'images': images.map((e) => e.toJson()).toList(),'sku': sku.map((e) => e.toJson()).toList(),};}
}class Image {final int id;final String src;Image({required this.id,required this.src,});// 从JSON对象创建Image实例factory Image.fromJson(Map<String, dynamic> json) {return Image(id: json['id'] as int,src: json['src'] as String,);}// 将Image实例转换为JSON对象Map<String, dynamic> toJson() {return {'id': id,'src': src,};}
}class Sku {final String name;final List<SkuItem> list;Sku({required this.name,required this.list,});// 从JSON对象创建Sku实例factory Sku.fromJson(Map<String, dynamic> json) {return Sku(name: json['name'] as String,list: List.from(json['list'] as List).map((e) => SkuItem.fromJson(e)).toList(),);}// 将Sku实例转换为JSON对象Map<String, dynamic> toJson() {return {'name': name,'list': list.map((e) => e.toJson()).toList(),};}
}class SkuItem {final int id;final String name;RxBool show; // 自定义响应式变量,判断当前项是否选中SkuItem({required this.id,required this.name,bool showValue = false, // 默认false}) : show = RxBool(showValue);// 从JSON对象创建SkuItem实例factory SkuItem.fromJson(Map<String, dynamic> json) {return SkuItem(id: json['id'] as int,name: json['name'] as String,showValue: false, // JSON 数据中没有 show 字段,所以自定义设置为 false);}// 将SkuItem实例转换为JSON对象Map<String, dynamic> toJson() {return {'id': id,'name': name,};}
}
在GoodsModel
中,要确保sku
下的SkuItem
中,每一项都需要添加一个动态响应式数据show
字段来实现规格切换高亮显示,
controller
import 'package:flutter_aidishi/utils/loading.dart';
import 'package:get/get.dart';
import '../../../models/home/goods_detail.dart';class GoodsDetailController extends GetxController {GoodsDetailController();final ProductId = Get.arguments['id'];GoodsModel? goodsDetail; // 商品详情List<Image> bannerList = []; // 商品列表RxList<Sku> skuList = RxList<Sku>([]); // 直接指定类型为RxListList skuSelected = []; // 选中后的skubool loading = false; // 提交状态int type = 1; // 下单状态,1加入购物车,2立即购买RxInt payNum = 1.obs; // 下单数量_initData() {// 模拟接口请求var data = {'id':1,'name':'精品小米等多种五谷杂粮精品小等多种五谷杂粮','logo':'https://cdn.uviewui.com/uview/swiper/1.jpg','price':100.5,'old_price':200.0,'stock':998,'images':[{'id':1,'src':'https://cdn.uviewui.com/uview/swiper/1.jpg',},{'id':2,'src':'https://cdn.uviewui.com/uview/swiper/2.jpg',},{'id':3,'src':'https://cdn.uviewui.com/uview/swiper/3.jpg',}],'sku':[{'name':'颜色','list':[{'id':8,'name':'红色',},{'id':9,'name':'蓝色'},{'id':10,'name':'白加黑'},{'id':11,'name':'紫色'},{'id':12,'name':'绿色'},]},{'name':'尺码','list':[{'id':13,'name':'S'},{'id':14,'name':'M'},{'id':15,'name':'L'},{'id':16,'name':'XL'},{'id':17,'name':'XXL'},]},]};goodsDetail = GoodsModel.fromJson(data);bannerList = goodsDetail!.images;// 使用assignAll方法将普通的List<Sku>赋值给RxList<Sku>。这是GetX库中推荐的方法来填充响应式列表。skuList.assignAll(goodsDetail!.sku); // 正确地将List<Sku>转换为RxList<Sku>update(["goods_detail"]);}// 更改数量onTapChangePayNum(int value){payNum.value = value;}// SKU切换void onTapChangeSku(index,i){// 先循环,当前点击的小规格默认全部为falseskuList[index].list.forEach((sku)=> sku.show.value = false);// 在赋值,当前点击项trueskuList[index].list[i].show.value = true;update(["goods_detail"]);}// 下单void submit(){// 每次先清空,在去把已选择的sku放到skuSelected中skuSelected.clear();skuList.forEach((item){item.list.forEach((val){if(val.show.value){skuSelected.add(val);}});});if(skuSelected.length != skuList.length){Loading.error('请先选择完整规格');}else{print('下单方式:$type,购买数量:$payNum,看看选择了哪些规格:${skuSelected[0].id},${skuSelected[1].id}');}}@overridevoid onInit() {super.onInit();}@overridevoid onReady() {super.onReady();_initData();}@overridevoid onClose() {super.onClose();}
}
view
import 'package:flutter/material.dart';
import 'package:flutter_aidishi/extension/index.dart';
import 'package:flutter_aidishi/widget/index.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:get/get.dart';
import 'package:tdesign_flutter/tdesign_flutter.dart';
import 'package:flutter_swiper_null_safety/flutter_swiper_null_safety.dart';import 'index.dart';class GoodsDetailPage extends GetView<GoodsDetailController> {const GoodsDetailPage({super.key});// 轮播图Widget _buildBanner() {return Container(height: 312.w,child: Swiper(autoplay: true, // 自动轮播itemCount: 2, // 轮播数量loop: true, // 循环pagination: const SwiperPagination(alignment: Alignment.bottomCenter, // 指示器位置builder: TDSwiperPagination.dotsBar, // 具体样式),itemBuilder: (BuildContext context, int index) {return GestureDetector(onTap: (){print('点击了第$index个图片');},// child: TDImage(imgUrl: controller.bannerList[index].src,),child: TDImage(assetUrl: 'assets/images/banner.png',type: TDImageType.square,),);},),);}// 商品信息Widget _buildGoodsName() {return Container(padding: EdgeInsets.only(left: 15.w,right: 15.w,top: 20.w,bottom: 20.w),width: 375.w,color: Colors.white,child: <Widget>[Text("${controller.goodsDetail?.name}",maxLines: 2,overflow: TextOverflow.ellipsis,style: TextStyle(fontSize: 15.sp,fontWeight: FontWeight.bold),),SizedBox(height: 15.w,),<Widget>[<Widget>[Text('¥',style: TextStyle(fontSize: 13.sp,color: AppColors.mainColor),),Text('${controller.goodsDetail?.price}',style: TextStyle(fontSize: 24.sp,color: AppColors.mainColor),),Text('/现价',style: TextStyle(fontSize: 13.sp,color: AppColors.mainColor),),SizedBox(width: 10.w,),Text('¥${controller.goodsDetail?.oldPrice}/原价',style: TextStyle(fontSize: 14.sp,color: AppColors.Color999,decoration: TextDecoration.lineThrough,decorationColor: AppColors.Color999),)].toRow(crossAxisAlignment: CrossAxisAlignment.baseline,textBaseline: TextBaseline.alphabetic),Text('库存 ${controller.goodsDetail?.stock}',style: TextStyle(fontSize: 11.sp,color: AppColors.Color999),)].toRow(mainAxisAlignment: MainAxisAlignment.spaceBetween)].toColumn(crossAxisAlignment: CrossAxisAlignment.start),);}// 商品详情Widget _buildGoodsDetail() {return <Widget>[SizedBox(height: 10.w,),<Widget>[Container(width: 50.w,height: 1,color: Color(0xffe1e1e1),),SizedBox(width: 10.w,),Text('商品详情',style: TextStyle(fontSize: 11.sp,color: AppColors.Color999),),SizedBox(width: 10.w,),Container(width: 50.w,height: 1,color: Color(0xffe1e1e1),),].toRow(mainAxisAlignment: MainAxisAlignment.center,),SizedBox(height: 10.w,),Container(height: 500.w,color: Colors.blueGrey,child: Center(child: Text('富文本'),),)].toColumn();}// 可滚动内容区域Widget _buildTop(){return SingleChildScrollView(child: <Widget>[_buildBanner(),SizedBox(height: 15.w,),_buildGoodsName(),_buildGoodsDetail(),].toColumn(),);}// 底部悬浮按钮Widget _buildGoodsFoot(BuildContext context) {return <Widget>[GestureDetector(onTap: (){print('弹出购物车');controller.type = 1;Navigator.of(context).push(TDSlidePopupRoute(modalBarrierColor: TDTheme.of(context).fontGyColor2,slideTransitionFrom: SlideTransitionFrom.bottom,builder: (context) {return Container(width: 375.w,height: 500.w,decoration: BoxDecoration(color: Colors.white,borderRadius: BorderRadius.only(topLeft: Radius.circular(10.w),topRight: Radius.circular(10.w)),),child: _buildFootPopup(context),);}));},child: Container(width: 187.5.w,height: 49.w,color: Colors.white,child: Center(child: Text('加入购物车',style: TextStyle(fontSize: 14.sp),),),)),GestureDetector(onTap: (){print('立即结算');controller.type = 2;Navigator.of(context).push(TDSlidePopupRoute(modalBarrierColor: TDTheme.of(context).fontGyColor2,slideTransitionFrom: SlideTransitionFrom.bottom,builder: (context) {return Container(width: 375.w,height: 500.w,decoration: BoxDecoration(color: Colors.white,borderRadius: BorderRadius.circular(10.w)),child: _buildFootPopup(context),);}));},child: Container(width: 187.5.w,height: 49.w,color: AppColors.mainColor,child: Center(child: Text('立即购买',style: TextStyle(fontSize: 14.sp,color: AppColors.Colorfff),),),)),].toRow();}// 多规格弹窗Widget _buildFootPopup(BuildContext context){return Container(padding: EdgeInsets.all(15.w),child: <Widget>[// 商品信息<Widget>[TDImage(assetUrl: 'assets/images/goods.png',type: TDImageType.roundedSquare,width: 74,height: 74,),Container(width: 220.w,child: <Widget>[Text('精品小米等多种五谷杂粮精品小米等多精品小米等多种五谷杂粮精品小米等多种五谷杂粮种五谷杂粮',maxLines: 2,overflow: TextOverflow.ellipsis,style: TextStyle(fontSize: 14.sp,fontWeight: FontWeight.bold),),SizedBox(height: 10.w,),<Widget>[Text('¥',style: TextStyle(fontSize: 12.sp,color: AppColors.mainColor),),Text('2500',style: TextStyle(fontSize: 16.sp,color: AppColors.mainColor),),Text('/现价',style: TextStyle(fontSize: 12.sp,color: AppColors.mainColor),),SizedBox(width: 10.w,),Text('¥2000/原价',style: TextStyle(fontSize: 10.sp,color: AppColors.Color999,decoration: TextDecoration.lineThrough,decorationColor: AppColors.Color999),)].toRow(crossAxisAlignment: CrossAxisAlignment.baseline,textBaseline: TextBaseline.alphabetic)].toColumn(),),GestureDetector(onTap: ()=> Navigator.of(context).pop(),child: TDImage(assetUrl: 'assets/images/close.png',type: TDImageType.roundedSquare,width: 20,height: 20,),)].toRow(crossAxisAlignment: CrossAxisAlignment.start,mainAxisAlignment: MainAxisAlignment.spaceBetween),SizedBox(height: 15.w,),Container(width: 345.w,height: 1,color: Color(0xfff5f5f5),),SizedBox(height: 10.w,),// 库存<Widget>[Text('库存:886',style: TextStyle(fontSize: 13.sp),),<Widget>[Text('数量',style: TextStyle(fontSize: 13.sp),),SizedBox(width: 10.w,),// 选择数量TDStepper(theme: TDStepperTheme.filled,value:controller.payNum.value,min:1,onChange:(value){controller.onTapChangePayNum(value);})].toRow()].toRow(mainAxisAlignment: MainAxisAlignment.spaceBetween),SizedBox(height: 20.w,),Container(height: 260.w, // 固定高度color: Colors.white, // 可选:可改成灰色,查看滚动区域child: SingleChildScrollView(// 如果内容在垂直方向上超出Container的高度,则可以滚动child: Column(// 使用Column来垂直排列子组件children: <Widget>[// 大规格for(var index = 0;index<controller.skuList.length;index++)<Widget>[Container(width: 375.w,child: Text('${controller.skuList[index].name}'),),SizedBox(height: 10.w,),<Widget>[// 小规格// for(var val in item.list)for(var i = 0;i<controller.skuList[index].list.length;i++)GestureDetector(onTap: (){controller.onTapChangeSku(index,i);},child: Obx(() =>Container(margin: EdgeInsets.only(right: 20.w,bottom: 20.w,left: 0),padding: EdgeInsets.only(left: 30.w,right: 30.w,top: 6.w,bottom: 6.w),child: Text('${controller.skuList[index].list[i].name}'),decoration: BoxDecoration(color: controller.skuList[index].list[i].show.value ? Color(0xffffffff) : Color(0xffF8F8F8),borderRadius: BorderRadius.circular(5.w),border: Border.all(color: controller.skuList[index].list[i].show.value ? Color(0xffFF770F) : Color(0xff999999),width: 1.0)),)),)].toWrap()].toColumn(crossAxisAlignment: CrossAxisAlignment.start),// 你可以继续添加更多的子组件],),),),// 结算SizedBox(height: 20.w,),Container(width: 345.w,child: TDButton(text: '确定', // 按钮文案height: 43.w, // 自定义高度// 文案左侧图标,根据提交状态判断是否显示loadingiconWidget: controller.loading ? TDLoading(size: TDLoadingSize.small,icon: TDLoadingIcon.circle,) : Container(),size: TDButtonSize.large, // 按钮尺寸type: TDButtonType.fill, // 类型:填充,描边,文字theme: TDButtonTheme.primary, // 主题shape: TDButtonShape.round, // 形状:圆角,胶囊,方形,圆形,填充 rectangle, round, square, circle, filledisBlock: true, // 是否时BlockonTap:controller.submit, // 点击提交按钮触发padding: EdgeInsets.all(0),margin: EdgeInsets.all(0),),)].toColumn(),);}// 主视图Widget _buildView(BuildContext context) {return <Widget>[_buildTop().expanded(),_buildGoodsFoot(context)].toColumn();}@overrideWidget build(BuildContext context) {return GetBuilder<GoodsDetailController>(init: GoodsDetailController(),id: "goods_detail",builder: (_) {return Scaffold(appBar: AppBar(title: const Text("goods_detail")),body: _buildView(context),backgroundColor: Color(0xffF6F6F6),);},);}
}
相关文章:
Flutter:商品多规格内容总结,响应式数据,高亮切换显示。
如图所示: 代码为练习时写的项目,写的一般,功能实现了,等以后再来优化。 自己模拟的数据结构 var data {id:1,name:精品小米等多种五谷杂粮精品小等多种五谷杂粮,logo:https://cdn.uviewui.com/uview/swiper/1.jpg,price:100.5…...
WPF+LibVLC开发播放器-LibVLC播放控制
接上一篇: LibVLC在C#中的使用 实现LibVLC播放器播放控制 界面 界面上添加一个Button按钮用于控制播放 <ButtonGrid.Row"1"Width"88"Height"24"Margin"10,0,0,0"HorizontalAlignment"Left"VerticalAlignme…...
Mac环境下brew安装LNMP
安装不同版本PHP 在Mac环境下同时运行多个版本的PHP,同Linux环境一样,都是将后台运行的php-fpm设置为不同的端口号,下面将已php7.2 和 php7.4为例 添加 tap 目的:homebrew仅保留最近的php版本,可能没有你需要的版本…...
nodejs后端项目使用pm2部署
nodejs后端项目使用pm2部署 安装pm2 npm install pm2 -g查看版本号 pm2 --version启动项目 pm2 start app.js# 设置别名 pm2 start app.js --name demo停止项目 pm2 stop [AppName] pm2 stop [ID]# 停止所有项目 pm2 stop all重启项目 pm2 restart [AppName] pm2 re…...
【C++】深入理解字符变量取地址的特殊性与内存管理机制详解
博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯栈内存中的变量分配:谁先谁后?cout 的输出行为:按顺序执行,按地址递增读取代码执行顺序与内存布局的关系编译器优化的影响 &…...
【银河麒麟操作系统真实案例分享】内存黑洞导致服务器卡死分析全过程
了解更多银河麒麟操作系统全新产品,请点击访问 麒麟软件产品专区:https://product.kylinos.cn 开发者专区:https://developer.kylinos.cn 文档中心:https://documentkylinos.cn 现象描述 机房显示器连接服务器后黑屏ÿ…...
蓝桥杯软件赛系列---lesson1
🌈个人主页:羽晨同学 💫个人格言:“成为自己未来的主人~” 我们今天会再开一个系列,那就是蓝桥杯系列,我们会从最基础的开始讲起,大家想要备战明年蓝桥杯的,让我们一起加油。 工具安装 DevC…...
工业异常检测-CVPR2024-新的3D异常数据合成办法和自监督网络IMRNet
论文:https://arxiv.org/pdf/2311.14897v3.pdf 项目:https://github.com/chopper-233/anomaly-shapenet 这篇论文主要关注的是3D异常检测和定位,这是一个在工业质量检查中至关重要的任务。作者们提出了一种新的方法来合成3D异常数据&#x…...
HeidiSQL:MySQL图形化管理工具深度解析
本文还有配套的精品资源,点击获取 简介:HeidiSQL是一款开源的MySQL图形化管理工具,适用于多种数据库系统,如MySQL、MariaDB、SQL Server、PostgreSQL和SQLite。其提供的直观操作界面和丰富的功能简化了数据库操作,包…...
【Redis】深入解析Redis缓存机制:全面掌握缓存更新、穿透、雪崩与击穿的终极指南
文章目录 一、Redis缓存机制概述1.1 Redis缓存的基本原理1.2 常见的Redis缓存应用场景 二、缓存更新机制2.1 缓存更新的策略2.2 示例代码:主动更新缓存 三、缓存穿透3.1 缓存穿透的原因3.2 缓解缓存穿透的方法3.3 示例代码:使用布隆过滤器 四、缓存雪崩4…...
Flask使用Celery与多进程管理:优雅处理长时间任务与子进程终止技巧(multiprocessing)(subprocess)
在许多任务处理系统中,我们需要使用异步任务队列来处理繁重的计算或长时间运行的任务,如模型训练。Celery是一个广泛使用的分布式任务队列,而在某些任务中,尤其是涉及到调用独立脚本的场景中,我们需要混合使用multipro…...
【PyTorch】torch.distributed.elastic.multiprocessing.errors.ChildFailedError:
报错说明 torch.distributed.elastic.multiprocessing.errors.ChildFailedError: 报错如图所示 报错分析 该报错是 torch 和 CUDA 版本不兼容导致。 (一般N卡自带的CUDA版本与最新的torch版本相差较大) 解决方案 1.查看自己的CUDA版本 # 查看自己的…...
使用android studio写一个Android的远程通信软件(APP),有通讯的发送和接收消息界面
以下是使用 Android Studio 基于 Java 语言编写一个简单的 Android APP 实现远程通信(这里以 TCP 通信为例)的代码示例,包含基本的通信界面以及发送和接收消息功能。 1. 创建项目 打开 Android Studio,新建一个 Empty Activity …...
突破空间限制!从2D到3D:北大等开源Lift3D,助力精准具身智能操作!
文章链接:https://arxiv.org/pdf/2411.18623 项目链接:https://lift3d-web.github.io/ 亮点直击 提出了Lift3D,通过系统地提升隐式和显式的3D机器人表示,提升2D基础模型,构建一个3D操作策略。 对于隐式3D机器人表示&a…...
Android KEY的哪些事儿
目录 一、APK应用签名 1、什么是APK应用签名? 1.1 目的和作用? 1.2 长什么样子? 2、APK应用签名使用流程 步骤一:如何生成APK应用签名文件? 步骤二:如何集成APK应用签名文件? 步骤三&am…...
李宏毅深度学习-Pytorch Tutorial2
什么是张量? 张量(Tensor)是深度学习和机器学习中一个非常基础且重要的概念。在数学上,张量可以被看作是向量和矩阵的泛化。简单来说,张量是一种多维数组,它可以表示标量(0维)、向量…...
【译】为 SAP 表维护视图 (SM30) 创建选择屏幕
原文标题:Create Selection Screen for SAP Table Maintenance View (SM30) 原文链接: https://www.saphub.com/abap-dictionary/sap-abap-tmg-selection-screen/ 通常,带有单个屏幕的 SAP 表维护视图 (SM30) 会显示表中的所有记录ÿ…...
element Plus中 el-table表头宽度自适应,不换行
在工作中,使用el-table表格进行开发后,遇到了小屏幕显示器上显示表头文字会出现换行展示,比较影响美观,因此需要让表头的宽度变为不换行,且由内容自动撑开。 以下是作为工作记录,用于demo演示教程 先贴个…...
C语言程序设计P5-4【应用函数进行程序设计 | 第四节】——知识要点:数组作函数参数
知识要点:数组作函数参数 视频: 目录 一、任务分析 二、必备知识与理论 三、任务实施 一、任务分析 任务要求用选择法对数组中的 10 个整数按由小到大的顺序排序,前面在讲解数组时讲冒泡法排序曾提到选择法排序的思想。 所谓选择法就是…...
时间序列模型在LSTM中的特征输入
这里写目录标题 前言LSTM的输入组成时间步例子 实际代码解读特征提取处理成dataloader格式(用于输入到模型当中)对应到lstm的模型创建代码 总结 前言 本文章将帮助理解如何将一个时间序列的各种特征(年月日的时间特征,滚动窗口滞…...
Python_Flask02
所有人都不许学Java了,都来学Python! 如果不来学的话请网爆我的老师 连接前的准备 安装pymysql 和 flask_sqlalchemy,安装第三下面两个所需要的包才能连接上数据库 pip install pymysql pip install flask_sqlalchemy pymysql是一个Pyth…...
threejs相机辅助对象cameraHelper
为指定相机创建一个辅助对象,显示这个相机的视锥。 想要在场景里面显示相机的视锥,需要创建两个相机。 举个例子,场景中有个相机A,想要显示相机A的视锥,那么需要一个相机B,把B放在A的后面,两个…...
断点续传+测试方法完整示例
因为看不懂网上的断点续传案例,而且又不能直接复制使用,干脆自己想想写了一个。 上传入参类: import com.fasterxml.jackson.annotation.JsonIgnore; import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModelProp…...
C#设计模式--状态模式(State Pattern)
状态模式是一种行为设计模式,它允许对象在其内部状态发生变化时改变其行为。这种模式的核心思想是将状态封装在独立的对象中,而不是将状态逻辑散布在整个程序中。 用途 简化复杂的条件逻辑:通过将不同的状态封装在不同的类中,可…...
Excel技巧:如何批量调整excel表格中的图片?
插入到excel表格中的图片大小不一,如何做到每张图片都完美的与单元格大小相同?并且能够根据单元格来改变大小?今天分享,excel表格里的图片如何批量调整大小。 方法如下: 点击表格中的一个图片,然后按住Ct…...
hadoop中导出表与数据的步骤
大家好,我是 V 哥。在Hadoop中导出表与数据,可以通过多种方式实现,包括使用Hive的EXPORT命令、MapReduce作业、Hive查询以及Sqoop工具。下面V 哥将详细介绍这些步骤和一些代码示例,来帮助大家更好理解。 1. 使用Hive的EXPORT命令…...
springBoot中的日志级别在哪里配置
在Spring Boot中,日志级别的配置可以通过多种方式来实现,主要包括在配置文件中设置、使用自定义的logback配置文件,以及在代码中动态配置等。以下是一些具体的配置方法: 一、在配置文件中设置日志级别 Spring Boot默认使用appli…...
17. Threejs案例-Three.js创建多个立方体
17. Threejs案例-Three.js创建多个立方体 实现效果 知识点 WebGLRenderer (WebGL渲染器) WebGLRenderer 是 Three.js 中用于渲染 WebGL 场景的核心类。它负责将场景中的对象渲染到画布上。 构造器 new THREE.WebGLRenderer(parameters) 参数类型描述parametersObject可选…...
数据结构——有序二叉树的删除
在上一篇博客中,我们介绍了有序二叉树的构建、遍历、查找。 数据结构——有序二叉树的构建&遍历&查找-CSDN博客文章浏览阅读707次,点赞18次,收藏6次。因为数据的类型决定数据在内存中的存储形式。left right示意为左右节点其类型也为…...
力扣1401. 圆和矩形是否有重叠
用矢量计算: class Solution { public:bool checkOverlap(int radius, int xCenter, int yCenter, int x1, int y1, int x2, int y2) {//矩形中心float Tx(float)(x1x2)/2;float Ty(float)(y1y2)/2;//强行进行对称操作,只考虑第一象限if(xCenter<Tx)…...
idea连接到docker出现 org.apache.hc.client5.http.ConnectTimeoutException 异常怎么办?
前情提要 我电脑是win11,我安装了centOS7虚拟机,配置linux环境 idea是2024社区免费版本 我就这一步步排查问题,终于发现了是因为我的2375端口没有ipv4开放,只在ipv6开放 踩坑提醒: 对了,一个一个问题排…...
一番赏小程序定制开发,打造全新抽赏体验平台
随着盲盒的热潮来袭,作为传统的潮玩方式一番赏也再次受到了大家的关注,市场热度不断上升! 一番赏能够让玩家百分百中奖,商品种类丰富、收藏价值高,拥有各种IP,从而吸引着各个圈子的粉丝玩家,用…...
PHP语法学习(第六天)
💡依照惯例,回顾一下昨天讲的内容 PHP语法学习(第五天)主要讲了PHP中的常量和运算符的运用。 🔥 想要学习更多PHP语法相关内容点击“PHP专栏” 今天给大家讲课的角色是🍍菠萝吹雪,“我菠萝吹雪吹的不是雪,而…...
按vue组件实例类型实现非侵入式国际化多语言翻译
#vue3##国际化##本地化##international# web界面国际化,I18N(Internationalization,国际化),I11L(International,英特纳雄耐尔),L10N(Localization,本地化)&…...
2024年认证杯SPSSPRO杯数学建模B题(第一阶段)神经外科手术的定位与导航解题全过程文档及程序
2024年认证杯SPSSPRO杯数学建模 B题 神经外科手术的定位与导航 原题再现: 人的大脑结构非常复杂,内部交织密布着神经和血管,所以在大脑内做手术具有非常高的精细和复杂程度。例如神经外科的肿瘤切除手术或血肿清除手术,通常需要…...
51c视觉~合集24
我自己的原文哦~ https://blog.51cto.com/whaosoft/11870494 #R-Adapter 零样本模型微调新突破,提升鲁棒性与泛化能力 论文提出新颖的Robust Adapter(R-Adapter),可以在微调零样本模型用于下游任务的同时解决这两个问题。该方…...
idea启动tomcat服务中文乱码
在idea中启动tomcat服务后部分中文乱码 但是在tomcat日志部分正常 并且在tomcat中中文也是正常 查询大量资料修改idea编码,虚拟机编码、tomcat默认编码、终端默认编码,统统没有效果。 最终发现修改tomcat下文件夹 .\conf\logging.properties 网络上…...
android studio 读写文件操作(应用场景二)
android studio版本:2023.3.1 patch2 例程:readtextviewIDsaveandread 本例程是个过渡例程,如果单是实现下图的目的有更简单的方法,但这个方法是下一步工作的基础,所以一定要做。 例程功能:将两个textvi…...
【数据结构】【线性表】特殊的线性表-字符串
目录 字符串的基本概念 字符串的三要素 字符串的基本概念 串的编码 串的实现及基本运算 顺序串的实现 串的静态数组实现 串的动态数组的实现 顺序存储的四种方案 链式串的实现 基本运算 方案三 方案一 字符串的基本概念 数据结构千千万,…...
【AWS re:Invent 2024】一文了解EKS新功能:Amazon EKS Auto Mode
文章目录 一、为什么要使用 Amazon EKS Auto Mode?二、Amazon EKS自动模式特性2.1 持续优化计算成本2.2 迁移集群操作2.3 EKS 自动模式的高级功能 三、EKS Auto 集群快速创建集群配置四、查看来自 API 服务器的指标五、EKS 相关角色权限设置六、参考链接 一、为什么…...
HTTPS的工作过程
1.HTTPS协议原理 1.1HTTPS协议的由来 HTTP在传输网络数据的时候是明文传输的,信息容易被窃听甚至篡改,因此他是一个不安全的协议(但效率高)。在如今的网络环境中,数据安全是很重要的(比如支付密码又或者各…...
Java并发编程学习之从资本家的角度看多线程和并发性(一)
目录 前言前置知识一、单线程时代二、为什么要有多线程,多线程的优点?三、使用多线程会遇到什么问题?四、多线程和并发编程的关系总结 前言 这篇文章是打开Java多线程和并发编程的大门的开始,如标题《从老板的角度看多线程和并发…...
基于STM32设计的智能宠物喂养系统(华为云IOT)_273
文章目录 一、前言1.1 项目介绍【1】项目开发背景【2】设计实现的功能【3】项目硬件模块组成【4】设计意义【5】国内外研究现状【6】摘要1.2 设计思路1.3 系统功能总结1.4 开发工具的选择【1】设备端开发【2】上位机开发1.5 参考文献1.6 系统框架图1.7 系统原理图1.8 实物图1.9…...
Mybatis-Plus的主要API
一、实体类操作相关API BaseMapper<T>接口 功能:这是 MyBatis - Plus 为每个实体类对应的 Mapper 接口提供的基础接口。它提供了一系列基本的 CRUD(增删改查)操作方法。例如insert(T entity)方法用于插入一条记录,d…...
Pillow:强大的Python图像处理库
目录 一、引言 二、Pillow 库的安装 三、Pillow 库的基本概念 四、图像的读取和保存 五、图像的基本属性 六、图像的裁剪、缩放和旋转 七、图像的颜色调整 八、图像的滤镜效果 九、图像的合成和叠加 十、图像的绘制 十一、示例程序:制作图片水印 十二、…...
Springboot定时任务详解
文章目录 Springboot定时任务详解一、引言二、cron表达式三、使用Scheduled注解1、开启定时任务2、添加定时任务 四、使用TaskScheduler接口1、注入TaskScheduler实例 五、集成Quartz框架1、集成Quartz 六、实际使用示例七、总结 Springboot定时任务详解 一、引言 在现代软件…...
【Linux】环境ChatGLM-4-9B 模型之 openai API 服务
一、摘要 最近看到 Function Call 比较感兴趣,它的核心是赋予大模型能够调用外部API的能力,能够解决大模型功能扩展性问题,允许模型调用外部数据库或API,提供特定领域的详细信息;解决信息实时性问题,模型可以实时获取最新数据;解决数据局限性问题,大模型训练数据虽多但…...
mobi文件转成pdf
将 MOBI 文件转换为 PDF 格式通常涉及两个步骤: 解析 MOBI 文件:需要提取 MOBI 文件的内容(文本、图片等)。将提取的内容转换为 PDF:将 MOBI 文件的内容渲染到 PDF 格式。 可用工具 kindleunpack 或 mobi࿱…...
Linux---对缓冲区的简单理解--第一个系统程序
前序: 首先先理解一下什么是回车与换行;回车和换行是两个概念,它们不是一个东西; 回车:光标回到开始;换行:换到下一行; 如下图: 行缓冲区 如何理解缓冲区问题? 可以认为࿰…...
word poi-tl 表格功能增强,实现表格功能垂直合并
目录 问题解决问题poi-tl介绍 功能实现引入依赖模版代码效果图 附加(插件实现)MergeColumnData 对象MergeGroupData 类ServerMergeTableData 数据信息ServerMergeTablePolicy 合并插件 问题 由于在开发功能需求中,word文档需要垂直合并表格&…...