下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
【移动应用开发技术】怎么在iOS中实现一个按比例拼图功能
本篇文章给大家分享的是有关怎么在iOS中实现一个按比例拼图功能,在下觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着在下一起来看看吧。要求:各个模块的大小反映各个模块的占比(销售额),所有模块共同组成一个正方形。后台返回的数据格式:{
"result":
true,
"data":
{
"category_sale":
[
{
"name":
"我是你的哥",
"sale_amount":
1,
"gross_margin_ratio":
0.22
},
{
"name":
"不是亲哥哥",
"sale_amount":
4,
"gross_margin_ratio":
0
},
{
"name":
"呵呵哒",
"sale_amount":
3,
"gross_margin_ratio":
0.19
},
{
"name":
"因缺思厅",
"sale_amount":
2,
"gross_margin_ratio":
0.4
}]
},
"msg":
"ok",
"code":
200,
"executed":
"0.0320830345"
}注:gross_margin_ratio代表“毛利率”,不是模块的占比。分析第一眼看到这个原型图的时候我就觉得不简单,后面和Android一起研究了一下,也没有想到什么好的算法。正巧那天上司跑来问我们有没有什么需要帮忙的,我赶紧把这个问题扔给他。一周后,他给我说了思路:每一排放三个,让它们的高度一致。每一排放三个,让它们的高度一致。经他这么一点,这个问题立即就不是问题了(放3个还是放两个通过开方得到最合适的值)。一排放三个模块,三个一组组成一个矩形,这一组的总面积确定,宽确定,那么高就确定了。高确定,每个模块的面积确定,每个模块的宽也就确定了。至于排版交给UICollectionView就行了。实现效果如下:核心代码:-
(void)setModel:(CQCategoryModel
*)model
{
_model
=
model;
CGFloat
totalSaleAmount
=
0;
for
(CQCategoryItemModel
*itemModel
in
_model.category_sale)
{
totalSaleAmount
+=
itemModel.sale_amount;
}
for
(CQCategoryItemModel
*itemModel
in
_model.category_sale)
{
if
(totalSaleAmount
==
0)
{
//
特殊处理只有一个item,并且SaleAmount还是0的情况
itemModel.ratio
=
1;
}
else
{
itemModel.ratio
=
itemModel.sale_amount/totalSaleAmount;
}
}
//
计算列数
NSInteger
listCount
=
0;
for
(int
i
=
0;
i
<
_model.category_sale.count;
i++)
{
if
(i
*
i
<
_model.category_sale.count
&&
(i+1)
*
(i+1)
>=
_model.category_sale.count)
{
listCount
=
i+1;
break;
}
}
//
计算行数
NSInteger
rowCount
=
ceil(_model.category_sale.count
/
(CGFloat)listCount);
//
这个方阵是listCount*rowCount的矩阵(最后一排可能不足listCount)
//
同一排的cell高度相同
for
(int
i
=
0;
i
<
rowCount;
i++)
{
//
行
CGFloat
rowArea
=
0;
//
行面积
for
(int
j
=
0;
j
<
listCount;
j++)
{
//
列
if
(i*listCount+j>=_model.category_sale.count)
{
break;
}
CQCategoryItemModel
*itemModel
=
_model.category_sale[i*listCount+j];
itemModel.size
=
itemModel.ratio
*
(self.collectionView.width*self.collectionView.width);
rowArea
+=
itemModel.size;
}
//
计算cell的宽高
for
(int
j
=
0;
j
<
listCount;
j++)
{
//
列
if
(i*listCount+j>=_model.category_sale.count)
{
break;
}
CQCategoryItemModel
*itemModel
=
_model.category_sale[i*listCount+j];
itemModel.height
=
rowArea
/
self.collectionView.width;
itemModel.width
=
itemModel.size
/
itemModel.height;
}
}
[self.collectionView
reloadData];
}
-
(CGSize)collectionView:(UICollectionView
*)collectionView
layout:(UICollectionViewLayout
*)collectionViewLayout
sizeForItemAtIndexPath:(NSIndexPath
*)indexPath
{
CQCategoryItemModel
*model
=
self.model
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- Unit 8 Summer holiday is coming!Lesson 47 公开课教学课件【七年级英语下册(冀教版)】
- (新人教版)高中英语必修第三册全册分单元教材解读(共5个单元)
- 市政改善城市供电设施
- 市政风景名胜区保护修缮
- 2024年特种作业考试-焊接与热切割作业笔试参考题库含答案
- 2024年火电电力职业技能鉴定考试-电力生产“1000个为什么”笔试参考题库含答案
- 2024年中国奥马珠单抗注射液行业研究报告
- 2024年浙江住院医师-浙江住院医师麻醉科笔试参考题库含答案
- 2024年法律知识法治建设知识竞赛-价格法知识竞赛笔试参考题库含答案
- 2024-2030全球与中国石油管道涂料市场现状及未来发展趋势
- 2024年浙江绍兴市轨道交通集团有限公司招聘笔试参考题库含答案解析
- 南方科技大学自述信800字范文六篇
- 做一个有责任心的人主题班会教育课件ppt模板
- 【赞赏资料】东式染发公式配方比例(最新整理)
- (完整版)算法设计与分析复习题目及答案
- 易经六十四卦全图解
- 手术部位感染目标性监测
- 初中女生主题班会ppt课件
- 厚皮性骨膜病患者HPGD及SLCO2A1基因变异
- 钢材规格型号理论重量表
- 小升初个人简历模板
评论
0/150
提交评论