ios 5 and ios6 compatibility features -xcode - ios

I want to create a map based app but apple will no longer user google maps in ios 6.I dont want to upgrade to the developer beta yet as I am waiting for the final release. But I also want to get started as soon as possible. If I start my project now will it change or the code will differ when the ios 6 is available? In other words if I make a successful built in ios 5 will it be unsuccessful when i upgrade to ios6? Will I have to rewrite the entire thing or everything will be compatible resulting to an also successful built? thank you in advance..

Your code will work fine.
Almost nothing changes with iOS 6 and MKMapKit in terms of code.
The only thing which works different in iOS 6 is the way you call the native Map App from inside you app. (if you are using this functionality)

You don't need to wait to use beta versions of XCode, you place them in different locations on your hard drive and leave the current XCode in place.
Then you can test in the iOS 6 simulator just to make sure it works as well as on iOS 5.

Related

Use Old SKTextureAtlas or SpriteAtlas

I made a game that makes use of many textureAtlases. I am currently using SpriteAtlases in the assets.xcassets folder which works great until testing devices below iOS 10.
Running on any devices at iOS 9 displays this issue below and it won't load the textures.
-[CUIThemeRendition newImageFromCSIDataSlice:ofBitmap: usingColorspace:] Unsupported pixel format in CSI got 5
Unable to create unsliced image from csi bitmap data.
I couldn't fix this issue (I read that it might be a bug) so my only two options I can think of is to either use the old .atlases in the project bundle or only have my game support iOS 10.0 and newer when using the spriteAtlases. Which is the better option or is there another alternative?
Using the .atlas method is old and inefficient. The XCassets .spriteatlas is, by far, a better usage of memory and will make your project run better.
My recommendation would be to not support iOS 9 and lower. Users still on iOS 9 are such a small minority, you would be screwing your iOS 10 users by using this inefficient method. At this point, most people have upgraded to iOS 10 or newer or bought a new device.
It gets to a point where us developers physically cannot continue to support older iOS versions. In fact, if I remember correctly, Twitter just recently dropped support for iOS 9. I think it would be a good idea to follow suit.

What happens when my app no longer supports older iOS

If a user was using my app on iOS 8 and my latest release supports iOS 9 only. The user update OS to iOS9.
Does he get al alert to update app when he opens my app?
Can the user still use my app without updating it?
What happens for the deprecated code? Will the app crash while trying to access such APIs?
No alerts. If user will not update iOS your application will not be updated. Your project should be updated that now it requires iOS 9, see deployment target in your project settings. If you don't change this setting than it will get updated and you can have a crash if new API is used on old iOS.
If you didn't change server side in such way that it breaks compatibility than old version should still work.
This should be investigated by you. It depends on many factors. If you have setup project "deployment target" properly than update will not be performed on older iOS versions. This may be tricky if your application should support older versions of iOS. Not updated application will continue to work on new iOS even if deprecated API is used. Apple will simply reject updates witch are using deprecated API but still maintains that API. Once I had a problem since UIAlertView was deprecated and old application had new bug where UIAlertView was not respecting application orientation. I had to do a tricky code which detected if UIAlertController (I prefer this approach instead detecting iOS version) is available than use it and if not than fallback to UIAlertView was used.
During application update the biggest problem you can create is setting compatibility or database comp compatibility. So you should be careful with that.

Will an app built with an older version of Swift be able to live indefinitely on app store?

Alright, have a question here -
A while ago I built an app in Swift using pods that, for one reason or another, disappeared one day. Meaning the project was there, but it reverted to a MUCH older version and was inrepairable. It's a great app and I released on the app store, so others are using it and that's great but I am unable to update it. The binary is gone.
My question is - with the updating of the app store and Swift (i.e. Swift 3 now instead of 2) will my app be able to run still on the app store in years to come?
Right now with Swift 3/ios 10 it still runs well. It's good.
But can an app written in an older version of Swift live indefinitely on the app store? Or will it die one day? Hoping its not the former..
Whether an app built with Swift will still be available in the App Store in a few years doesn't depend on the fact it's written in Swift. For a released app, Swift is compiled to binary code and Swift libraries are bundled with app. There are no Swift specific dependencies left.
However, Apple might have other reason to pull your app:
Your app hasn't been updated in a long while.
Your app hasn't been updated for the latest devices (e.g. new screen formats).
Your app was built against an old iOS version that lasted iOS versions are no longer compatible with. (Each iOS version contains compatiblity code to run old apps, e.g. iOS can still emulate the pre-iOS 7 UI.)
Your app crashes on newer devices or iOS versions.
Your app violates App Store rules but it wasn't discovered on the initial submission.
Having said that, if your app doesn't crash or violate rules, it'll likely take a few years until there is a realistic chance for it to be pulled.
even app which are written in objective - c also works fine which is more older then swift, then why your swift app will not work? it will definitely work without any failure!! doesn't matter whether it is swift 2 or swift 3!!!

