本文整理匯總了Java中com.facebook.react.bridge.Promise類的典型用法代碼示例。如果您正苦於以下問題:Java Promise類的具體用法?Java Promise怎麽用?Java Promise使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
Promise類屬於com.facebook.react.bridge包,在下文中一共展示了Promise類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: share
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
/**
* Open a chooser dialog to send text content to other apps.
*
* Refer http://developer.android.com/intl/ko/training/sharing/send.html
*
* @param content the data to send
* @param dialogTitle the title of the chooser dialog
*/
@ReactMethod
public void share(ReadableMap content, String dialogTitle, Promise promise) {
if (content == null) {
promise.reject(ERROR_INVALID_CONTENT, "Content cannot be null");
return;
}
try {
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setTypeAndNormalize("text/plain");
if (content.hasKey("title")) {
intent.putExtra(Intent.EXTRA_SUBJECT, content.getString("title"));
}
if (content.hasKey("message")) {
intent.putExtra(Intent.EXTRA_TEXT, content.getString("message"));
}
Intent chooser = Intent.createChooser(intent, dialogTitle);
chooser.addCategory(Intent.CATEGORY_DEFAULT);
Activity currentActivity = getCurrentActivity();
if (currentActivity != null) {
currentActivity.startActivity(chooser);
} else {
getReactApplicationContext().startActivity(chooser);
}
WritableMap result = Arguments.createMap();
result.putString("action", ACTION_SHARED);
promise.resolve(result);
} catch (Exception e) {
promise.reject(ERROR_UNABLE_TO_OPEN_DIALOG, "Failed to open share dialog");
}
}
示例2: getAvailableVoices
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void getAvailableVoices(Promise promise) {
if(notReady(promise)) return;
try {
WritableArray voicesList = Arguments.createArray();
Voice[] array = tts.getVoices().toArray(new Voice[tts.getVoices().size()]);
for(Voice voice: array) {
WritableMap newVoice = returnMapForVoice(voice);
voicesList.pushMap(newVoice);
}
promise.resolve(voicesList);
} catch(Exception e) {
promise.reject("not_found", "Unable to retrieve voices for getAvailableVoices()", e);
}
}
開發者ID:echo8795,項目名稱:react-native-android-text-to-speech,代碼行數:18,代碼來源:RNAndroidTextToSpeechModule.java
示例3: getImageIntentBase64
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void getImageIntentBase64(Promise promise) {
if (getCurrentActivity() != null) {
Intent intent = getCurrentActivity().getIntent();
if (intent != null) {
String action = intent.getAction();
String type = intent.getType();
if (Intent.ACTION_SEND.equals(action) && type != null) {
if (type.startsWith("image/")) {
encodedImage = handleSendImage(intent); // Handle single image being sent
}
}
}
}
if (encodedImage != null) {
promise.resolve(encodedImage);
} else {
promise.reject("IMAGE_NOT_FOUND");
}
}
示例4: getAppBrightness
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void getAppBrightness(Promise promise) {
final Activity curActivity = getCurrentActivity();
if(curActivity == null) {
return;
}
try {
float result = curActivity.getWindow().getAttributes().screenBrightness;
if(result < 0){
int val = Settings.System.getInt(getReactApplicationContext().getContentResolver(), Settings.System.SCREEN_BRIGHTNESS);
promise.resolve(val * 1.0f / 255);
}else{
promise.resolve(result);
}
} catch (Exception e) {
e.printStackTrace();
promise.reject("-1", "get app's brightness fail", e);
}
}
示例5: createAndSendTransaction
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
/**
* Create and send transaction.
*
* @param passphrase Passphrase
* @param nonce Account nonce (use -1 to use last known nonce)
* @param toAddress Address destination
* @param amount Amount
* @param gasLimit Gas limit
* @param gasPrice Gas price
* @param data
* @param promise Promise
* @return Return String transaction
*/
@ReactMethod
public void createAndSendTransaction(String passphrase, double nonce, String toAddress,
double amount, double gasLimit, double gasPrice,
String data, Promise promise) {
try {
Account acc = GethHolder.getAccount();
Address fromAddress = acc.getAddress();
BigInt chain = new BigInt(GethHolder.getNodeConfig().getEthereumNetworkID());
Context ctx = new Context();
if (nonce == -1) {
nonce = GethHolder.getNode().getEthereumClient().getPendingNonceAt(ctx, fromAddress);
}
Transaction tx = new Transaction(
(long) nonce,
new Address(toAddress),
new BigInt((long) amount),
new BigInt((long) gasLimit),
new BigInt((long) gasPrice),
data.getBytes("UTF8"));
// Sign a transaction with a single authorization
Transaction signed = GethHolder.getKeyStore().signTxPassphrase(acc, passphrase, tx, chain);
// Send it out to the network.
GethHolder.getNode().getEthereumClient().sendTransaction(ctx, signed);
promise.resolve(tx.toString());
} catch (Exception e) {
promise.reject(NEW_TRANSACTION_ERROR, e);
}
}
示例6: initFingerPrintIdentify
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void initFingerPrintIdentify(final Promise promise) {
currentActivity = getCurrentActivity();
if(currentActivity != null) {
if(this.mFingerprintIdentify == null) {
this.mFingerprintIdentify = new FingerprintIdentify(currentActivity, new BaseFingerprint.FingerprintIdentifyExceptionListener() {
@Override
public void onCatchException(Throwable exception) {
Log.d("ReactNative", "ERROR FINGERPRINT: " + exception.getLocalizedMessage());
}
});
}
sendResponse("ok", null, promise);
} else {
sendResponse("failed", "ERROR_INITIALIZED", promise);
}
}
開發者ID:williamtran29,項目名稱:react-native-fingerprint-identify,代碼行數:18,代碼來源:RNFingerprintIdentifyModule.java
示例7: getSessionInfo
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void getSessionInfo(final Promise callback) {
Taplytics.getSessionInfo(new SessionInfoRetrievedListener() {
@Override
public void sessionInfoRetrieved(HashMap hashMap) {
WritableMap resultData = new WritableNativeMap();
if(hashMap.containsKey("session_id")){
resultData.putString("session_id", (String) hashMap.get("session_id"));
}
if(hashMap.containsKey("appUser_id")){
resultData.putString("appUser_id", (String) hashMap.get("appUser_id"));
}
callback.resolve(resultData);
}
});
}
示例8: queryCache
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void queryCache(final ReadableArray uris, final Promise promise) {
// perform cache interrogation in async task as disk cache checks are expensive
new GuardedAsyncTask<Void, Void>(getReactApplicationContext()) {
@Override
protected void doInBackgroundGuarded(Void... params) {
WritableMap result = Arguments.createMap();
ImagePipeline imagePipeline = Fresco.getImagePipeline();
for (int i = 0; i < uris.size(); i++) {
String uriString = uris.getString(i);
final Uri uri = Uri.parse(uriString);
if (imagePipeline.isInBitmapMemoryCache(uri)) {
result.putString(uriString, "memory");
} else if (imagePipeline.isInDiskCacheSync(uri)) {
result.putString(uriString, "disk");
}
}
promise.resolve(result);
}
}.executeOnExecutor(GuardedAsyncTask.THREAD_POOL_EXECUTOR);
}
示例9: toGraphDef
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void toGraphDef(String id, Promise promise) {
try {
Graph graph = graphs.get(id);
promise.resolve(Base64.encodeToString(graph.toGraphDef(), Base64.DEFAULT));
} catch (Exception e) {
promise.reject(e);
}
}
示例10: close
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void close(String id, Promise promise) {
try {
Graph graph = graphs.get(id);
graph.close();
promise.resolve(true);
} catch (Exception e) {
promise.reject(e);
}
}
示例11: signB64Data
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void signB64Data(final String privKeyData, final String password, final String b64Data, Promise promise) {
try {
// region Decode Base64
byte[] data = Base64.decode(b64Data, Base64.DEFAULT);
// endregion
// region Decode Private Key
PGPSecretKey secKey = PGPUtils.getSecretKey(privKeyData);
PGPPrivateKey privKey = PGPUtils.decryptArmoredPrivateKey(secKey, password);
// endregion
// region Sign Data
String signature = PGPUtils.signArmoredAscii(privKey, data, signatureAlgo);
WritableMap resultMap = Arguments.createMap();
resultMap.putString("asciiArmoredSignature", signature);
resultMap.putString("hashingAlgo", PGPUtils.hashAlgoToString(signatureAlgo));
resultMap.putString("fingerPrint", Utils.bytesToHex(secKey.getPublicKey().getFingerprint()));
promise.resolve(resultMap);
// endregion
} catch (Exception e) {
promise.reject(e);
}
}
示例12: getEnginesInfo
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void getEnginesInfo(Promise promise) {
if(notReady(promise)) return;
try {
WritableArray ttsInfo = Arguments.createArray();
List<TextToSpeech.EngineInfo> engineList = tts.getEngines();
Iterator iterator = engineList.iterator();
while(iterator.hasNext()) {
ttsInfo.pushString(iterator.next().toString());
}
promise.resolve(ttsInfo);
} catch(Exception e) {
promise.reject("error", "Unable to retrieve TTS Engine info for getEnginesInfo()", e);
}
}
開發者ID:echo8795,項目名稱:react-native-android-text-to-speech,代碼行數:19,代碼來源:RNAndroidTextToSpeechModule.java
示例13: createChannel
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
@ReactMethod
public void createChannel(ReadableMap options, final Promise promise) {
final JSONObject attributes = RCTConvert.readableMapToJson(options.getMap("attributes"));
final String uniqueName = options.getString("uniqueName");
String friendlyName = options.getString("friendlyName");
Channel.ChannelType type = (options.getString("type").compareTo("CHANNEL_TYPE_PRIVATE") == 0) ? Channel.ChannelType.PRIVATE : Channel.ChannelType.PUBLIC;
channels().channelBuilder()
.withUniqueName(uniqueName)
.withFriendlyName(friendlyName)
.withType(type)
.withAttributes(attributes)
.build(new CallbackListener<Channel>() {
@Override
public void onError(final ErrorInfo errorInfo) {
super.onError(errorInfo);
promise.reject("create-channel-error", "Error occurred while attempting to createChannel.");
}
@Override
public void onSuccess(final Channel newChannel) {
promise.resolve(RCTConvert.Channel(newChannel));
}
});
}
示例14: canOpenURL
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
/**
* Determine whether or not an installed app can handle a given URL.
*
* @param url the URL to open
* @param promise a promise that is always resolved with a boolean argument
*/
@ReactMethod
public void canOpenURL(String url, Promise promise) {
if (url == null || url.isEmpty()) {
promise.reject(new JSApplicationIllegalArgumentException("Invalid URL: " + url));
return;
}
try {
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));
// We need Intent.FLAG_ACTIVITY_NEW_TASK since getReactApplicationContext() returns
// the ApplicationContext instead of the Activity context.
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
boolean canOpen =
intent.resolveActivity(getReactApplicationContext().getPackageManager()) != null;
promise.resolve(canOpen);
} catch (Exception e) {
promise.reject(new JSApplicationIllegalArgumentException(
"Could not check if URL '" + url + "' can be opened: " + e.getMessage()));
}
}
示例15: getInitialURL
import com.facebook.react.bridge.Promise; //導入依賴的package包/類
/**
* Return the URL the activity was started with
*
* @param promise a promise which is resolved with the initial URL
*/
@ReactMethod
public void getInitialURL(Promise promise) {
try {
Activity currentActivity = getCurrentActivity();
String initialURL = null;
if (currentActivity != null) {
Intent intent = currentActivity.getIntent();
String action = intent.getAction();
Uri uri = intent.getData();
if (Intent.ACTION_VIEW.equals(action) && uri != null) {
initialURL = uri.toString();
}
}
promise.resolve(initialURL);
} catch (Exception e) {
promise.reject(new JSApplicationIllegalArgumentException(
"Could not get the initial URL : " + e.getMessage()));
}
}