- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想从 Android Wear 设备向连接的手机发送消息。Android 智能手机应用程序是用 native Java 编写的并且可以运行。 Wear-Application 是使用 Xamarin 用 c# 编写的,无法正常工作。这是我到目前为止得到的:
public class MainActivity : Activity, IMessageApiMessageListener,
IGoogleApiClientConnectionCallbacks, IResultCallback
{
private IGoogleApiClient mApiClient;
private SensorManager _SensorManager;
private Sensor _Gyroscop;
private static String WEAR_MESSAGE_PATH = "//message";
protected override void OnCreate (Bundle bundle)
{
base.OnCreate (bundle);
// Set our view from the "main" layout resource
SetContentView (Resource.Layout.Main);
var v = FindViewById<WatchViewStub> (Resource.Id.watch_view_stub);
v.LayoutInflated += delegate {
};
if(_SensorManager == null) {
_SensorManager = (SensorManager)GetSystemService(SensorService);
}
SensorListener s = new SensorListener();
_Gyroscop = _SensorManager.GetDefaultSensor (SensorType.Gyroscope);
_SensorManager.RegisterListener (s, _Gyroscop,SensorDelay.Normal);
s.SensorChangedEvent += delegate(SensorEvent e) {
if(mApiClient.IsConnected ){
sendMessage(WEAR_MESSAGE_PATH,"Test");
}
};
initGoogleApiClient ();
}
private void initGoogleApiClient() {
mApiClient = new GoogleApiClientBuilder( this )
.AddApi( WearableClass.Api )
.AddConnectionCallbacks( this )
.Build();
if (mApiClient != null && !(mApiClient.IsConnected || mApiClient.IsConnecting)) {
mApiClient.Connect ();
}
}
private void sendMessage( String path, String text ) {
WearableClass.NodeApi
.GetConnectedNodes (mApiClient)
.SetResultCallback (this);
}
public void OnResult (Java.Lang.Object raw)
{
Exception nodeException, messageException;
try {
//send the message
var nodeResult = raw.JavaCast<INodeApiGetConnectedNodesResult> ();
foreach (var node in nodeResult.Nodes)
WearableClass.MessageApi.SendMessage (mApiClient, node.Id, WEAR_MESSAGE_PATH, StringToByteArray("Test")).SetResultCallback (this); //will go to second try/catch block
return;
} catch (Exception e) {
nodeException = e;
}
try {
//check that it worked correctly
var messageResult = raw.JavaCast<IMessageApiSendMessageResult> ();
if (!messageResult.Status.IsSuccess)
Console.WriteLine ("Problem");
return;
} catch (Exception e) {
messageException = e;
}
}
public void OnConnected (Bundle p0)
{
WearableClass.MessageApi.AddListener (mApiClient, this);
}
public void OnConnectionSuspended (int p0)
{
WearableClass.MessageApi.RemoveListener (mApiClient, this);
}
}
问题是手机没有收到消息。
最佳答案
我终于完成了一个演示手持设备和穿戴设备之间通信的最小工作示例。它是纯 Xamarin 解决方案,允许双向发送消息和数据映射。
由于手持设备和可穿戴设备发送和接收信息的方式相同,因此我创建了一个名为“Communication”的共享项目。它包含一个由两个应用程序使用的“Communicator”类。
此外,在这个简单示例中,两个主要 Activity 的 AXML 和 C# 实现是相同的。我们将在每个设备上看到两个按钮,用于发送新消息或一些数据。
Communicator
类派生自 Java.Lang.Object
并实现两个监听器接口(interface)。
public class Communicator: Java.Lang.Object, IMessageApiMessageListener, IDataApiDataListener
{
...
它包含一个 IGoogleApiClient
readonly IGoogleApiClient client;
并存储一个公共(public)路径:
const string path = "/communicator";
(这两个 API,消息 API 和数据 API,都需要一个“路径”作为一种通信 channel 标识符。对所有消息使用相同的路径是第一次尝试,但在增加流量时可能会产生噪音更复杂的应用程序。)
Communicator
使用 Android Context
构建并构建 IGoogleApiClient
.
public Communicator(Context context)
{
client = new GoogleApiClientBuilder(context)
.AddApi(WearableClass.Api)
.Build();
}
以下方法将在恢复或暂停 Activity 时调用。他们连接或断开 client
并注册或取消注册 Communicator
作为消息/数据监听器:
public void Resume()
{
if (!client.IsConnected) {
client.Connect();
WearableClass.MessageApi.AddListener(client, this);
WearableClass.DataApi.AddListener(client, this);
}
}
public void Pause()
{
if (client != null && client.IsConnected) {
client.Disconnect();
WearableClass.MessageApi.RemoveListener(client, this);
WearableClass.DataApi.RemoveListener(client, this);
}
}
发送信息有两种比较相似的方法,一种是消息,一种是数据 map 。为了避免阻塞 UI,这两个任务都在后台线程上执行。请注意,消息被发送到特定的“节点”(= 设备),而数据没有特定的接收者。
public void SendMessage(string message)
{
Task.Run(() => {
foreach (var node in Nodes()) {
var bytes = Encoding.Default.GetBytes(message);
var result = WearableClass.MessageApi.SendMessage(client, node.Id, path, bytes).Await();
var success = result.JavaCast<IMessageApiSendMessageResult>().Status.IsSuccess ? "Ok." : "Failed!";
Console.WriteLine(string.Format("Communicator: Sending message {0}... {1}", message, success));
}
});
}
public void SendData(DataMap dataMap)
{
Task.Run(() => {
var request = PutDataMapRequest.Create(path);
request.DataMap.PutAll(dataMap);
var result = WearableClass.DataApi.PutDataItem(client, request.AsPutDataRequest()).Await();
var success = result.JavaCast<IDataApiDataItemResult>().Status.IsSuccess ? "Ok." : "Failed!";
Console.WriteLine(string.Format("Communicator: Sending data map {0}... {1}", dataMap, success));
});
}
当然,我们需要接收数据的方法。它们实际上是由上面的两个接口(interface)定义的,需要得到实现。 (OnDataChanged
检查正确的路径,因为数据可能不专用于此应用。)
public void OnMessageReceived(IMessageEvent messageEvent)
{
var message = Encoding.Default.GetString(messageEvent.GetData());
Console.WriteLine(string.Format("Communicator: Message received \"{0}\"", message));
MessageReceived(message);
}
public void OnDataChanged(DataEventBuffer p0)
{
Console.WriteLine(string.Format("Communicator: Data changed ({0} data events)", p0.Count));
for (var i = 0; i < p0.Count; i++) {
var dataEvent = p0.Get(i).JavaCast<IDataEvent>();
if (dataEvent.Type == DataEvent.TypeChanged && dataEvent.DataItem.Uri.Path == path)
DataReceived(DataMapItem.FromDataItem(dataEvent.DataItem).DataMap);
}
}
他们每个人都调用以下事件之一。
public event Action<string> MessageReceived = delegate {};
public event Action<DataMap> DataReceived = delegate {};
最后但同样重要的是,我们需要一种方法来检索所有连接的节点:
IList<INode> Nodes()
{
var result = WearableClass.NodeApi.GetConnectedNodes(client).Await();
return result.JavaCast<INodeApiGetConnectedNodesResult>().Nodes;
}
为简单起见,两个应用使用相同的布局。它包含两个按钮,每个按钮占屏幕总大小的 50%。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<Button
android:id="@+id/messageButton"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="Send message" />
<Button
android:id="@+id/dataButton"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="Send data" />
</LinearLayout>
这两个应用程序都实现了 MainActivity
源自 Activity
:
public class MainActivity : Activity
{
...
每个 Activity 都有一个 communicator
封装所有与通信相关的代码。
Communicator communicator;
在 OnCreate
的末尾我们实例化 communicator
,
communicator = new Communicator(this);
并连接messageButton
var messageButton = FindViewById<Button>(Resource.Id.messageButton);
messageButton.Click += (sender, e) => communicator.SendMessage("time: " + DateTime.Now.ToString("T"));
communicator.MessageReceived += message => RunOnUiThread(() => messageButton.Text = message);
以及 dataButton
var dataButton = FindViewById<Button>(Resource.Id.dataButton);
dataButton.Click += delegate {
var dataMap = new DataMap();
dataMap.PutString("time", DateTime.Now.ToString("T"));
communicator.SendData(dataMap);
};
communicator.DataReceived += dataMap => RunOnUiThread(() => dataButton.Text = dataMap.ToString());
(我们使用格式标识符“T”生成包含秒数的“长时间”字符串。这样,在大多数情况下,字符串会从一次点击变为另一次点击。这很重要,因为发送相同的数据映射 两次不会触发 OnDataChanged
事件处理程序!)
最后,我们Resume
和 Pause
communicator
在正确的地方:
protected override void OnResume()
{
base.OnResume();
communicator.Resume();
}
protected override void OnPause()
{
communicator.Pause();
base.OnPause();
}
由于我们使用的是 Google 移动服务,因此我们需要将以下行放入 <application>
两者的标签 AndroidManifest.xml
文件:
<meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />
打开应用程序时,我们会看到以下屏幕。
点击几下后,两个应用程序都会通过消息 API 或数据 API 相互发送当前时间。现在屏幕如下所示。
请注意,某些数据映射的发送者也会收到它。所以时间上dataButton
在两个设备上都是一样的。相反,消息只发送给所有其他节点,因此不会返回给发送者。
关于c# - Android wear Xamarin 消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28570070/
我已经从github https://github.com/xamarin/xamarin-forms-samples下载了Xamarin.Form示例项目 打开任何示例项目后,它不允许我在iOS S
我收到此错误: "MyApp\App.cs(7,7): Error CS0246: The type or namespace name 'Xamarin' could not be found (a
我想知道 Xamarin 是否带有 Mono 运行时及其所有应用程序包。在这种情况下,如果两个基于 Xamarin 的应用程序安装在一个设备上,该设备将拥有两个 Mono 运行时权利。这是 Xamar
如何将库导入 Xamarin? 例如,我将如何导入 json.net为我的项目使用 xamarin? 谢谢 最佳答案 Json.NET可免费获得精美包装 Xamarin-compatible Comp
我不知道如何在输入框中置顶占位符文本。 我有一个很大的输入框,想把占位符文本放在顶部。 最佳答案 您需要为每个平台创建一个自定义渲染器以对齐占位符,如下所示: public class Placeh
我很难找到有关Xamarin.Forms的后台任务支持的文档。 Xamarin.Forms是否提供对定期后台任务的支持? 我需要为Windows Phone 10和Android都实现此功能。 最佳答
Xamarin.iOS中是否提供iOS Picker?我进行了详尽的搜索,但是没有示例,也没有信息可查。但是,它在Xamarin.Form中可用。 最佳答案 UIPickerView的真实示例示例:(
有谁知道是否可以使用 Xamarin.Forms 创建CardView样式(可滚动)列表?我们需要它在iOS和Android上将呈现为相同的。还需要调整阴影等属性(略微提高每张卡) 最佳答案 这是一个
所以,我对 Xamarin 有点陌生,我试图弄清楚如何显示一个包含用户文本输入字段的弹出窗口。 DisplayAlert 不这样做,因为它没有文本输入字段。我应该使用什么? 最佳答案 您可以使用 Di
我有一个运行良好的表单应用程序,但我注意到当页面出现时,背景颜色在几分之一秒内设置不正确。 我有这个代码用于我的 OnAppearing protected override async vo
您好,我正在开发一个具有登录功能的应用程序,它可以选择让您保持登录状态,即使您关闭该应用程序也是如此。 问题是什么?这就是我在 App.cs 中所做的: var statusLog = Appli
由于BackgroundImage是一个字符串,您应该如何设置Page的背景图像?我将不胜感激任何建议。 到目前为止,我已经尝试过: MainPage = new ContentPage {
如何使用 Renderer 在 Xamarin Forms 中使用渐变效果创建此按钮? 最佳答案 在 xamarin 中,您不能将渐变颜色添加为内置功能。您必须创建不同的渲染功能。这个 link 将指
背景:我正在处理一个 C# 项目。过去,当我做 System.Console.WriteLine("Hello"); 我会看到一个弹出控制台打印“你好”。控制台今天消失了,我该怎么做才能让它再次出现?
我们每天都在使用 Xamarin 和 Xamarin Forms,并且经常遇到异常而没有任何关于如何调试的有用信息。 有时它是我们的目标,有时是 Xamarin 中的错误,尤其是 Xamarin Fo
我正在使用 xamarin studio(带有 nuget 包管理插件),并且在我的项目中有一些 nuget 包。 项目上下文菜单中有“管理”和“恢复 nuget 包”,但也有控制台吗? 最佳答案 X
我有一个 CustomCalendar 元素,它是通过扩展 ContentView 并在另一个 ContentPage 中使用此自定义 View 而创建的。我尝试使用非聚焦事件来检测外部点击。但是问题
因此,对于整个MVVM,我还是一个新手。我几乎了解它的基本知识。我有一个可以按原样工作的示例,但是我试图将其更改为MVVM样式。我只是尝试不同的例子,所以我可以学习。 (LoginPage.xaml)
我正在尝试使我的Xamarin项目在Prism和DryIoc中使用MVVM。 我主要想使用自动注册,如下所示: [AutoRegisterForNavigation] ... protected ov
我有一个问题,如何在 Forms Xamarin 中制作模态屏幕,如附加的图像。 我想知道你们是否可以向我发送一段代码或示例以了解如何做到这一点。 https://extravios.com.br/c
我是一名优秀的程序员,十分优秀!