Emoticons – Windows Phone
Olá pessoal, tudo bom?
Nesse post apenas compartilho uma dica que também foi publicada no site WinPhoneBrasil. Quando você envia mensagens através do seu Windows Phone o teclado virtual apresenta algumas opções de emoticons, porém, há várias outras imagens que não foram adicionadas ao teclado, mas que também podem ser enviadas junto à mensagem. Veja a imagem abaixo:
Windows Phone Emoticons – Fonte: http://winphonebrasil.com.br/11893/dica-emoticons-nativos-do-windows-phone/wpemoticons-4
Clique AQUI para aumentar o tamanho da imagem.
Grande abraço e fica a dica!
Eduardo Henrique Rizo
Post relacionado:
Curso Windows Phone – Acelerometro (Accelerometer)
Nesse post faço uma pequena demonstração sobre como utilizar o acelerometro do Windows Phone. No exemplo, capturamos as informações relacionadas ao plano XYZ e aproveitamos também para montar uma aplicação que simula o nível e prumo de um determinado objeto.
O valor do acelerometro é disponibilizado em um vetor tridimensional que representa os componentes de aceleração nos eixos X, Y, e Z em unidades gravitacionais.
O sensor do acelerometro irá detectar a força da gravidade, juntamente com quaisquer forças resultantes do movimento do telefone. A classe MotionReading utiliza sensores de dispositivos múltiplos para separar o vetor gravidade da aceleração do dispositivo e permite a você facilmente determinar a atitude atual (yaw, pitch e roll) do dispositivo.
Para capturar as informações do acelerometro é necessário utilizar a classe Accelerometer, onde se obtem, por exemplo, as coordenadas XYZ de acordo com a posição que o usuário estiver segurando o telefone.
Para o exemplo em questão, você precisará utilizar os namespaces Microsoft.Devices.Sensors e Microsoft.Xna.Framework.
Abaixo, demonstro o código Silverlight para composição dos elementos da tela:
...
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
<StackPanel>
<TextBlock x:Name="CoordX" Foreground="Red" HorizontalAlignment="Center" Text="{Binding ValorXProperty, StringFormat='X: {0}'}" FontSize="30" FontWeight="Bold" />
<TextBlock x:Name="CoordY" Foreground="Green" HorizontalAlignment="Center" Text="{Binding ValorY, StringFormat='Y: {0}'}" FontSize="30" FontWeight="Bold" />
<TextBlock x:Name="CoordZ" Foreground="Blue" HorizontalAlignment="Center" Text="{Binding ValorZ, StringFormat='Z: {0}'}" FontSize="30" FontWeight="Bold" />
</StackPanel>
<Line x:Name="LinhaX" X1="220" Y1="400" X2="320" Y2="400" Stroke="Red" StrokeThickness="5" />
<Line x:Name="LinhaY" X1="220" Y1="400" X2="220" Y2="310" Stroke="Green" StrokeThickness="5" />
<Line x:Name="LinhaZ" X1="220" Y1="400" X2="170" Y2="450" Stroke="Blue" StrokeThickness="5" />
<Rectangle x:Name="Regua" Margin="0,480,0,0" Width="450" Height="80" Stroke="#FFC0C0C0" RadiusX="40" RadiusY="40"/>
<Line Margin="0,480,0,0" Stroke="#FFC0C0C0" X1="0" Y1="0" X2="0" Y2="120" HorizontalAlignment="Center" />
<Ellipse x:Name="ball" Width="70" Height="70" Fill="Red" Margin="0,480,0,0">
<Ellipse.RenderTransform>
<TranslateTransform x:Name="BallTransform"/>
</Ellipse.RenderTransform>
</Ellipse>
</Grid>
...
Declaração do objeto da classe Accelerometer, inicialização e definição dos métodos para tratamento dos movimentos:
...
Accelerometer acelerometroOBJ = null;
// Constructor
public MainPage()
{
InitializeComponent();
if (Accelerometer.IsSupported)
{
acelerometroOBJ = new Accelerometer { TimeBetweenUpdates = TimeSpan.FromMilliseconds(10) };
acelerometroOBJ.CurrentValueChanged += acelerometro_CurrentValueChanged;
acelerometroOBJ.ReadingChanged += new EventHandler(acelerometroOBJ_ReadingChanged);
acelerometroOBJ.Start();
}
else
MessageBox.Show("Desculpe, mas seu dispositivo não oferece suporte para o acelerometro");
}
...
Nesse método chamamos outro método via Dispatcher que receberá as informações X, Y e Z (gravitacional)
...
void acelerometro_CurrentValueChanged(object sender, SensorReadingEventArgs<AccelerometerReading> e)
{
Dispatcher.BeginInvoke(() => UpdateUI(e.SensorReading));
}
...
Nesse chamamos um método para trabalhar com as coordenadas X e Y
...
void acelerometroOBJ_ReadingChanged(object sender, AccelerometerReadingEventArgs e)
{
double x = e.X;
x = x > 0.5 ? 0.5 : x;
x = x < -0.5 ? -0.5 : x;
Dispatcher.BeginInvoke(() => UpdateBall(x));
}
...
Tratando o movimento para as linhas do plano X, Y e Z
...
private void UpdateUI(AccelerometerReading accelerometerReading)
{
Vector3 aceleracao = accelerometerReading.Acceleration;
CoordX.Text = "X: " + aceleracao.X.ToString("0.000");
CoordY.Text = "Y: " + aceleracao.Y.ToString("0.000");
CoordZ.Text = "Z: " + aceleracao.Z.ToString("0.000");
LinhaX.X2 = LinhaX.X1 + aceleracao.X * 200;
LinhaY.Y2 = LinhaY.Y1 + aceleracao.Y * 200;
LinhaZ.X2 = LinhaZ.X1 + aceleracao.Z * 100;
LinhaZ.Y2 = LinhaZ.Y1 + aceleracao.Z * 100;
}
...
Tratando o movimento para o exemplo do prumo e nível (X e Y)
...
private void UpdateBall(double x)
{
BallTransform.X = x * (Regua.Width - ball.Width);
}
...
Para início é isso, daqui para frente é só usar a imaginação.
Grande abraço,
Eduardo Henrique Rizo
Post relacionado:
Inventário de Hardware e Software: Instalação e configuração da ferramenta OCS Inventory
Olá pessoal, tudo bom?
Produzi um vídeo que demonstra como instalar e configurar a ferramenta para inventário de hardware e software OCS Inventory.
Vale ressaltar que essa é uma ferramenta free, ou seja, não há necessidade de aquisição de licenças para uso.
Um grande abraço a todos,
Eduardo Henrique Rizo
Post relacionado:
Curso Windows Phone – Aplicações com suporte a versões Trial
Olá pessoal, tudo bom?
Criei um vídeo (sem audio, mas legendado) que explica passo a passo uma técnica para incluir em seu aplicativo o suporte a versões Trial. Isso passa a ser importante quando você disponibiliza no Marketplace aplicações com custo para o usuário, sendo assim, ele poderá testar seu aplicativo antes de decidir pela compra do mesmo.
Grande abraço,
Eduardo Henrique Rizo
Post relacionado:
Curso Windows Phone – Como tratar o clique do botão Back do celular com Windows Phone
Olá pessoal, tudo bom?
Segue uma dica rápida sobre como tratar o clique do botão Back (voltar) de um aparelho celular com o sistema Windows Phone da Microsoft. Essa dica pode vir a ser importante em situações onde o desenvolvedor queira perguntar ao usuário, por exemplo, se ele realmente gostaria de sair da aplicação que está usando, ou quando você quiser personalizar a ação desse botão.
Veja o código C# que você deve adicionar em toda página da aplicação Windows Phone onde se queira utilizar esse recurso:
protected override void OnBackKeyPress(System.ComponentModel.CancelEventArgs e)
{
if (MessageBox.Show("Sair do aplicativo?", "Logout", MessageBoxButton.OKCancel) == MessageBoxResult.OK)
{
//Faça alguma coisa aqui...
base.OnBackKeyPress(e);
}
else
e.Cancel = true;
}
Grande abraço,
Eduardo Henrique Rizo
Post relacionado:
Processo de instalação do OpenNMS em um servidor Debian 6 (vídeo)
O vídeo disponibilizado neste post visa complementar o artigo “Instalação do OpenNMS no Debian – Passo a passo” que também está disponível neste Blog.
Um grande abraço,
Eduardo Henrique Rizo


