swift 有UNSafePoint的概念,但是不能够与C/C++直接交互,但是对于C/C++模块操作就需要进行一些改进那就是今天的主角moulemap啦。...要想使用你自己的C/C++按照 import的方式在swift使用那么你需要经历以下几个简单配置 1 当然是将对应的C/C++源码文件导入到swift项目中 2 配置modulemap啦 3 import...使用啦 至于导入c/C++代码自不必说例如 ?...到此为止您就可以使用 import Sk来使用您的C/C++ var skName = "SkeyBoy".data(using: .utf8)!...惊喜吧,通过这个我们可以在swift中直接导入C/C++的库啦
为了良好的交互体验,相信大家在对待scrollView无数据时的提示页都会使用一些第三方来定制,最典型的就是使用DZNEmptyDataSet。...而Swift除了可以面向对象编程,它还可以面向协议编程。那可不可以也用协议来解决情况呢?...但是比较麻烦,因为UserDefaults是单例,整个进程共用这一份资源,如果你当前controller遵守了我们的协议LXFEmptyDataSetable并做出了定制,那么当下一个controller在遵守协议后使用了默认定制时...,非常地恰巧,我们定义的方法lxf_EmptyDataSet需要外界将UIScrollView传递进来,在DZNEmptyDataSet的数据源方法和代理方法也有scrollView。...可以使用Cocoapods的方式来安装使用 pod 'LXFProtocolTool' 我也将 iOS - Swift 面向协议编程(二) 中提及的通过协议便捷加载xib的功能也集成了进来。
通过一个 UIScrollView 的扩展,可以轻松为 UIScrollView 的所有子类添加下拉刷新功能。...SnapKit - 就是“snap”, --swift 喜欢自动布局吗?当然喜欢!至少在storyboard中创建时会喜欢。...在代码中纯手工创建约束灰常痛苦,但幸运的是我们有了SnapKit,在board中用上它,你可以简单直观地编写约束了。...第二个Demo模拟了一个经典的FlowLayout,任意一个元素隐藏时,底下的元素需要自动“顶”上来,配合这个扩展,你可以在IB里连一连,选一选,不用一行代码就能搞定。...FXLabel - FXLabel是一个功能强大使用简单的类库,通过提供一个子类改进了标准的UILabel组件,为字体增加了阴影、内阴影和渐变色等,可以被用在任何标准的UILabel中。
在UIView类中提供了一个可供重载的方法: - (CGSize)intrinsicContentSize NS_AVAILABLE_IOS(6_0); 如果某类视图有自己的固有内容尺寸则需要重载这个方法的实现...系统内部的实现中如果布局引擎在布局时发现某个视图没有设置高度或者宽度约束那么就会去调用这个视图的intrinsicContentSize方法,如果这个方法返回了正常的尺寸则视图就按这个尺寸来进行渲染和展示...为此当UIScrollView要和AutoLayout进行结合使用并实现滚动能力的话就不能直接将所有子视图都添加到UIScrollView中去, 而是需要中间建立一个容器视图,首先将容器视图添加到UIScrollView...在设置约束依赖时将容器视图的上下左右分别依赖UIScrollView视图的上下左右边界,如果需要上下滚动则将容器视图中的最底部子视图的底部边界依赖容器视图的底部边界。...因此如果想使用布局视图的尺寸自适应功能,那么在将布局视图的尺寸设置为wrap后,就可以像使用UILabel那样不用去设置布局视图的宽度约束和高度约束了。比如有两个兄弟视图A,B。
采用子控制器的原因是因为防止所有的逻辑代码都混在根控制器中,所以没有使用nicklockwood 的iCarousel 或SwipeView ,而是采用了之前一直在用的SCPageViewController...记录下自动布局中遇到的几个坑。...所以一般都会和setNeedsLayout一起使用。如果希望立刻生成新的frame需要调用此方法,利用这点一般布局动画可以在更新布局后直接使用这个方法让动画生效。...self.isBigger; }]; button;}); 关于UIScrollView的自动布局 上面提到的页面遇到了多重的UIScrollView,使用自动布局的时候也是够蛋疼的。...具体使用技巧参考Masonry自动布局详解九:复杂ScrollView布局、在UIScrollView中使用Autolayout布局以及iOS_autoLayout_Masonry。
采用子控制器的原因是因为防止所有的逻辑代码都混在根控制器中,所以没有使用nicklockwood的iCarousel或SwipeView,而是采用了之前一直在用的SCPageViewController...记录下自动布局中遇到的几个坑。...所以一般都会和setNeedsLayout一起使用。如果希望立刻生成新的frame需要调用此方法,利用这点一般布局动画可以在更新布局后直接使用这个方法让动画生效。...self.isBigger;}];button;}); 关于UIScrollView的自动布局 上面提到的页面遇到了多重的UIScrollView,使用自动布局的时候也是够蛋疼的。...具体使用技巧参考Masonry自动布局详解九:复杂ScrollView布局、在UIScrollView中使用Autolayout布局以及iOS_autoLayout_Masonry。
这时候两个scrollView都会滑动,我们可以在滑动回调里,根据当前的情况进行处理,实现想要的滑动规则了。----滑动规则制定Tips:规则一定要提前确认好。...= { let view = UIView(frame: .zero) view.backgroundColor = .red return view}()private lazy...undefinedMOMultiTabContainerViewController内部是一个scrollView,添加多个subScrollView,结构如下:(详情可见MOMultiTabContainerViewController.swift...的contentOffset的精确度问题,所以在计算或判等时需要注意了。...使用 `NSDecimalNumber`----github demo----参考:Strange problem comparing floats in objective-C
默认是NO.如果设置为YES的话则边缘视图的边距不起作用了,而且子视图的weight也不起作用了。而且不是调整自己的大小了 //也就是当垂直方向则所有子视图按顺序排列在中间。...但实际中我们总是带着解决问题的想法去使用某个框架和库的,我这里想说的是当你在使用AutoLayout时因为复杂的约束设置以及更新方法而焦头烂额时,当你使用AutoLayout而对多屏幕多设备适配而进行多条件编写时...,当你使用AutoLayout对你的布局性能造成影响时,也许你会想着是否有一个新的布局库能帮我解决这个问题,没有错,也许MyLayout就能帮你解决你实际中的众多复杂布局和性能的问题,而且MyLayout...所以你也可以先以尝试的态度来接触和使用这种新的布局解决方案,而且为了让大家能更好的使用这个布局库,在我的开源库中为每种布局都建立了异常丰富的演示和使用的DEMO,同时我还建立了一个能供大家交流和解决问题的...swift版本的TangramKit中得到了有效的解决。
https://blog.csdn.net/u010105969/article/details/80091745 背景: 在swift工程中要使用一个刷新控件,网上的建议还是直接使用MJRefresh...,于是就在swift工程中导入了MJRefresh,并进行了使用。...具体使用: (使用cocoaPods将MJRefresh继承到项目中,MJRefresh虽然是OC版本的,但确能在swift项目中直接使用并不用进行桥接) 为UITableView添加刷新、加载的视图
在 Swift 图表中使用Foundation 库中的测量类型 在这篇文章中,我们将建立一个条形图,比较基督城地区自然散步的持续时间。...虽然我们可以记住我们在创建测量时使用了小时hours,但这并不理想。例如,我们可以决定以后改变数据模型,以分钟为单位存储持续时间,或者数据可能来自其他地方,所以手动重构单位并不是一个完美的解决方案。...of External Types),如果Swift Charts在未来添加了这种一致性,它可能会被破坏。...只是在与原始值转换时要使用相同的单位,这一点很重要。 我们现在可以更新我们的图表,以使用我们的自定义Plottable类型。...我们收到的值是使用我们在Plottable一致性中定义的初始化器创建的,所以在我们的案例中,测量值是以分钟为单位提供的。但我相信对于这个特定的图表,使用小时会更好。
*)scrollView{ NSLog(@"即将开始滑动内容时"); } - (void)scrollViewDidScroll:(UIScrollView *)scrollView{...*)scrollView withView:(nullable UIView *)view{ NSLog(@"开始缩放"); } - (void)scrollViewDidZoom:(UIScrollView...:(UIScrollView *)scrollView{ return [UIView new]; } ScrollerView缩放的代理回调 //滚动视图在和方法的实现结束时调用此方法,但仅在请求动画时调用...{ NSLog(@"点击状态栏是否可以回到顶部"); return YES; } //scrollViewShouldScrollToTop设置为YES,滚动视图在完成滚动到内容顶部时发送此消息...- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView{ NSLog(@"滚动视图在完成滚动到内容顶部时发送此消息"); } UIScrollerView
虽然我们可以记住我们在创建测量时使用了小时 hours,但这并不理想。...Conformances of External Types[3]),如果 Swift Charts 在未来添加了这种一致性,它可能会被破坏。...只是在与原始值转换时要使用相同的单位,这一点很重要。 我们现在可以更新我们的图表,以使用我们的自定义 Plottable 类型。...我们收到的值是使用我们在 Plottable 一致性中定义的初始化器创建的,所以在我们的案例中,测量值是以分钟为单位提供的。但我相信对于这个特定的图表,使用小时会更好。...最后的结果是在X轴上显示以小时为单位的格式化持续时间。 你可以从我们的 GitHub repo 中获得这篇文章中使用的项目的完整 示例代码[4]。
UIScrollViewDelegate> @property(nonatomic, assign) MOTitleLineViewType type; @property(nonatomic, strong) UIScrollView...NSStringDrawingUsesLineFragmentOrigin attributes:dic context:nil]; //返回line的宽度 return frame.size.width; } - (UIScrollView..._scrollView) { _scrollView = [[UIScrollView alloc] init]; _scrollView.showsHorizontalScrollIndicator..._line; } @end 使用例子: // // ViewController.m // MOTitleAndLineView // // Created by 莫晓卉 on 2018/9/...addSubview:_titleView]; _titleView.backgroundColor = [UIColor redColor]; _titleView.titles = @[@"swift
iOS开发UIScrollView使用详解 一、ScrollView常用方法和属性 @property(nonatomic)CGPoint contentOffset; 设置滚动的偏移量 @property...你的滚动视图只能同一时间在一个方向上滚动,但是当你从对角线拖动时,是时刻在水平和竖直方向同时滚动的。...)scrollView; 视图动画结束时触发的方法,使用set方法设置偏移量后回触发 - (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView...; 返回进行缩放的视图 - (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view; 视图内容将要开始缩放时触发的方法...- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(CGFloat)
self.scrollView addSubview:secondLabel]; //委托方法 #pragma mark - UIScrollViewDelegate //返回缩放时所使用的...UIView对象 - (UIView*)viewForZoomingInScrollView:(UIScrollView *)scrollView{ return scrollView;...} //开始缩放时调用 - (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView...} //抬起手指停止拖动时调用,布尔值确定滚动到最后位置时是否需要减速 - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView...*)scrollView{ } 这里在view中添加了一个设置了大小的ScrollView,在ScrollView中添加了两个Label,两个Label的开始y值不同所以第一个一开始就能看见
环境: Xcode:Xcode 8.2 Swift:swift3+ git 地址:https://github.com/TieShanWang/KKPopover pod 集成:pod 'KKPopover...' 【注意】pod 版本,swift 3 支持,以 3....可以看到当 sourceView(加号按钮) 在不同地方的时候,popover 自动更改方向、调整箭头方向、位置以适应不同的 sourceView 类说明 open class KKPopover: UIView..., sourceView: UIView) /// 根据 sourceView 展示在指定视图中 /// - Parameters: /// - view: 添加到的视图,不传则添加到 window...查找 perferArrowDirection 内部合适的方向使用 open class KKPopoverArrowView: UIView 箭头视图的配置项 /// 边角弧度 open
UIView view.addSubview(testView) } 使用与 UIViewController 子类源文件关联的 xib Demo HomeViewController.swift...第4章 在 Interface Builder 中使用 Auto Layout ---- 在 IB 中使用 Auto Layout 的优缺点 设置约束十分简单 如果约束不恰当,IB 提供很好的实时反馈...Swift 里面可以对应 Int、Double、Float。...用 External Object 重构 VC 只能在于 xib IB 中的关键字总结 Swift @IBAction @IBOutlet @IBDesignable @IBInspectable...IB 中,但是源文件必须是 UIView 或者 NSView 的子类。
void)setZoomScale:(CGFloat)scale animated:(BOOL)animated NS_AVAILABLE_IOS(3_0); //34.缩小到特定区域的内容,所以它是在接收器中可见...滚动动画停止时执行代码改变时触发,也就是setContentOffset改变的时候 - (void)scrollViewDidEndScrollingAnimation:(UIScrollView *...)scrollView; //50.返回一个放大或者缩小的视图 - (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;...:(UIScrollView *)scrollView { return _beautifulView; } 代理使用的一般规律 作用:用来监听控件的某些行为 代理:是控制器对象 代理:是id类型...中的模式:NSRunLoopCommonModes // 主线程不管在处理什么操作,都会抽时间处理NSTimer [[NSRunLoop mainRunLoop] addTimer:self.timer
init:不会调用layoutSubviews addSubview::被添加的view1、调用这个方法的view2、view2的所有子view都会调用layoutSubviews setFrame:只有在view...设置frame且尺寸参数有不同的情况下调用 滑动UIScrollView时,scrollView和其父view会调用 旋转屏幕会在viewController的根view调用 重新改变view的大小,其父...NSParagraphStyleAttributeName:textStyle}]; 设置粗体文字 首先可以上这个网站:http://iosfonts.com/查看自己要用的字体是否支持粗体,然后使用下面方法...; ---- 其他 Cocoapods pod install 太慢 reference pod install --verbose --no-repo-update 标注代码段 reference 在OC...里经常用 #pragma mark - xxxx 来分隔代码 Swift里用的是 // MARK: - xxx
滚动视图分页 UIScrollView的pagingEnabled属性用于控制是否按分页进行滚动。在一些应用中会应用到这一个特性,最典型的就是手机桌面的应用图标列表。...这些界面中往往每一页功能都比较独立,系统也提供了UIPageViewController来实现这种分页滚动的功能。 实现分页滚动的UI实现一般是最外层一个UIScrollView。...其原因是无论是分页滚动还是不分页滚动,在滚动时都是通过调整滚动视图的contentOffset来实现的。...而当滚动视图进行横竖屏切换时不会调整对应的contentOffset值,这样就导致了在屏幕方向切换时的滚动位置出现异常。...解决的办法就是在屏幕滚动时的相应回调处理方法中修正这个contentOffset的值来解决这个问题。