I've got a SearchView
setup, and I have a loosely decoupled architecture using Retrofit
and Otto
.
I am wondering what the Best Practices are for Search in Android, or any mobile application in general (meaning something like this could be applied to iOS as well).
Specifically I am using an AutoCompleteTextView
to handle suggestions in my SearchView
and the data is coming straight from the API
. I don't believe this is a best practice since everytime a user changes text in the SearchView
there is an API call initiated.
I'm thinking about storing a Cache in SQLite and then pinging results from there, but what if the user wants the most immediate data? How would you handle that? What pattern would that employ?
Would appreciate any thoughts on the best architecture or approach to Search in Android.
So to answer this question in a sufficient way, as I was not satisfied with the other answers here there are a few more steps to consider in this problem.
First we would need to ask a few questions in regards to how we would tackle this issue:
And many more questions.
I would probably first build a custom adapter to handle the querying in the search, then implement aggressive caching on the user's queries. This is important in the sense that a user's queries are very important. It would probably make sense to only used cached results for Autocomplete
it is very expensive to implement autocomplete and have it ping the server at every text change.
Caching can be accomplished by using the SQLite
helpers in Android. This can be expensive, but we are dealing with simple query objects, (as this should be the case from the API the objects should be memory or byte size expensive).