Android 客户端:

package com.example.admin.gpsget;

import android.Manifest;
import android.content.Context;
import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager; import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.EditText;
import android.widget.Button;
import android.widget.Toast;
import android.view.View; import java.io.IOException;
import java.io.PrintStream;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Timer;
import java.util.TimerTask; import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.os.HandlerThread;
import android.os.Message; import static java.lang.Thread.sleep; import java.util.Timer;
import java.util.TimerTask; public class MainActivity extends AppCompatActivity implements Runnable
{
private LocationManager locationManager; private final String SERVER_HOST_IP = "10.41.239.240"; /* 服务器端口 */
private final int SERVER_HOST_PORT = 9400; private Button btnConnect;
private Button btnSend;
private EditText show;
private Socket socket;
private PrintStream output;
private Thread thread; public void toastText(String message)
{
Toast.makeText(this, message, Toast.LENGTH_LONG).show();
} public void handleException(Exception e, String prefix)
{
e.printStackTrace();
toastText(prefix + e.toString());
} @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initView(); // 获取系统LocationManager服务
locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
// 从GPS获取最近的定位信息 Location location = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
updateView(location); // 将location里的位置信息显示在EditText中 /* 设置每2秒获取一次GPS的定位信息 */ locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 5000, 1, new LocationListener() { @Override
public void onLocationChanged(Location location) {
// 当GPS定位信息发生改变时,更新位置
updateView(location);
} @Override
public void onProviderDisabled(String provider) {
updateView(null);
} @Override
public void onProviderEnabled(String provider) {
// 当GPS LocationProvider可用时,更新位置
updateView(locationManager.getLastKnownLocation(provider)); } @Override
public void onStatusChanged(String provider, int status,
Bundle extras) {
}
}); thread=new Thread(this);
thread.start();
btnConnect.setOnClickListener(new Button.OnClickListener()
{
@Override
public void onClick(View v)
{
// initClientSocket();
}
}); btnSend.setOnClickListener(new Button.OnClickListener() {
@Override
public void onClick(View v) {
sendMessage(show.getText().toString());
}
}); }
private void updateView(Location location) {
if (location != null) {
StringBuffer sb = new StringBuffer();
sb.append("position: \nlat:");
sb.append(location.getLongitude());
sb.append("\nlng:");
sb.append(location.getLatitude());
sb.append("\nhight:");
sb.append(location.getAltitude());
sb.append("\nspeed:");
sb.append(location.getSpeed());
sb.append("\ndirection:");
sb.append(location.getBearing());
sb.append("\njingdu:");
sb.append(location.getAccuracy());
sb.append("\n");
show.setText(sb.toString());
} else {
// 如果传入的Location对象为空则随便显示点东西
show.setText("juygfugf");
}
} public void initView()
{
btnConnect = (Button)findViewById(R.id.btnConnect);
btnSend = (Button)findViewById(R.id.btnSend);
show = (EditText) findViewById(R.id.editText); btnSend.setEnabled(false);
show.setEnabled(false);
} public void closeSocket()
{
try
{
output.close();
socket.close();
}
catch (IOException e)
{
handleException(e, "close exception: ");
}
} private void initClientSocket()
{
try
{
/* 连接服务器 */
socket = new Socket(SERVER_HOST_IP, SERVER_HOST_PORT); /* 获取输出流 */
output = new PrintStream(socket.getOutputStream(), true, "utf-8"); btnConnect.setEnabled(false);
btnSend.setEnabled(true);
}
catch (UnknownHostException e)
{
handleException(e, "unknown host exception: " + e.toString());
}
catch (IOException e) {
handleException(e, "io exception: " + e.toString());
}
} private void sendMessage(String msg)
{
output.print(msg);
} @Override
public void run() {
initClientSocket();
while (true)
{
try {
Thread.currentThread().sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace(); }
sendMessage(show.getText().toString());
} }
}

AndroidManifest.xml添加:

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.INTERNET" />

