/* * Tencent is pleased to support the open source community by making * Tencent GT (Version 2.4 and subsequent versions) available. * * Notwithstanding anything to the contrary herein, any previous version * of Tencent GT shall not be subject to the license hereunder. * All right, title, and interest, including all intellectual property rights, * in and to the previous version of Tencent GT (including any and all copies thereof) * shall be owned and retained by Tencent and subject to the license under the * Tencent GT End User License Agreement (http://gt.qq.com/wp-content/EULA_EN.html). * * Copyright (C) 2015 THL A29 Limited, a Tencent company. All rights reserved. * * Licensed under the MIT License (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of the License at * * http://opensource.org/licenses/MIT * * Unless required by applicable law or agreed to in writing, software distributed * under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR * CONDITIONS OF ANY KIND, either express or implied. See the License for the * specific language governing permissions and limitations under the License. */ package com.tencent.wstt.gt.plugin; import java.util.concurrent.LinkedBlockingQueue; import android.app.Activity; import android.os.Bundle; public abstract class PluginItem { public String name; // 作为接收从SDK发送来的命令的标识 public String alias; public String description; public int logo_id; public Class<? extends Activity> activityClass; protected LinkedBlockingQueue<Bundle> taskQueue; private Thread consumerThread; private PluginTaskExecutor mExecutor; public PluginItem(String name, String alias, String descriotion, int logo_id, Class<? extends Activity> activityClass) { this.name = name; this.alias = alias; this.description = descriotion; this.logo_id = logo_id; this.activityClass = activityClass; // 任务限量100 taskQueue = new LinkedBlockingQueue<Bundle>(100); } /** * 初始化连接 GT 时,该插件需要做的事情 */ public void onInitConnectGT() { } /** * 可以接收被测应用传递过来的bundle,至于具体怎么处理,插件拿着Queue看着办吧 * @param bundle */ public void addTask(Bundle bundle) { taskQueue.offer(bundle); } public void setTaskExecutor(final PluginTaskExecutor executor) { if (null != consumerThread) { consumerThread.interrupt(); consumerThread = null; } mExecutor = executor; consumerThread = new Thread(mExecutor.getClass().getName()) { @Override public void run() { try { while (true) { Bundle task = taskQueue.take(); mExecutor.execute(task); } } catch (InterruptedException e) { e.printStackTrace(); } } }; consumerThread.start(); } public void removeTaskExecutor() { if (null != consumerThread) { consumerThread.interrupt(); consumerThread = null; } } /** * 同步执行命令方法 * @param bundle */ public void doTask(Bundle bundle) { mExecutor.execute(bundle); } @Override public boolean equals(Object other) { if (other == this) { return true; } if (! (other instanceof PluginItem)) { return false; } PluginItem otherItem = (PluginItem)other; if (name.equals(otherItem.name)) { return true; } return false; } @Override public int hashCode() { if (name == null) { return -1; } return name.hashCode(); } }