অনুসন্ধানের পরামর্শ অনুরোধ UI ভিউ জেনারেটর
সার্চ সাজেশনের UI ভিউ পেতে হলে, আপনাকে প্রথমে নিম্নলিখিত ধাপগুলো অনুসরণ করে এর জেনারেটরটি সংগ্রহ করতে হবে:
- আপনার টার্গেট
Activityক্লাসকেGetSearchSuggestionsViewGeneratorCallbackইন্টারফেসটি ইমপ্লিমেন্ট করতে দিন অথবা অ্যানোনিমাস ইনার ক্লাস ব্যবহার করুন। -
GetSearchSuggestionsViewGeneratorCallbackইন্টারফেসেরonSuccess(SearchSuggestionsViewGenerator)এবংonError(String)মেথডগুলো ওভাররাইড করুন। - সার্চ কনটেক্সটগুলোর একটি তালিকা দিয়ে
GetSearchSuggestionsViewOptionsক্লাস ইনস্ট্যান্সটি তৈরি করুন। (ঐচ্ছিক) এই অবজেক্টটি একটিSearchSuggestionsViewOptionsঅবজেক্টও গ্রহণ করে, যা সার্চ সাজেশন UI-এর চেহারা কাস্টমাইজ করার জন্য কিছু অপশন প্রদান করে। -
SearchInAppsServiceএরgetSearchSuggestionsView(GetSearchSuggestionsViewOptions, GetSearchSuggestionsViewGeneratorCallback)ফাংশনটি কল করুন। - UI জেনারেটরটি পাওয়ার পর, আপনি এটিকে একটি ViewModel-এ সংরক্ষণ করার কথা ভাবতে পারেন, যাতে অ্যাক্টিভিটি পুনরায় তৈরি করার প্রয়োজন হলে (যেমন অ্যাপটি চলার সময় কনফিগারেশন পরিবর্তিত হলে) আপনাকে আর জেনারেটরটির জন্য অনুরোধ করতে না হয়।
নমুনা কোড
জাভা
package ...;
...
import androidx.appcompat.app.AppCompatActivity;
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewGeneratorCallback;
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewOptions;
import com.google.android.libraries.searchinapps.SearchInAppsService;
import com.google.android.libraries.searchinapps.SearchSuggestionsViewGenerator;
import java.util.Arrays;
import java.util.List;
...
public class MainActivity extends AppCompatActivity implements GetSearchSuggestionsViewGeneratorCallback {
private SearchInAppsService service;
@Override
public void onSuccess(SearchSuggestionsViewGenerator generator) {
...
}
@Override
public void onError(String errorMessage) {
...
}
@Override
protected void onCreate(Bundle savedInstanceState) {
...
service = SearchInAppsService.create(this);
// Right now only the first element of this list will be used.
List<String> searchContext = Arrays.asList(new String[]{"This is a test query, for example."});
// Uses the default SearchSuggestionsViewOptions.
service.getSearchSuggestionsView(
new GetSearchSuggestionsViewOptions().setTextContext(searchContext),this);
...
}
@Override
public void onDestroy() {
service.shutDown();
super.onDestroy();
}
}
জেটপ্যাক কম্পোজ
package ...
...
import android.os.Bundle
import androidx.activity.compose.setContent
import androidx.appcompat.app.AppCompatActivity
import androidx.compose.runtime.Composable
import androidx.compose.runtime.DisposableEffect
import androidx.compose.runtime.mutableStateOf
import androidx.compose.ui.platform.LocalContext
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewGeneratorCallback
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewOptions
import com.google.android.libraries.searchinapps.SearchInAppsService
import com.google.android.libraries.searchinapps.SearchSuggestionsViewGenerator
...
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
SearchSuggestionsUI()
}
}
@Composable
fun SearchSuggestionsUI() {
...
var service by remember {
mutableStateOf<SearchInAppsService?>(
SearchInAppsService.create(LocalContext.current))
}
DisposableEffect(Unit) { onDispose { service?.shutDown() } }
val callback =
object : GetSearchSuggestionsViewGeneratorCallback {
override fun onSuccess(generator: SearchSuggestionsViewGenerator) {
...
}
override fun onError(errorMessage: String) {
...
}
}
var searchContexts: List<String> = listOf<String>("Query")
// Uses the default SearchSuggestionsViewOptions.
var options: GetSearchSuggestionsViewOptions =
GetSearchSuggestionsViewOptions()
.setTextContext(searchContexts)
service?.getSearchSuggestionsView(options, callback)
...
}
}
অবস্থান-ভিত্তিক অনুসন্ধানের পরামর্শের জন্য অনুরোধ করুন
getSearchSuggestionsView এন্ট্রি পয়েন্টটি অবস্থান-ভিত্তিক অনুসন্ধানের পরামর্শও সমর্থন করে। এই ধাপগুলো অনুসরণ করে LocationContext অবজেক্টের একটি তালিকা দিয়ে একটি GetSearchSuggestionsViewOptions অবজেক্ট তৈরি করুন। তারপর, পূর্ববর্তী বিভাগের ধাপগুলো অনুসরণ করে GetSearchSuggestionsViewOptions কে getSearchSuggestionsView ফাংশনে পাস করুন।
- (আবশ্যক)
GeographicalRestrictionsঅবজেক্টটি ব্যবহার করেLocationContextঅবজেক্টটি তৈরি করুন।GeographicalRestrictionsঅবজেক্টটি একটিCircularAreaঅবজেক্ট গ্রহণ করে, যেটিতে এলাকাটির কেন্দ্রের অক্ষাংশ ও দ্রাঘিমাংশ এবং এলাকাটির ব্যাসার্ধ থাকে। - (ঐচ্ছিক)
TimeSegmentঅবজেক্ট ব্যবহার করেTimeRestrictionsঅবজেক্টটি তৈরি করুন।TimeSegmentঅবজেক্টটি একটি স্ট্রিং গ্রহণ করে, যা ISO 8601 ফরম্যাটে সময় শ্রেণীকে উপস্থাপন করে। - (ঐচ্ছিক) অনুরোধ করা জিও টাইপগুলো দিয়ে
GeoTypeRestrictionsঅবজেক্টটি তৈরি করুন। প্রদত্ত টাইপগুলো সার্ভিস দ্বারা ফেরত আসা ফলাফলের র্যাঙ্কিং এবং ফিল্টারিং সমন্বয় করতে ব্যবহৃত হয়। সমর্থিত মানগুলো হলো: "restaurant", "cafe", "bar", "park", "zoo", "museum", "attraction", "atm", "bank", "hair_salon", "real_estate_agency", "bicycle_sharing_location", "car_rental_agency", "shopping_center", "grocery_store" এবং "hotel"।
নমুনা কোড
জাভা
package ...;
...
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewGeneratorCallback;
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewOptions;
import com.google.android.libraries.searchinapps.LocationContext;
import com.google.android.libraries.searchinapps.LocationContext.CircularArea;
import com.google.android.libraries.searchinapps.LocationContext.GeoTypeRestrictions;
import com.google.android.libraries.searchinapps.LocationContext.GeographicalRestrictions;
import com.google.android.libraries.searchinapps.LocationContext.LatLng;
import com.google.android.libraries.searchinapps.LocationContext.TimeRestrictions;
import com.google.android.libraries.searchinapps.LocationContext.TimeSegment;
import com.google.android.libraries.searchinapps.SearchInAppsService;
import com.google.android.libraries.searchinapps.SearchSuggestionsViewGenerator;
...
LocationContext locationContext = new LocationContext(
new GeographicalRestrictions(
new CircularArea(
new LatLng(
40.7414728,
-74.0059622),
1000)))
// Optional. If set, the returned suggestions are categories of which
// there are several businesses in the requested area that are open at
// the given time.
.setTimeRestrictions(
new TimeRestrictions(
new TimeSegment("2024-05-18T19:20:30.45+01:00")))
// Optional. If set, the returned suggestions are subset of the
// requested categories.
.setGeoTypeRestrictions(
new GeoTypeRestrictions("restaurant", "parks"));
// Uses the default SearchSuggestionsViewOptions.
service = SearchInAppsService.create(this);
// Uses the default SearchSuggestionsViewOptions.
service.getSearchSuggestionsView(
new GetSearchSuggestionsViewOptions().setLocationContext(Arrays.asList(locationContext)), this);
জেটপ্যাক কম্পোজ
package ...
...
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewGeneratorCallback
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewOptions
import com.google.android.libraries.searchinapps.LocationContext
import com.google.android.libraries.searchinapps.LocationContext.CircularArea
import com.google.android.libraries.searchinapps.LocationContext.GeoTypeRestrictions
import com.google.android.libraries.searchinapps.LocationContext.GeographicalRestrictions
import com.google.android.libraries.searchinapps.LocationContext.LatLng
import com.google.android.libraries.searchinapps.LocationContext.TimeRestrictions
import com.google.android.libraries.searchinapps.LocationContext.TimeSegment
import com.google.android.libraries.searchinapps.SearchInAppsService
import com.google.android.libraries.searchinapps.SearchSuggestionsViewGenerator
...
var locationContext: LocationContext = LocationContext(
GeographicalRestrictions(
CircularArea(
LatLng(40.7414728, -74.0059622),
1000)))
// Optional. If set, there are several businesses in the requested area that
// are open at the given time.
.setTimeRestrictions(
TimeRestrictions(
TimeSegment("2024-05-18T19:20:30.45+01:00")))
// Optional. If set, the returned suggestions are subset of the requested
// categories.
.setGeoTypeRestrictions(
GeoTypeRestrictions("restaurant", "parks"))
// Uses the default SearchSuggestionsViewOptions.
var options: GetSearchSuggestionsViewOptions =
GetSearchSuggestionsViewOptions()
.setLocationContext(listOf<LocationContext>(locationContext))
service.getSearchSuggestionsView(options, callback)
...
অনুসন্ধানের পরামর্শ যোগ করুন UI ভিউ
getSearchSuggestionsView এর চূড়ান্ত আউটপুট হলো একটি SearchSuggestionsViewGenerator অবজেক্ট। আপনি এই অবজেক্টের populateView(Context) ফাংশন ব্যবহার করে UI ভিউ তৈরি করতে এবং updateView(View) ফাংশন ব্যবহার করে বিদ্যমান ভিউ আপডেট করতে পারেন (বিশেষ করে Jetpack Compose অ্যাপের জন্য)।
Jetpack Compose অ্যাপের ক্ষেত্রে, তৈরি হওয়া ক্লাসিক ভিউটি ব্যবহার করার জন্য AndroidView ব্যবহার করা উচিত।
নমুনা কোড
জাভা
package ...;
...
import androidx.appcompat.app.AppCompatActivity;
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewGeneratorCallback;
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewOptions;
import com.google.android.libraries.searchinapps.SearchInAppsService;
import com.google.android.libraries.searchinapps.SearchSuggestionsViewGenerator;
import java.util.Arrays;
import java.util.List;
...
public class MainActivity extends AppCompatActivity implements GetSearchSuggestionsViewGeneratorCallback {
private SearchInAppsService service;
@Override
public void onSuccess(SearchSuggestionsViewGenerator generator) {
ViewGroup container = findViewById(R.id.[container_id]);
container.removeAllViews();
container.addView(generator.populateView(this));
}
@Override
public void onError(String errorMessage) {
...
}
@Override
protected void onCreate(Bundle savedInstanceState) {
...
service = SearchInAppsService.create(this);
List<String> searchContext = Arrays.asList(new String[]{"Query"});
// Uses the default SearchSuggestionsViewOptions.
service.getSearchSuggestionsView(
new GetSearchSuggestionsViewOptions().setTextContext(searchContext),this);
...
}
@Override
public void onDestroy() {
service.shutDown();
super.onDestroy();
}
}
জেটপ্যাক কম্পোজ
package ...
...
import android.os.Bundle
import androidx.activity.compose.setContent
import androidx.appcompat.app.AppCompatActivity
import androidx.compose.runtime.Composable
import androidx.compose.runtime.DisposableEffect
import androidx.compose.runtime.MutableState
import androidx.compose.runtime.mutableStateOf
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.viewinterop.AndroidView
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewGeneratorCallback
import com.google.android.libraries.searchinapps.GetSearchSuggestionsViewOptions
import com.google.android.libraries.searchinapps.SearchInAppsService
import com.google.android.libraries.searchinapps.SearchSuggestionsViewGenerator
...
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent { SearchSuggestionsUI() }
}
@Composable
fun SearchSuggestionsUI() {
...
var service by remember {
mutableStateOf<SearchInAppsService?>(
SearchInAppsService.create(LocalContext.current))
}
var viewGenerator = mutableStateOf<SearchSuggestionsViewGenerator?>(null)
DisposableEffect(Unit) { onDispose { service?.shutDown() } }
val callback =
object : GetSearchSuggestionsViewGeneratorCallback {
override fun onSuccess(generator: SearchSuggestionsViewGenerator) {
viewGenerator.value = generator
}
override fun onError(errorMessage: String) {}
}
var searchContexts: List<String> = listOf<String>("Query")
// Uses the default SearchSuggestionsViewOptions.
var options: GetSearchSuggestionsViewOptions =
GetSearchSuggestionsViewOptions().setTextContext(searchContexts)
service?.getSearchSuggestionsView(options, callback)
ChipGroupUI(viewGenerator)
...
}
@Composable
fun ChipGroupUI(viewGenerator: MutableState<SearchSuggestionsViewGenerator?>) {
viewGenerator.value?.let { viewGenerator ->
var context = LocalContext.current
AndroidView(
factory = { context -> viewGenerator.populateView(context) },
update = { view -> viewGenerator.updateView(view, context) },
)
}
}
}