当前位置: 首页>>代码示例>>C++>>正文


C++ SharedMemory::setShMemData方法代码示例

本文整理汇总了C++中SharedMemory::setShMemData方法的典型用法代码示例。如果您正苦于以下问题:C++ SharedMemory::setShMemData方法的具体用法?C++ SharedMemory::setShMemData怎么用?C++ SharedMemory::setShMemData使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在SharedMemory的用法示例。


在下文中一共展示了SharedMemory::setShMemData方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: reloadRoute

// 経路情報を読み込み直して画像に反映する
void reloadRoute(string path)
{
	cvtColor(pic, pic_tmp, CV_GRAY2BGR);
	Point prePoint(-1, -1);

	int	x_val, y_val;

	string str, x_str, y_str;
	string searchWord(",");
	string::size_type x_pos, y_pos;

	// csで保存した経路情報の一時ファイルを読み込む
	ifstream ifs(path + ".tmp");
	if (ifs.fail())
	{
		cerr << "False" << endl;
		shMem.setShMemData(false, ISINSERT);
		return;
	}
	//ヘッダ部分をとばす
	getline(ifs, str);

	while (getline(ifs, str))
	{
		//先頭から,までの文字列をint型で取得
		x_pos = str.find(searchWord);
		if (x_pos != string::npos){
			x_str = str.substr(0, x_pos);
			x_val = stoi(x_str);
		}

		//xの値の後ろから,までの文字列をint型で取得
		y_pos = str.find(searchWord, x_pos + 1);
		if (y_pos != string::npos){
			y_str = str.substr(x_pos + 1, y_pos);
			y_val = stoi(y_str);
		}

		//取得した[x,y]を画像に反映
		pic_tmp.at<Vec3b>(y_val, x_val ) = Vec3b(0, 255, 0);
		circle(pic_tmp, cv::Point(x_val, y_val), 10, cv::Scalar(0, 255, 0), 3);
		if (prePoint.x > 0 && prePoint.y > 0) line(pic_tmp, prePoint, Point(x_val, y_val), cv::Scalar(0, 0, 200), 3, 4);

		prePoint = Point(x_val, y_val);
	}
	pic_col = pic_tmp.clone();
	rectangle(pic_tmp, zoomPoint, Point(zoomPoint.x + zoomSize.width, zoomPoint.y + zoomSize.height), cv::Scalar(0, 0, 200), 5, 4);

	imshowResize(string("Origin"), pic_tmp, Size(pic_tmp.cols / reductionRate.width, pic_tmp.rows / reductionRate.height));

	// zoom画像に点を描画
	pic_zoom = Mat(pic_col, Rect(zoomPoint, zoomSize));
	imshow("zoom", pic_zoom);

	::prePoint = prePoint;

	shMem.setShMemData(false, ISCONFIRMED);
	shMem.setShMemData(false, ISINSERT);
}
开发者ID:HORIOJAPAN,项目名称:makeroute,代码行数:60,代码来源:makeroute.cpp

示例2: coodClick

// 左クリックで経路座標を選択
void coodClick(int event, int x, int y, int flag, void* )
{

	// マウスイベントを取得
	switch (event) {
	case cv::EVENT_MOUSEMOVE:
		break;
	case cv::EVENT_LBUTTONDOWN:
		// クリックされた座標をグローバル変数に保存
		xy[0] = x;
		xy[1] = y;

		// 座標を共有メモリに保存
		shMem.setShMemData(true, ISCOODDECISION);
		shMem.setShMemData(x + zoomPoint.x, COOD_X);
		shMem.setShMemData(y + zoomPoint.y, COOD_Y);

		// 座標に点を打つ(確定ではないので一時画像に挿入して表示)
		pic_tmp = pic_zoom.clone();
		pic_tmp.at<Vec3b>(xy[1], xy[0]) = Vec3b(150, 50, 200);
		circle(pic_tmp, Point(xy[0], xy[1]), 4, Scalar(150, 50, 200), 2);
		imshow("zoom", pic_tmp);

		break;
	case cv::EVENT_RBUTTONDOWN:
		break;
	case cv::EVENT_MBUTTONDOWN:
		break;
	case cv::EVENT_LBUTTONUP:
		break;
	case cv::EVENT_RBUTTONUP:
		break;
	case cv::EVENT_MBUTTONUP:
		break;
	case cv::EVENT_LBUTTONDBLCLK:
		break;
	case cv::EVENT_RBUTTONDBLCLK:
		break;
	case cv::EVENT_MBUTTONDBLCLK:
		break;
	}

}
开发者ID:HORIOJAPAN,项目名称:makeroute,代码行数:44,代码来源:makeroute.cpp

