This is an old revision of the document!
Bit of a pace change here, I don't particularly care about consumer electronics but mobile computers aka phones are an exception since for better or worse they're inextricably tied up with much of my life.
After being a longtime user of Pixel devices (which pairly nicely with Google Fi cell service), the screen on my Pixel 4a broke recently (originally written: 01 July 2022). At the same time I went to Yosemite with some friends and noticed that the pictures they took with their iPhones looked a lot better than the pictures I've taken with any Android phones. I was always skeptical of iPhone's ostensibly restrictive user experience (relative to Android), but being rather bored with technology and not finding any really good Android phones on the market (where are the microsd slots?) decided to pick up an iPhone. Apple has a decent 14 day return policy, so I figured I'd try it out and if the device annoyed me I'd just return it and get whatever the current number pixel is. In short, I've been pleasantly surprised by iPhone and am keeping it. I bought the iPhone 13 Mini with 512gb of storage.
My main hangups coming into iPhone numbered three:
I'd vaguely heard that it is difficult to access iPhone's filesystem. This is one of the things that kept me from seriously looking into iPhone in the past. I know how computers work, I know consumer computers have a filesystem that has files on it, one of the main things I do with computers is work with files on the filesystem. I'm generally not interested in learning abstractions over the filesystem and if I'm prevented from doing things I normally do with the filesystem, like moving files around, that's a nonstarter for me. Turns out this concern was misplaced. The iOS concept of the filesystem is more complicated than the one on Android, but from a functional perspective I can still accomplish the same tasks. I can mount various parts of the iPhone filesystem on my Arch laptop via a FUSE module and get to the files I need to get to. On iOS, apps apparently have their own private filesystems, which is kind of a neat concept and makes perfect sense from an application sandboxing perspective. These can also be mounted on Linux via FUSE. I can copy files to and from application filesystems and I can copy to and from the directories iOS exposes for use as mass storage.
By far the biggest filesystem-related task I do with phones is to sync my music collection to the device. With the way I manage my music collection, I prefer to do this with rsync
, it's simple and clean and does what I need it to. On Android I would mount the phone filesystem via jmtpfs
and rsync
my music to a directory in the filesystem; on iOS I mount the application filesystem for my music player application (VLC) using ifuse
and do the same thing.
Android:
jmtpfs ~/mnt
Mounts the whole phone filesystem on ~/mnt
. Now I can copy my music to ~/mnt/Music
with rsync
.
iOS:
ifuse -o allow_other --documents org.videolan.vlc-ios ~/mnt
Mounts VLC's application filesystem on ~/mnt
. Now I can copy my music to ~/mnt/Music
with rsync
.
A little more regarding application filesystems. The first thing I noticed when using iPhone was that when I wanted to save a picture from the browser to the phone, I had to choose where I wanted it to end up. The two options iOS presents in are Files
and Photos
. This is strange, conceptually I am saving a file, so the distinction between these two things isn't clear. After I figured out the application filesystem thing this makes a lot more sense; choosing Photos
saves the picture to the Photos
application's filesystem, saving it to Files
saves it to the Files
application's filesystem. This seemed like a bizarre abstraction over the very simple concept of a filesystem until I realized that this ties into how iOS does application sandboxing.
iOS doesn't work like Android where an app either has access to the filesystem or it doesn't; on iOS you grant individual apps access to specific paths in the filesystem. There also seems to be a concept of apps asking other apps for permission to access parts of their app filesystems, although this may be the same thing (not sure as I haven't done any iOS development). This is awesome from a security perspective and is something I didn't know I needed until I used it. For example, if I want to send a picture to a channel in Discord on Android, I open the Discord file picker and all photos on my phone are visible from within the application; i.e. Discord has unfettered access to the filesystem. A malicious or buggy Discord could choose to send any picture it wanted, there's no access controls preventing it from doing that. Contrast with iOS; I open the Discord file picker, and by default I see no photos. Instead there's iOS UX there that allows me to grant Discord access to *specific* photos. Once I grant access, then Discord allows me to pick from the photos I've granted it access to. This is a huge deal. This is absolutely how it should be. Filesystem access should be heavily locked down and mediated by the operating system on mobile devices. In retrospect Android is extremely primitive in this regard. It's difficult to explain in text without seeing how it works in practice, but once I used it, I had a moment of “ah, I get it now” and was sold on it.
One other note on this; I'd heard people say “oh but iOS has the Files app now” in response to concerns of restricted filesystem access. It does indeed have a Files app, and this app is interesting. It's a surprisingly comprehensive file management app. It allows you to access select application filesystems - it seems to be limited to ones that apps choose to expose - and some other parts of the filesystem, although the parts that are exposed are clearly curated by iOS. There's obviously no view of the root filesystem. Functionally it feels like porcelain over a bunch of bind mounts or a virtual filesystem being used to present a clean, access controlled interface to stuff iOS has decided you should see. To be honest, I rather like it. The Files app also has the capability to mount remote shares, another pleasant surprise; I was able to add my home Samba server easily and played around with copying music files from it into the VLC app filesystem using just the Files app, which actually worked.
I watch a lot of webms. For some reason - I really don't care about the justification - Apple has decided webm is not an ordained format and refuses to implement a system codec for it.
Yeah, this one kind of sucks. Webms just don't load or present as file downloads instead of embedded playback in places where they'd normally embed as videos on Android. Installing VLC and opening the file in VLC works well enough to live with it, but still, this is stupid and for a company that really cares about user experience, they should just implement webms. I don't care if there's a royalty situation or a nonfree codec situation or whatever the issue is. Apple is the world's most valuable company, they can afford to pay royalties so that I can play webms on my $1000+ mobile computer that I bought from them. No excuses.
Vague concerns about being locked into the Apple ecosystem, forced to use only apps approved by Apple, integration with iCloud, etc…
This one is also valid. Lack of first class support for sideloading is a legitimate gripe here. Functionally this means I can't install Newpipe to watch YouTube without ads. I don't know who the hell watches YouTube ads, but I'm not about to spend hours of my life watching that trash. My time is more valuable than that.
Using YouTube frontends like Invidious in the browser works, but it's not really a great experience. Notably, it is still better than the YouTube app with ads, but it's worse than Newpipe where I had my own curated playlists and subscriptions managed entirely through the app (not tied to my Google account).
I'm told that the data shows that people who buy iPhone are much more willing to pay money to solve problems than other people are. I imagine most people solve this problem by paying for YouTube Pro or YouTube Red or whatever the premium YouTube version is that doesn't show you ads. I may end up there but not today. As a matter of principle I refuse. I also think it's complete bullshit that I can't sideload apps on my $1000+ computer. I paid for it, it's mine, let me run my code on it. But this horse has been beat to death so many times, and Apple definitely knows that people will still use iPhone, and they're right about that. I'm still using iPhone.
Things I like.
Everyone knows this one. iPhone is famous for the UI being buttery smooth at all times. This is real. As much as I wish I didn't, I use my phone probably a couple hours a day. Having nearly every interaction with the device be pretty much glitch/hang-free is such a tangible upgrade over Android.
Minor things like picture-in-picture, context menus, the screenshot editor etc. all work together for an experience that is far more consistent and far more pleasant than Android. For a device that runs large swaths of my life, it's a significant upgrade.
When I first wrote this section after getting the phone, I wrote:
It is just a fact that the iPhone takes amazing pictures. Through whatever combination of camera and software, pictures on the iPhone turn out consistently better than any picture I ever took with any Android flagship - and I have owned a lot, from the Nexus 5 through the Pixel 4a. Having a wide angle camera is also awesome, I use that thing all the time.
After two years of using the phone, I now hate the iPhone “look”. I think it's because in that time I purchased a mirrorless camera and started doing enthusiast photography, prompting me to be much more conscious of colors, sharpening, contrast, noise and noise reduction, and all the other things you notice when you start grading your own photography. Now when I see photos produced by the stock iOS pipeline, I'm left wondering why they frequently look *so awful*. In some scenes the photos look good, but in many cases iOS will consistently
It is possible to shoot in raw on my iPhone, but doing so doesn't match the type of photography I use my phone for. My phone camera is for quick snaps to capture a moment or preserve a memory when I don't have my real camera, or don't want to use it. Oftentimes I want to share the photos I take soon after shooting. Shooting in raw means I need to demosaic, grade, and export that photo. When I take 30 pictures in a day that is too much effort for each photo. I need the computational pipeline to produce something that looks at least OK. The extreme amount of oversharping and local contrast that the iOS pipeline produces just looks terrible.
Here's two versions of the same photo I took of a rock wall in Colorado. I shot this using Halide, which produces both a raw and a HEIC that goes through the usual iOS image pipeline. I applied a neutral grade to the raw, only correcting for exposure, a little bit of chroma and a touch of contrast. Can you tell which one is the iOS photo and which is the raw? Hint: the iOS one looks like nothing that exists on planet Earth.
I guess the pipeline is optimized for what people want to see, but it looks awful to me.
I've also noticed that iOS takes pictures of sunsets that in real life have delicate and beautiful shades of pink and maps all of the pink tones into…orange? It's so egregious I genuinely believe that the pipeline detects sunset photos and applies a specific grade that crushes pinks and produces a very generic looking orange and blue photo.
I said most of what I wanted to say in the filesystem section, but yeah. The iOS security model is clearly much more mature than that of Android. At security conferences there's always a talk or two about breaking iOS application sandboxing. No one gives talks like that for Android. I think that's because breaking iOS is actually impressive. Nobody is surprised that Android is broken.
Wireless charging is dope, but MagSafe is the nicest system I've used out of all of them. I really like the MagSafe charger for iPhone.
Apple's build quality is legendary and it's on full display in the iPhone. Hardware silent mode switch is great.
This one actually surprised me. iOS has deeply integrated support for standard protocols and technologies into the OS, including: