linux python 笔记

linux python 笔记

纯粹个人笔记好查找

  1. 创建Python软链接
sudo ln -s /usr/bin/python3.8 /usr/bin/python

Python对应的OpenCV可以很好看到图片矩阵中的内容(c++我只会看到指针地址),用于了解rgba数据存储格式,便于以后图片分析

import cv2 as cv
import numpy as np
fn = 'fruits.jpg'
img = cv.imread(cv.samples.findFile(fn))
rgba=cv.cvtColor(img,cv.COLOR_RGB2RGBA)

cv.imshow("fruits",rgba)

cv.waitKey()
cv.destroyAllWindows()

以下0-3分别对应图片中的rgba四个通道;a透明度全为0xFF
RGBA数据存储情况

图片按像素处理python

def assignment_new_image(image):
    (height,width,channels)=image.shape #获取图高、宽、通道
    dest_image = np.zeros([height,width,channels],np.uint8)
    for row in range(height):
        for col in range(width):
            for c in range(channels):
                pv=image[row,col,c]
                dest_image[row,col,c]=pv
    return dest_image

图片按像素操作(C++)

Mat src = imread("test/2715DTZ.jpg");
imshow("src", src);
Mat rgba;
cvtColor(src, rgba, COLOR_BGR2BGRA);
imshow("rgba", rgba);
// Mat new_img;
// new_img.create(rgba.size(), rgba.type());//
Mat new_img(rgba.rows, rgba.cols, CV_8UC4);
int channel = rgba.channels(); //
for (int i = 0; i < rgba.rows; i++)
{
	for (int j = 0; j < rgba.cols; j++)
	{
		if (channel == 1)
		{
			new_img.at<uchar>(i, j) = rgba.at<uchar>(i, j);
		}
		else if (channel == 4)
		{
			// cout << "i=" << i << ";j=" << j << endl;
			new_img.at<Vec4b>(i, j)[0] = rgba.at<Vec4b>(i, j)[0];
			new_img.at<Vec4b>(i, j)[1] = rgba.at<Vec4b>(i, j)[1];
			new_img.at<Vec4b>(i, j)[2] = rgba.at<Vec4b>(i, j)[2];
			new_img.at<Vec4b>(i, j)[3] = rgba.at<Vec4b>(i, j)[3];
		}
	}
}

imshow("new_img", new_img);

ndk中对YUV格式图片转换成RGBA格式图片


/*
 * PresentImage90()
 *   Converting YUV to RGB
 *   Rotation image anti-clockwise 90 degree -- (x, y) --> (-y, x)
 */
void ImageReader::PresentImage90(ANativeWindow_Buffer *buf, AImage *image) {
    AImageCropRect srcRect;
    AImage_getCropRect(image, &srcRect);

    int32_t yStride, uvStride;
    uint8_t *yPixel, *uPixel, *vPixel;
    int32_t yLen, uLen, vLen;
    AImage_getPlaneRowStride(image, 0, &yStride);
    AImage_getPlaneRowStride(image, 1, &uvStride);
    AImage_getPlaneData(image, 0, &yPixel, &yLen);
    AImage_getPlaneData(image, 1, &vPixel, &vLen);
    AImage_getPlaneData(image, 2, &uPixel, &uLen);
    int32_t uvPixelStride;
    AImage_getPlanePixelStride(image, 1, &uvPixelStride);
//    Mat src = imread("/sdcard/DCIM/Camera/capture.jpg");

    int32_t height = MIN(buf->width, (srcRect.bottom - srcRect.top));
    int32_t width = MIN(buf->height, (srcRect.right - srcRect.left));
    Mat dst_src(height, width, CV_8UC4);
    uint32_t *out = static_cast<uint32_t *>(buf->bits);
    out += height - 1;
    for (int32_t y = 0; y < height; y++) {
        const uint8_t *pY = yPixel + yStride * (y + srcRect.top) + srcRect.left;

        int32_t uv_row_start = uvStride * ((y + srcRect.top) >> 1);
        const uint8_t *pU = uPixel + uv_row_start + (srcRect.left >> 1);
        const uint8_t *pV = vPixel + uv_row_start + (srcRect.left >> 1);

        for (int32_t x = 0; x < width; x++) {
            const int32_t uv_offset = (x >> 1) * uvPixelStride;
            // [x, y]--> [-y, x]
            out[x * buf->stride] = YUV2RGB(pY[x], pU[uv_offset], pV[uv_offset]);
            int32_t pix = YUV2RGB(pY[x], pU[uv_offset], pV[uv_offset]);
            uchar r=((pix&0x00ff0000)>>16);
            uchar g=((pix&0x0000ff00)>>8);
            uchar b=((pix&0x000000ff));

            dst_src.at<Vec4b>(y, x)[0] = r;
            dst_src.at<Vec4b>(y, x)[1] = g;
            dst_src.at<Vec4b>(y, x)[2] = b;
            dst_src.at<Vec4b>(y, x)[3] = 255;
        }
        out -= 1;  // move to the next column
    }
    imwrite("/sdcard/DCIM/Camera/capture1.jpg", dst_src);
}