界面如下:

c++服务端:

#include <WinSock2.h>
#include <stdio.h>
#include <Windows.h> #pragma comment(lib,"ws2_32.lib") int main(int argc,char *argv[])
{ short port; port=9400;
WSADATA wsa; if (WSAStartup(MAKEWORD(2,2),&wsa)!=0)
{
printf("socket init error");
exit(-1);
} SOCKET serverSocket; if((serverSocket=socket(AF_INET,SOCK_STREAM,IPPROTO_TCP))==INVALID_SOCKET)
{
printf("创建套接字失败!");
exit(-1);
} struct sockaddr_in serverAddress;
memset(&serverAddress,0,sizeof(sockaddr_in));
serverAddress.sin_family=AF_INET;
serverAddress.sin_addr.S_un.S_addr=htonl(INADDR_ANY);
serverAddress.sin_port=htons(port); if (bind(serverSocket,(sockaddr*)&serverAddress,sizeof(serverAddress))==SOCKET_ERROR)
{
printf("socket port error:%d",port);
exit(-1);
} if (listen(serverSocket,SOMAXCONN)==SOCKET_ERROR)
{
printf("listen error");
exit(-1);
}
printf("Server 9400 is listening......\n");
SOCKET clientSocket;
struct sockaddr_in clientAddress; memset(&clientAddress,0,sizeof(clientAddress));
int addrlen=sizeof(clientAddress); if ((clientSocket=accept(serverSocket,(sockaddr*)&clientAddress,&addrlen))==INVALID_SOCKET)
{
printf("link error");
exit(-1);
} char buf[4096]; while (1)
{
int bytes=recv(clientSocket,buf,sizeof(buf),0); /* if ((bytes=recv(clientSocket,buf,sizeof(buf),0))==SOCKET_ERROR)
{
printf("data error");
exit(-1);
}*/ buf[bytes]='\0';
printf("Message from %s:\n %s\n",inet_ntoa(clientAddress.sin_addr),buf);
// if(send(clientSocket,buf,bytes,0)==SOCKET_ERROR)
// {
// printf("发送数据失败!");
//// exit(-1);
// } } WSACleanup();
exit(-1); }

Android实时获得经纬度,发送给c++服务端的更多相关文章

  1. android上传图片、视频、文件,服务端使用wcf接收

    最近一直在搞android上传图片.视频.文件,服务端使用wcf接收,本文对调试中的遇到的问题进行记录. 首先android上传一些小图片是比较容易的一天下来差不多就能调试出来,但是上传一些大的文件时 ...

  2. 浅谈android Socket 通信及自建ServerSocket服务端常见问题

    摘  要:TCP/IP通信协议是可靠的面向连接的网络协议,它在通信两端各建立一个Socket,从而在两端形成网络虚拟链路,进而应用程序可通过可以通过虚拟链路进行通信.Java对于基于TCP协议的网络通 ...

  3. Android应用源码图书馆管理系统带服务端数据库

    本项目是一套基于安卓的图书馆管理系统,包括jsp服务端源码,安卓客户端源码和mysql数据库.代码比较简单,供学习anroid与j2ee交互.例如Sqlite的使用.安卓客户端与jsp的web服务端的 ...

  4. IOS 推送消息 php做推送服务端

    IOS推送消息是许多IOS应用都具备的功能,最近也在研究这个功能,参考了很多资料终于搞定了,下面就把步骤拿出来分享下: iOS消息推送的工作机制可以简单的用下图来概括: Provider是指某个iPh ...

  5. TYPESDK手游聚合SDK服务端设计思路与架构之三:流程优化之订单保存与通知

    经过前两篇文字的分析与设计,我们已经可以搭建出一个能够支持多游戏多渠道的聚合SDK服务端,但这只是理想化状态下的一个简化模型.如果接入渠道的逻辑都是按照理想化的简化过程来构建,那么对于支付的请求,我们 ...

  6. 手写内网穿透服务端客户端(NAT穿透)原理及实现

    Hello,I'm Shendi. 这天心血来潮,决定做一个内网穿透的软件. 用过花生壳等软件的就知道内网穿透是个啥,干嘛用的了. 我们如果有服务器(比如tomcat),实际上我们在电脑上开启了服务器 ...

  7. TYPESDK手游聚合SDK服务端设计思路与架构之一:应用场景分析

    TYPESDK 服务端设计思路与架构之一:应用场景分析 作为一个渠道SDK统一接入框架,TYPESDK从一开始,所面对的需求场景就是多款游戏,通过一个统一的SDK服务端,能够同时接入几十个甚至几百个各 ...

  8. eclipse使用CXF3.1.*创建webservice服务端客户端以及客户端手机APP(二)

    eclipse使用CXF3.1.*创建webservice服务端客户端以及客户端手机APP(二) 接上篇博客,本篇博客主要包含两个内容: 4.使用Android studio创建webservice客 ...

  9. eclipse使用CXF3.1.*创建webservice服务端客户端以及客户端手机APP(一)

    eclipse使用CXF3.1.*创建webservice服务端客户端以及客户端手机APP(一) 本篇博客主要包含五个内容: 1.CXF换将搭建以及eclipse配置CXF. 2.eclipse创建w ...

随机推荐

  1. Mac OS 10.12使用U盘重装(转)

    OS X Capitan和macOS Sierra的安装方式和下载系统的方法都是一致的,下面是OS X Capitan的安装方法: 一.准备工作: 准备一个8GB或者8G以上容量的U盘 确保里面的数据 ...

  2. Mac下快速新建txt文件

    1.打开终端,定位到桌面 cd desktop 2.输入 vi test.txt 此时,一个txt文件就会建立在桌面上,操作vi时的提示:按[i]为输入内容,编辑好之后按[esc]键,然后输入[:wq ...

  3. 初始设置ubuntu 16.04 Vps部署rails

    参考 https://blog.longwin.com.tw/2005/12/ssh_keygen_no_passwd/ 1 选择搬瓦工左边菜单栏中的“Root password modificati ...

  4. Linux下iptables 禁止端口和开放端口

    1.关闭所有的 INPUT FORWARD OUTPUT 只对某些端口开放.下面是命令实现: iptables -P INPUT DROP iptables -P FORWARD DROP iptab ...

  5. java几个经典的算法题目----------二维矩阵算法

    public class testClockwiseOutput { public static void main(String[] args) { //1.构建矩阵数据 int[][] arr = ...

  6. 《Think Python》第16章学习笔记

    目录 <Think Python>第16章学习笔记 16.1 Time 16.2 纯函数(Pure functions) 16.3 修改器(Modifiers) 16.4 原型 vs. 方 ...

  7. JS日期、月份的加减

    JS日期.月份的加减 需要注意的是返回的月份是从0开始计算的,也就是说返回的月份要比实际月份少一个月,因此要相应的加上1 // 日期,在原有日期基础上,增加days天数,默认增加1天 function ...

  8. [javaSE] 数据结构(栈)

    栈(stack)是一种线性存储结构,有以下特点: 1.栈中数据是按照先进后出的方式进出栈的 2.向栈中添加删除元素时,只能从栈顶进行操作 使用数组实现栈 定义一个类ArrayStack 实现入栈方法p ...

  9. [javaSE] 多线程(守护线程)

    我们一般使用多线程,都是while的死循环,想要结束线程,只需退出死循环即可 当线程中调用了sleep()方法或者wait()方法,当前的线程就会进入冻结状态,这个线程就结束不了 调用Thread对象 ...

  10. [C#]浅谈协变与逆变

    看过几篇说协变与逆变的博客,虽然都是正确无误的,但是感觉都没有说得清晰明了,没有切中要害.那么我也试着从我的理解角度来谈一谈协变与逆变吧. 什么是协变与逆变 MSDN的解释:https://msdn. ...