Updating app for iOS 8

I have an application whose minimum version has been set to iOS 7.0. This application also uses NSUserDefaults dictionary. This application is using UIAlertView and UIActionSheet extensively (not sure how much Apple non-disclosure covers). Now, with iOS 8.0, these two views have been deprecated and have been replaced by controller UIAlertController. Now, there are two ways that I can see which can help me in updating the app for iOS 8.
Raise the minimum version to iOS 8.0 for the update. This way, the users running iOS 7.0 won't be able to see the update. However, it leads to the following situation :-
However, there is one problematic case, and that comes from upgrades
performed from within iTunes or on a device with a higher version
number that is then synced to iTunes. When the user syncs the older
device with iTunes, iTunes will actually delete the application from
the device because it cannot run the new version currently within
iTunes. I had a couple of users with original iPod touches report this
when I upgraded one of my applications to only support 4.0.
The above comment is present under the accepted answer at the following url :-
Raising minimum iOS Deployment Target Version for App Update
Since, the application is using NSUserDefaults dictionary, the relevant entries in the dictionary would get erased when the application is deleted.
The other option is for me to detect in the code which version is being used and code accordingly using if-else statements. This would enable me to keep the iOS 7.0 as the minimum version and might also help me in deploying the update for iOS 8.0. However, this seems like a lot of work which can potentially lead to bugs.
So, I was wondering which option is better between the above 2 ways ? (This application would only be using Objective-C for now due to some constraints).
The best thing to do from the user's perspective is probably to code using UIAlertView and UIActionSheet even though they're deprecated. Keep your iOS 7 target the same as it's been. Xcode shouldn't give you warnings since you're using the older version as your base target. You won't need to change anything about your code and it should still work well enough.
Once you're ready to switch (perhaps when iOS 9 comes out), I would switch your base target to iOS 8 and update your code to use UIAlertController everywhere. To me, it doesn't make sense to spend time trying to support two different versions if it's just an API deprecation that still allows your code to work how you've written it for years. Saves resources and energy to just update it later.
But it's really up to you and how much you want to support iOS 7. I think it doesn't make sense to drop support until the next version comes out. I always try to support the current and last versions so there are no annoyed customers, but it depends on your own needs.
If you have analytics integrated, check out percentage of iOS 8 adoption once it's been released for the public. If not, it's a great opportunity to add it to find out how up to date your customers are!

If I use built-in/standard iOS controls in my iPad app will they automatically update with an iOS system update?

I'm in the design stage of an iPad app. If I use standard UI elements in my design (e.g. a standard iOS button design) and then get the dev's to implement the standard UI elements without any customization, will they update automatically when iOS 7 update comes out?
If not, what do I need to do when the update comes out? What changes need to be made in the app in order to use the new iOS7 styling?
Short answer : No
Descriptive answer: No they won't get updated automatically. You have to recompile your apps using XCode 5 to make sure that your app looks as per new UI controls of iOS 7. If you won't compile them then you will not be able to see even a single UI component and other than this you might get some crashes too.
It is always recommended to recompile your App and test it according to new iOS version to make sure that your apps looks according to newer UI and doesn't crashes on new OS because of changed/ deprecated APIs
I just updated my iPhone to iOS 7 and all my apps still use the old UI elements, (such as NavBar, TabBar, etc). Not sure yet how to update them to use the new ones, (I haven't updated to XCode 5 for example), but the quick answer is: no, your apps still look the same.

Resources