图片多通道合并并展示

	clock_t startTime, endTime;

	uchar arr[4][height][width];
	uchar arr1[4 * height * width];
	int channel = rgba.channels(); //
	startTime = clock();		   //计时开始
	for (int i = 0; i < rgba.rows; i++)
	{
		for (int j = 0; j < rgba.cols; j++)
		{
			if (channel == 1)
			{
				new_img.at<uchar>(i, j) = rgba.at<uchar>(i, j);
			}
			else if (channel == 4)
			{
				// cout << "i=" << i << ";j=" << j << endl;
				new_img.at<Vec4b>(i, j)[0] = rgba.at<Vec4b>(i, j)[0];
				new_img.at<Vec4b>(i, j)[1] = rgba.at<Vec4b>(i, j)[1];
				new_img.at<Vec4b>(i, j)[2] = rgba.at<Vec4b>(i, j)[2];
				new_img.at<Vec4b>(i, j)[3] = rgba.at<Vec4b>(i, j)[3];
				// uchar b = rgba.at<Vec4b>(i, j)[0];
				// uchar g = rgba.at<Vec4b>(i, j)[1];
				// uchar r = rgba.at<Vec4b>(i, j)[2];
				// uchar a = rgba.at<Vec4b>(i, j)[3];
				// int y = i;
				// int x = j;

				// arr[0][y][x] = b;
				// arr[1][y][x] = g;
				// arr[2][y][x] = r;
				// arr[3][y][x] = a;
				// *(arr1 + i * width + j) = b;
				// *(arr1 + height * width + i * width + j) = g;
				// *(arr1 + height * width * 2 + i * width + j) = r;
				// *(arr1 + height * width * 3 + i * width + j) = a;
			}
		}
	}

	endTime = clock(); //计时结束
	cout << "The run time is: " << (double)(endTime - startTime) / CLOCKS_PER_SEC << "s" << endl;
	vector<Mat> channels1;
	// Mat arr_img(Size(width, height), CV_8UC4, arr);
	Mat arr_img;
	// split(arr_img, channels1);
	channels1.push_back(Mat(Size(width, height), CV_8UC1, arr[0]));
	channels1.push_back(Mat(Size(width, height), CV_8UC1, arr[1]));
	channels1.push_back(Mat(Size(width, height), CV_8UC1, arr[2]));
	channels1.push_back(Mat(Size(width, height), CV_8UC1, arr[3]));

	Mat arr_img1(Size(width, height), CV_8UC4, arr1);
	cvtColor(arr_img1, arr_img1, COLOR_RGBA2RGB);
	merge(channels1, arr_img);
	imshow("arr_img", arr_img);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Python笔记.md 是一个用于记录Python编程相关内容的markdown文档。 在Python学习过程中,学习者通常会遇到各种问题和疑惑,需要有一个地方来记录学习笔记和重要概念,以方便日后复习和查阅。Python笔记.md 就是一个很好的选择。 Python笔记.md 可以按照自己的需要来组织内容,比如可以分为不同的章节或主题,并使用markdown语法来格式化文档,使其更加清晰易读。 在Python笔记.md中,可以记录Python的基础语法、常用数据结构、函数、类、模块等内容。此外,还可以记录一些常见的错误和解决方法,以便日后遇到类似问题时能够快速找到解决方案。 Python笔记.md 还可以用来记录自己的思考和理解。在学习过程中,我们常常会思考某个概念或代码背后的原理,这时候可以将自己的思考记录在笔记中,以便后续复习和回顾。 使用Python笔记.md 还可以方便与他人分享学习心得。可以在文档中加入注释或标题,使得文档更加易读和友好。同时,也可以将Python笔记.md 推送到版本控制系统中,与他人共享和共同编辑。 总之,Python笔记.md 是一个非常有用的工具,可以帮助学习者系统地记录、整理和复习Python编程相关的知识和经验。无论是初学者还是有经验的开发者,都可以从中受益,并提高自己的编程技能。 ### 回答2: Python笔记.md是一个使用Markdown语法编写的Python笔记文档。Markdown语法是一种轻量级的标记语言,可以快速地编辑和排版文档。 在Python笔记.md中,可以记录Python程序设计的相关知识、概念和技巧。通过使用Markdown语法,可以方便地插入代码块、链接、图片以及其他强调和排版格式,使得笔记更加直观和易读。 Python笔记.md可以按照不同的章节和主题组织内容,方便快速查找和阅读。在每个章节中,可以记录不同的Python编程概念,如数据类型、控制结构、函数、类等。可以通过示例代码和解释说明来详细解释这些概念的用法和特点。 在笔记中,还可以记录一些Python的常见问题和解决方案,例如常见错误、调试技巧等。这些内容可以帮助初学者更好地理解和掌握Python语言。 此外,Python笔记.md还可以连接到其他的Python资源,如官方文档、教程、在线代码编辑器等。这样可以提供更多的学习和参考资料。 总之,Python笔记.md是一个有条理、易读和方便编辑的Python学习笔记文档,可以帮助人们更好地学习和理解Python编程语言。 ### 回答3: Python笔记md是一种用来记录Python编程语言相关内容的文本文件格式。它使用Markdown语法来快速、简洁地编写和格式化笔记Python笔记md的优点是: 1. 简单易懂:Markdown语法简洁明了,使用起来非常简单,即便没有编程背景的人也能快速上手。 2. 跨平台兼容:无论是在Windows、Mac还是Linux系统中,Python笔记md都可以轻松使用。 3. 可读性强:Python笔记md的文本格式使得代码和说明可以同时显示,方便读者理解和学习。 4. 方便分享和发布:Python笔记md可以导出为HTML或PDF格式,方便分享给其他人或者发布到网络上。 5. 与开发工具兼容:大多数集成开发环境(IDE)和文本编辑器都支持Markdown语法,可以实时预览和编辑笔记。 使用Python笔记md可以帮助程序员记录代码和相关的解释和说明,方便复习和查看。它还可以用于编写技术博客、文档和教育材料等。而且由于其文本格式的特点,Python笔记md也非常适合使用版本控制系统进行版本管理。 总而言之,Python笔记md是一种简单、灵活且易于分享的笔记格式,可以有效提高编程学习和开发的效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值