Last Updated on : 2023-03-09 08:17:39
Scene recommendation is designed to improve connections between users and smart devices through scene services and enhance smart scene capabilities for the devices.
This topic describes API methods for scene recommendation to implement a range of features. For example, get a list of recommended scenes, get a list of recommended scenes for a specific device, get details of a recommended scene, and add or remove a recommended scene. For more information about scene recommendation, see Scene Recommendation Management.
API description
Returns a list of the latest scenes that match certain conditions before you call getRecommendAll that returns a list of recommended scenes.
This API method is throttled every 12 hours. The matching logic will no longer be executed in the cloud within each throttling period if this API method is repeatedly called. This API method is only applicable to apps developed based on App SDK v3.29.0 or later.
fun requireRecommendMatch(relationId: Long, callback: IResultCallback<Boolean>?)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
callback | The callback. |
Example
For App SDK v3.34.5 and later:
TuyaHomeSdk.getSceneServiceInstance().recommendService().requireRecommendMatch(
relationId,
object : IResultCallback<Boolean>() {
override fun onSuccess(result: Boolean) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
For App SDK versions earlier than v3.34.5:
TuyaHomeSdk.getSceneManagerInstance().requestRecomMore(homeId, new IResultCallback() {
@Override
public void onError(String code, String error) {
}
@Override
public void onSuccess() {
}
});
API description
Returns a list of recommended scenes. Before this API method, you must call requireRecommendMatch that returns a list of the latest matching scenes. Otherwise, the recommended scenes in the response will be unchanged. This API method is only applicable to apps developed based on App SDK v3.21.0 or later.
fun getRecommendAll(relationId: Long, callback: IResultCallback<List<RecommendScene>?>?)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
callback | The callback. |
The following table lists the properties of RecommendScene
.
Field | Type | Description |
---|---|---|
id | long | The ID of the recommended scene. |
recommendId | String | The ID of the recommended scene. |
matchType | int | The rules of matching conditions. Valid values:
|
ownerId | String | The home ID. |
name | String | The name of the scene. |
coverIcon | String | The URL of the scene icon. |
background | String | The background image. |
displayColor | String | The background color of the displayed scene. |
recomDescription | String | The description of the scene. |
recomCoefficient | int | The recommendation coefficient. |
hotCount | String | The number of users who have accessed the recommended scene. |
ruleGenre | int | The type of linkage that triggers the scene. |
conditions | List<SceneCondition> | The list of scene conditions. |
actions | List<SceneAction> | The list of actions in the scene. |
Example
For App SDK v3.34.5 and later:
TuyaHomeSdk.getSceneServiceInstance().recommendService().getRecommendAll(
relationId,
object : IResultCallback<List<RecommendScene>?>() {
override fun onSuccess(result: List<RecommendScene>?) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
For App SDK versions earlier than v3.34.5:
TuyaHomeSdk.getSceneManagerInstance().getRecommendSceneList(homeId, new ITuyaResultCallback<List<SceneBean>>() {
@Override
public void onSuccess(List<SceneBean> sceneBeans) {
}
@Override
public void onError(String errorCode, String errorMessage) {
}
});
API description
Returns a list of the latest matching scenes that can be recommended to a device at the end of the pairing process. This API method is called before the request that displays the recommended scenes for the device.
This API method is throttled every 12 hours. The matching logic will no longer be executed in the cloud within each throttling period if this API method is repeatedly called. This API method is only applicable to apps developed based on App SDK v3.29.0 or later.
fun requireRecommendMatchTwo(relationId: Long, callback: IResultCallback<Boolean>?)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
callback | The callback. |
Example
For App SDK v3.34.5 and later:
TuyaHomeSdk.getSceneServiceInstance().recommendService().requireRecommendMatchTwo(
relationId,
object : IResultCallback<Boolean>() {
override fun onSuccess(result: Boolean) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
For App SDK versions earlier than v3.34.5:
TuyaHomeSdk.getSceneManagerInstance().requestRecomMoreNew(homeId, new IResultCallback() {
@Override
public void onError(String code, String error) {
}
@Override
public void onSuccess() {
}
});
API description
Returns a list of scenes that are recommended to a specific device. Before this API method, you must call requireRecommendMatchTwo that returns a list of the latest scenes matching the device. Otherwise, the recommended scenes in the response will be unchanged. This API method is only applicable to apps developed based on App SDK v3.29.0 or later.
fun getRecommendsByDevice(
relationId: Long,
deviceId: String,
size: Int,
callback: IResultCallback<List<RecommendScene>?>?
)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
deviceId | The device ID. |
size | The number of recommended scenes. For more information, see Scene Recommendation Rules. |
callback | The callback. |
Example
For App SDK v3.34.5 and later:
TuyaHomeSdk.getSceneServiceInstance().recommendService().getRecommendsByDevice(
relationId, devId, 3,
object : IResultCallback<List<RecommendScene>?>() {
override fun onSuccess(result: List<RecommendScene>?) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
For App SDK versions earlier than v3.34.5:
TuyaHomeSdk.getSceneManagerInstance().getRecommendSceneListByDev(homeId, devId, 3, new ITuyaResultCallback<List<SceneBean>>() {
@Override
public void onSuccess(List<SceneBean> result) {
}
@Override
public void onError(String errorCode, String errorMessage) {
}
});
API description
Returns a list of scenes that are recommended to multiple devices in the same call. This API method is only applicable to apps developed based on App SDK v3.34.5 or later.
fun requestRecommendSceneWithDeviceIds(
relationId: Long,
devIds: String,
source: Int,
callback: IResultCallback<ArrayList<RecommendPlainScene?>?>
)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
devIds | The list of device IDs, separated with commas (,). Example: “6cda1ca75a5a768f5czn9i,6cda1ca75a5a768f5czn9b” |
source |
|
callback | The callback. |
Example
TuyaHomeSdk.getSceneServiceInstance().recommendService().requestRecommendSceneWithDeviceIds(relationId, devIds, 1,
object : IResultCallback<ArrayList<RecommendPlainScene?>?> {
override fun onSuccess(result: ArrayList<RecommendPlainScene?>?) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
API description
Returns details of a recommended scene. This API method is only applicable to apps developed based on App SDK v3.34.5 or later.
fun requestRecommendDetail(relationId: Long, sceneId: String, callback: IResultCallback<RecommendScene?>?)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
sceneId | The scene ID. It is equivalent to the recommendId field of RecommendScene . |
callback | The callback. |
Example
TuyaHomeSdk.getSceneServiceInstance().recommendService().requestRecommendDetail(
relationId, recommendId,
object : IResultCallback<RecommendScene?>() {
override fun onSuccess(result: RecommendScene?) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
API description
Adds a recommended scene on the scene details page to save the scene as an effective one.
After the scene is added, you must refresh the list of recommended scenes and effective scenes. The scene will not be recommended after it is added to the list of effective scenes. This API method is only applicable to apps developed based on App SDK v3.21.0 or later.
fun handleRecommend(
relationId: Long,
sceneId: String,
action: String,
sceneData: NormalScene?,
callback: IResultCallback<Boolean?>?
)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
sceneId | The scene ID. It is equivalent to the recommendId field of RecommendScene . |
action | The action to add or save the recommended scene. |
sceneData | The scene data in the edit area. |
callback | The callback. |
Example
For App SDK v3.34.5 and later:
TuyaHomeSdk.getSceneServiceInstance().recommendService().handleRecommend(
relationId, sceneId, "save", normalScene,
object : IResultCallback<Boolean?>() {
override fun onSuccess(result: Boolean?) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
For App SDK versions earlier than v3.34.5:
final SceneBean bean = new SceneBean();
bean.setActions(smartSceneBean.getActions());
bean.setBackground(smartSceneBean.getBackground());
bean.setCode(smartSceneBean.getCode());
bean.setConditions(smartSceneBean.getConditions());
bean.setEnabled(smartSceneBean.isEnabled());
bean.setStickyOnTop(smartSceneBean.isTop());
bean.setId(smartSceneBean.getId());
bean.setName(smartSceneBean.getName());
bean.setMatchType(smartSceneBean.getMatchType());
bean.setBoundForPanel(smartSceneBean.isBoundForPanel());
bean.setPreConditions(smartSceneBean.getPreConditions());
bean.setNewLocalScene(smartSceneBean.isNewLocalScene());
bean.setLocalLinkage(smartSceneBean.isLocalLinkage());
bean.setStickyOnTop(smartSceneBean.isTop());
bean.setHotCount(smartSceneBean.getHotCount());
bean.setDisplayColor(smartSceneBean.getCoverColor());
bean.setCoverIcon(smartSceneBean.getCoverIcon());
TuyaHomeSdk.getSceneManagerInstance().recommendSceneSave(homeId, Long.parseLong(bean.getId()), bean, new IResultCallback() {
@Override
public void onError(String code, String error) {
}
@Override
public void onSuccess() {
}
});
API description
Removes an undesired recommended scene from the scene details page. Then, the scene disappears from the list of recommended scenes.
After the scene is removed, you must refresh the list of recommended scenes. The scene will no longer be recommended. This API method is only applicable to apps developed based on App SDK v3.21.0 or later.
fun handleRecommend(
relationId: Long,
sceneId: String,
action: String,
sceneData: NormalScene?,
callback: IResultCallback<Boolean?>?
)
Parameters
Parameter | Description |
---|---|
relationId | The home ID. |
sceneId | The scene ID. It is equivalent to the recommendId field of RecommendScene . |
action | The action to remove or cancel the recommended scene. |
sceneData | The scene data in the edit area. |
callback | The callback. |
Example
For App SDK v3.34.5 and later:
TuyaHomeSdk.getSceneServiceInstance().recommendService().handleRecommend(
relationId, sceneId, "remove", null,
object : IResultCallback<Boolean?>() {
override fun onSuccess(result: Boolean?) {
}
override fun onError(errorCode: String?, errorMessage: String?) {
}
})
For App SDK versions earlier than v3.34.5:
TuyaHomeSdk.getSceneManagerInstance().recommendSceneRemove(homeId, sceneId, null, new IResultCallback() {
@Override
public void onError(String code, String error) {
}
@Override
public void onSuccess() {
}
});
Is this page helpful?
YesFeedbackIs this page helpful?
YesFeedback