Swift's pitfall: How to implement multiple selection of enum

Swift's pitfall: How to implement multiple selection of enum

question

In OC, enum can have multiple selections. For example:

  1. NSString* string = @ "a paragraph of text" ;
  2. CGRect boundingRect = [string boundingRectWithSize:CGSizeMake(label.frame.width, CGFloat.max) options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading attributes:attributes context:nil];

By combining two enum values ​​with |, you can achieve the effect of multiple selection.

Now the question is: how to achieve the same effect in Swift?

Option Type in Swift

Swift's enum does not support multiple selections, so the option type that supports multiple selections should be implemented using struct: RawOptionSet. To implement the options type yourself, you can refer to this answer.

The official SDK is ported using this method.

Correct way to write

The correct way to write the code in the above example using Swift is as follows:

  1. let options : NSStringDrawingOptions = .UsesLineFragmentOrigin | .UsesFontLeading
  2. let boundingRect = string.bridgeToObjectiveC().boundingRectWithSize(CGSizeMake(label.frame.width, CGFloat.max), options: options, attributes: attributes, context: nil)

In OS X 10.10, this works.

iOS SDK bugs

But in the current version of iOS 8 SDK, this way of writing cannot be compiled. This is because in the iOS 8 SDK, NSStringDrawingOptions has been transplanted to enum: Int instead of struct: RawOptionSet.

How to solve this problem? We can only use OC to workaround.

Solution

Because the options used are the same, I simply wrote this class:

OCUtils.h

  1. @interface OCUtils : NSObject
  2. + (NSStringDrawingOptions)stringDrawingOptions;
  3. @end

OCUtils.m

  1. #import "OCUtils.h"  
  2. @implementation OCUtils
  3. + (NSStringDrawingOptions)stringDrawingOptions{
  4. return NSStringDrawingTruncatesLastVisibleLine |
  5. NSStringDrawingUsesLineFragmentOrigin |
  6. NSStringDrawingUsesFontLeading;
  7. }
  8. @end

Add the following to Bridging-Header.h:

  1. #import "OCUtils.h"  

Swift files used

  1. let boundingRect = string.bridgeToObjectiveC().boundingRectWithSize(CGSizeMake(label.frame.width, CGFloat.max), options: OCUtils.stringDrawingOptions(), attributes: attributes, context: nil)

If there are further requirements, it can be changed to be more general. The overall principle can only be like this.

Reference for this article : How to pass multiple enum values ​​as a function parameter

Original article: Swift's pitfall: How to implement multiple selection of enum

<<:  CES2015: ZTE releases 6-inch ultra-large screen mobile phone Grand X Max+

>>:  Break the 24-hour unspoken rule and create truly innovative apps

Recommend

Xiaomi Clearance Festival data analysis: more youthful than rich

The Mi Fan Festival is over, and Lei Jun quickly ...

Facebook releases React Native for Android

[[149937]] Facebook today released React Native f...

A comet from the "Jupiter family" has been discovered!

Author | Zhao Jingyuan Review | Zhang Mi, Sun Guo...

Traffic generation and promotion: How to find target users before promotion?

Finding target users and conducting targeted oper...

Look! There are a group of prehistoric monsters "sealed" in the rocks!

The fantastic creatures that are difficult to dis...

Can gray hair turn black again? The doctor's answer is unexpected

I believe that not many people like their gray ha...

Jack Ma is also optimistic! Will VR achieve a qualitative change in 2016?

[[161438]] At the end of October 2015, news came ...

AI decides your university? Calculate your 7 personal qualities in minutes

Currently, many universities adhere to the concep...

Can I optimize my phone without rooting? I tried these 10 apps

We cannot easily obtain root permissions on every...

Event Operation | What tricks are hidden in Pinduoduo’s red envelopes?

This article will tell you about some of the rout...

Why IT tycoons were easily believed in the "drug abuse rumors"

It is indeed not rational for the public to belie...