示例3: main

void main(int argc, char* argv[])
{
	// コマンドライン引数からパスを取得して画像を読み込む
	pic = imread(argv[1] , 0);

	// 複製
	pic_col = Mat(pic.rows, pic.cols, CV_8UC3);
	cvtColor(pic, pic_col, CV_GRAY2BGR);
	pic_tmp = pic_col.clone();
	pic_zoom = Mat(pic_col, Rect((pic_col.cols - zoomSize.width) / 2, (pic_col.rows - zoomSize.height) / 2,  zoomSize.width, zoomSize.height));

	// 全体画像の縮小率.縦横比固定のためzoomSizeの大きいほうのみで決める
	int largerSize = zoomSize.width > zoomSize.height ? zoomSize.width : zoomSize.height;
	reductionRate = Size(pic.cols / largerSize, pic.rows / largerSize);

	// 全体画像を縮小して表示
	namedWindow("Origin", 1);
	cv::setMouseCallback("Origin", zoomCoodClick, 0);
	imshowResize(string("Origin"), pic_col,Size(pic.cols/reductionRate.width,pic.rows/reductionRate.height));

	// ズーム画像を表示
	namedWindow("zoom", 1 );
	cv::setMouseCallback("zoom", coodClick, 0);
	imshow("zoom", pic_zoom);

	int key;
	while (true){
		key = waitKey(5);
		if (key == 's'){//保存
			string str;
			cout << "s" << endl;
			cout << "保存名=>";
			getline(cin, str);
			imwrite(str, pic_col);
			cout << "Saved" << endl;
		}
		else if (key == 'q' || shMem.getShMemData(ISEXIT))
		{
			string imgname = argv[1];
			imgname += ".jpg";
			imwrite(imgname, pic_col);
			cout << "Saved" << endl;
			shMem.setShMemData(false ,ISEXIT);
			break;
		}
		//点が確定したとき
		if (shMem.getShMemData( ISCONFIRMED ) != 0 )
		{
			// 確定画像にも点を描画
			pic_col.at<Vec3b>(xy[1] + zoomPoint.y, xy[0] + zoomPoint.x) = Vec3b(0, 255, 0);
			circle(pic_col, cv::Point(xy[0] + zoomPoint.x, xy[1] + zoomPoint.y), 10, cv::Scalar(0, 255, 0), 3);
			if (prePoint.x > 0 && prePoint.y > 0) line(pic_col, prePoint, Point(xy[0] + zoomPoint.x, xy[1] + zoomPoint.y), cv::Scalar(0, 0, 200), 3, 4);
			pic_tmp = pic_col.clone();
			rectangle(pic_tmp, zoomPoint, Point(zoomPoint.x + zoomSize.width, zoomPoint.y + zoomSize.height), cv::Scalar(0, 0, 200), 5, 4);

			imshowResize(string("Origin"), pic_tmp, Size(pic_tmp.cols / reductionRate.width, pic_tmp.rows / reductionRate.height));

			prePoint = Point(xy[0] + zoomPoint.x, xy[1] + zoomPoint.y);

			// zoom画像に点を描画
			pic_zoom = Mat(pic_col, Rect(zoomPoint, zoomSize));
			imshow("zoom", pic_zoom);

			shMem.setShMemData( false , ISCONFIRMED );
		}

		// cs側で経路を挿入したら反映のために経路情報を読みこみ直す
		if (shMem.getShMemData(ISINSERT))
		{
			reloadRoute(argv[1]);
		}

	}
}
开发者ID:HORIOJAPAN,项目名称:makeroute,代码行数:74,代码来源:makeroute.cpp


注:本文中的SharedMemory::setShMemData方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。