当前位置: 首页 > 编程日记 > 正文

OpenCV 【一】—— OpenCV中数组指针、图像分块计算、指针取像素值与MatToEigen方法,内存对齐

{
Topic1:
高效开辟内存,使适用于大型数组。//开辟新数组,或者开辟新的0或者某一数值的数组/Mat或者Map直接使用memset
//大数组操作效率较高
举例1:cv::Mat cv_ncc_temp(cv_input_32f.rows, cv_input_32f.cols, CV_8UC1);memset(cv_ncc_temp.data, 0, cv_input_32f.rows*cv_input_32f.cols * sizeof(uint8_t));
举例2:memset(cv_binary_image.data, 255, cv_input_32f.rows*cv_input_32f.cols / 4);
举例3:cv::Mat block_flag(max_row, max_col, CV_8UC1);memset(block_flag.data, 0, max_row * max_col * sizeof(uint8_t));//行指针如下
举例1:*****注意 行指针,整行取出所有元素,列变量便利有两种方式第一种通过pncc++,指针的方式来操控元素沿着列方向遍历。for (int i = xy_off; i < cv_input_32f.rows - xy_off; ++i) {uint8_t* psen = cv_ncc_result_temp.ptr<uint8_t>(i);float* pncc = cv_ncc_result.ptr<float>(i - xy_off);for (int j = xy_off; j < cv_input_32f.cols - xy_off; ++j) {*psen = (uint8_t)((*(pncc-xy_off) + 1)*127.5f);pncc++;psen++;}}
等价于:
cv_ncc_result.at<uint8_t>(i,j) = (uint8_t)((cv_ncc_result_temp.at<float>(i-xy_off,j-xy_off))+1)*127.5f举例2:*****行指针去除整行,列指针通过 *(psen+j)随着for循环中的j增加而移动,与举例1中常用的两种方式。内存溢出情况:主要差一些指针上线,尤其是上限边缘出,当不规则的分块或者分类出现时,内存溢出常出现的位置位于此的概率增大。for (int row = 0; row < max_row - 1; ++row) {uint8_t* pblock = block_flag.ptr<uint8_t>(row);for (int col = 0; col < max_col - 1; ++col) {int count = 0;for (int i = row * BLOCK_HEIGHT; i < (row + 1) * BLOCK_HEIGHT; i++) {uint8_t* psen = cv_ncc_result_temp.ptr<uint8_t>(i);for (int j = col * BLOCK_WIDTH; j < (col + 1) * BLOCK_WIDTH; j++) {if ((*(psen + j)) > 165 && (*(psen + j)) < 179) {count++;}}}if (count > 60) {*(pblock + col) = 1;}}}
Topic2:
多指针同时操作,图像分块赋值,指针越界问题定位思路
举例3:*****1)不同for循环中的不同名称的指针不会相互影响2)*(pblock1 + (j >> 6)等价于block_flag.at<uint8_t>(i/64,j/64) == 0for (int i = 0; i < cv_input_32f.rows; ++i) {uint8_t* pdata = cv_ncc_result_temp.ptr<uint8_t>(i);uint8_t* pblock1 = block_flag.ptr<uint8_t>(i >> 6);///for (int j = 0; j < cv_input_32f.cols; ++j) {if (*(pblock1 + (j >> 6)) == 0)///{if (*(pdata + j) < BACK_GROUND) {(*(pdata + j)) = 0;}}else {if (*(pdata + j) < FORE_GROUND) {(*(pdata + j)) = 0;}}}}Topic3:
Eigen::Map与Mat相互转换
举例1:通过指针操作将cv_ncc_result_temp的值赋值给blurred_image,完成Mat到eigen::map的转换for (int i = xy_off; i < cv_input_32f.rows - xy_off; ++i) {uint8_t* pdata = cv_ncc_result_temp.ptr<uint8_t>(i);for (int j = xy_off; j < cv_input_32f.cols - xy_off; ++j) {uint8_t* pimage = (uint8_t*)(&blurred_image((i + roi[1]), (j + roi[0])));//取指针,以指针元素操作,提高操作效率*pimage = (uint8_t) *(pdata + j);}}
举例2:通过指针操作完成cv_binary_image到binary_image的赋值,完成Mat到eigen::map的转换for (int i = 0; i < (int)(roi_rect.height / scale_binary); ++i) {uint8_t* pimage1 = (uint8_t*)(&binary_image(i + roi[1] / scale_binary, roi[0] / scale_binary));memcpy(pimage1, cv_binary_image.ptr<uint8_t>(i), roi_rect.width / scale_binary);}}

注意:

Eigen头文件要在opencv的eigen.hpp之前,否则报错!

Eigen中Matrix 与OpenCV中Mat间的转换

matrix->mat:eigen2cv

vector->mat:eigen2cv

mat->matrix:cv2eigen

mat->vector:cv2eigen

  Matx33d EE;for (int i = 0; i<3; i++)for (int j = 0; j < 3; j++) {//std::cout << "E =" << E.at<double>(i, j) << std::endl;EE(i, j) = E.at<double>(i, j);//std::cout << "E =" << EE(i, j) << std::endl;}std::cout << "EE =" << EE << std::endl;

Eigen与Opencv之间的转换,在包含Eigen库的基础上,#include<opencv2/core/eigen.hpp>

rr = (cv::Mat_<double>(3, 3) << -0.0001, -0.2, 3, 4, 5, 6, 7, 8, 791);

将Eigen::Matrix转换为cv::Mat

cv::eigen2cv(matrix,mat);

  Matx33d EE;for (int i = 0; i<3; i++)for (int j = 0; j < 3; j++) {//std::cout << "E =" << E.at<double>(i, j) << std::endl;EE(i, j) = E.at<double>(i, j);std::cout << "E =" << EE(i, j) << std::endl;}std::cout << "EE =" << EE << std::endl;  std::string filename3 = "./debug_output/xEx_output.txt";FILE* fp3 = fopen(filename3.c_str(), "at+");for (int i = 0; i < points1.size(); i++) {Vec3d x1(points1[i].x, points1[i].y, 1.);Vec3d x2(points2[i].x, points2[i].y, 1.);// Matx33d E(model.ptr<double>());// E = cv::eigen2cv(E, ee);// Eigen::Matrix3d er;//cv::cv2eigen(E, er);cv::Mat rr;Eigen::Matrix3d er;// rr = (cv::Mat_<double>(3, 3) << -0.0001, -0.2, 3, 4, 5, 6, 7, 8, 791);// cv::cv2eigen(rr, er);  //cv  to eigen Matx33d EE(-0.0001, -0.2, 3, 4, 5, 6, 7, 8, 791);Vec3d Ex1 = EE * x1;Vec3d Etx2 = EE.t() * x2;float x2tEx1 = x2.dot(Ex1);fprintf(fp3,"%10.8f\n",x2tEx1);} fclose(fp3);

A::BB(目标类型)cConverter::XXXX(const C::DD(代转类型) &XXX){……}

cv::Mat cConverter::toCvMatInverse(const cv::Mat &Tcw){cv::Mat Rcw = Tcw.rowRange(0,3).colRange(0,3);cv::Mat tcw = Tcw.rowRange(0,3).col(3);cv::Mat Rwc = Rcw.t();cv::Mat twc = -Rwc*tcw;cv::Mat Twc = cv::Mat::eye(4,4,Tcw.type());Rwc.copyTo(Twc.rowRange(0,3).colRange(0,3));twc.copyTo(Twc.rowRange(0,3).col(3));return Twc.clone();}cv::Mat cConverter::toCvMat(const Eigen::Matrix<double,3,1> &m){cv::Mat cvMat(3,1,CV_32F);for(int i=0;i<3;i++)cvMat.at<float>(i)=m(i);return cvMat.clone();}cv::Mat cConverter::Matrix3dtoCvMat(const Eigen::Matrix3d &m){cv::Mat cvMat(3,3,CV_32F);for(int i=0;i<3;i++)for(int j=0; j<3; j++)cvMat.at<float>(i,j)=m(i,j);return cvMat.clone();}cv::Mat cConverter::Matx33dtoCvMat(const Eigen::Matrix3d &m){cv::Mat cvMat(3,3,CV_32F);for(int i=0;i<3;i++)for(int j=0; j<3; j++)cvMat.at<float>(i,j)=m(i,j);return cvMat.clone();}cv::Mat cConverter::Matx44dtoCvMat(const Eigen::Matrix<double,4,4> &m){cv::Mat cvMat(4,4,CV_32F);for(int i=0;i<4;i++)for(int j=0; j<4; j++)cvMat.at<float>(i,j)=m(i,j);return cvMat.clone();}Eigen::Matrix<double,3,1> cConverter::toVector3d(const cv::Mat &cvVector){Eigen::Matrix<double,3,1> v;v << cvVector.at<float>(0), cvVector.at<float>(1), cvVector.at<float>(2);return v;}Eigen::Matrix<double,3,3> cConverter::toMatrix3d(const cv::Mat &cvMat3){Eigen::Matrix<double,3,3> M;M << cvMat3.at<float>(0,0), cvMat3.at<float>(0,1), cvMat3.at<float>(0,2),cvMat3.at<float>(1,0), cvMat3.at<float>(1,1), cvMat3.at<float>(1,2),cvMat3.at<float>(2,0), cvMat3.at<float>(2,1), cvMat3.at<float>(2,2);return M;}//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++cv::Matx44d cConverter::invMat(const cv::Matx44d& M){cv::Matx33d R = M.get_minor<3, 3>(0, 0);R = R.t();cv::Vec3d t(M(0, 3), M(1, 3), M(2, 3));t = -R * t;cv::Matx44d out(R(0, 0), R(0, 1), R(0, 2), t(0),R(1, 0), R(1, 1), R(1, 2), t(1),R(2, 0), R(2, 1), R(2, 2), t(2),0.0, 0.0, 0.0, 1.0);return out;}cv::Matx<double, 4, 4> cConverter::ogv2ocv(const Eigen::Matrix<double, 3, 4>& ogv_mat){cv::Matx34d ocv_mat;cv::eigen2cv(ogv_mat, ocv_mat);return cv::Matx<double, 4, 4>(ocv_mat(0, 0), ocv_mat(0, 1), ocv_mat(0, 2), ocv_mat(0, 3),ocv_mat(1, 0), ocv_mat(1, 1), ocv_mat(1, 2), ocv_mat(1, 3),ocv_mat(2, 0), ocv_mat(2, 1), ocv_mat(2, 2), ocv_mat(2, 3),0.0, 0.0, 0.0, 1.0);}g2o::SE3Quat cConverter::toSE3Quat(const cv::Matx44d& homCV){Eigen::Matrix<double, 3, 3> R;R << homCV(0, 0), homCV(0, 1), homCV(0, 2),homCV(1, 0), homCV(1, 1), homCV(1, 2),homCV(2, 0), homCV(2, 1), homCV(2, 2);Eigen::Matrix<double, 3, 1> t(homCV(0, 3), homCV(1, 3), homCV(2, 3));return g2o::SE3Quat(R, t);}cv::Matx44d cConverter::toCvMat(const g2o::SE3Quat& SE3){Eigen::Matrix<double, 4, 4> eigMat = SE3.to_homogeneous_matrix();return toCvMat(eigMat);}cv::Matx44d cConverter::toCvMat(const g2o::Sim3& Sim3){Eigen::Matrix3d eigR = Sim3.rotation().toRotationMatrix();Eigen::Vector3d eigt = Sim3.translation();double s = Sim3.scale();return toCvSE3(s*eigR, eigt);}cv::Matx44d cConverter::toCvMat(const Eigen::Matrix<double, 4, 4>& m){cv::Matx44d cvMat = cv::Matx44d::eye();cv::eigen2cv(m, cvMat);return cvMat;}cv::Matx33d cConverter::toCvMat(const Eigen::Matrix3d& m){cv::Matx33d cvMat = cv::Matx33d::eye();cv::eigen2cv(m, cvMat);return cvMat;}cv::Matx44d cConverter::toCvSE3(const Eigen::Matrix<double, 3, 3>& R,const Eigen::Matrix<double, 3, 1> &t){cv::Matx44d cvMat = cv::Matx44d::eye();for (int i = 0; i < 3; ++i)for (int j = 0; j < 3; ++j)cvMat(i, j) = R(i, j);for (int i = 0; i < 3; ++i)cvMat(i, 3) = t(i);return cvMat;}Eigen::Matrix<double, 3, 1> cConverter::toVector3d(const cv::Vec4d& cvVector){Eigen::Matrix<double, 3, 1> v;v << cvVector(0), cvVector(1), cvVector(2);return v;}Eigen::Matrix<double, 3, 1> cConverter::toVector3d(const cv::Vec3d& cvVector){Eigen::Matrix<double, 3, 1> v;v << cvVector(0), cvVector(1), cvVector(2);return v;}Eigen::Matrix<double, 3, 3> cConverter::toMatrix3d(const cv::Matx33d& cvMat3){Eigen::Matrix<double, 3, 3> M;M << cvMat3(0, 0), cvMat3(0, 1), cvMat3(0, 2),cvMat3(1, 0), cvMat3(1, 1), cvMat3(1, 2),cvMat3(2, 0), cvMat3(2, 1), cvMat3(2, 2);return M;}cv::Mat cConverter::toMat(const cv::Matx44d& matx44d){cv::Mat out = cv::Mat::zeros(4, 4, CV_64FC1);for (int c = 0; c < 4; ++c)for (int r = 0; r < 4; ++r)out.ptr<double>(r)[c] = matx44d(r, c);return out;}

参考网址:

https://blog.csdn.net/u011722133/article/details/80118330

https://blog.csdn.net/piaoxuezhong/article/details/79110421

https://blog.csdn.net/u012706484/article/details/78775360

相关文章:

【Java】类与对象 - 参数传值

目录 面向过程语言简介 面向对象语言简介 面向对象编程的三个特性 参数传值 传值机制 基本数据类型的参数的传值 引用类型参数的传值 可变参数 面向过程语言简介 核心是编写解决问题某个问题的代码块&#xff0c;代码块是程序执行时产生的一种行为。面向过程语言缺少一…

新闻发布项目——业务逻辑层(newsTbService)

package bdqn.newsManageServlet.Service;import java.util.List;import bdqn.newsManageServlet.entity.newsTb;/*** 新闻业务逻辑层的接口* author Administrator**/ public interface newsTbService {//分页查询public List<newsTb>getPagingNews(int pagesize,int pa…

使用阿里云发布分布式网站,开发时候应该注意什么?

虽然之前写过关于负载均衡的文章&#xff0c;但是似乎大家都对负载均衡这个标题很陌生。今天就换个角度&#xff0c;从分布式网站发布角度说一下 首先&#xff0c;网站发布一定离不开服务器&#xff0c;就是阿里云的云服务器ECS。最近发现&#xff0c;老用户也有机会购买特价服…

【Java】类与对象 - 对象的组合

一个类的成员变量可以是Java允许的任何数据类型&#xff0c;因此&#xff0c;一个类可以把某个对象作为自己的成员变量&#xff0c;也就是说&#xff0c;该对象将其他对象作为自己的组成部分。 组合和复用 如果一个对象a组合了对象b&#xff0c;那么对象a就可以委托对象b调用…

CMakeLists.txt学习记录

一、Cmake 学习地址与作用 cmake详细见&#xff1a;https://gitlab.kitware.com/cmake/community/-/wikis/home 是一个跨平台、开源的构建系统。它是一个集软件构建、测试、打包于一身的软件。它使用与平台和编译器独立的配置文件来对软件编译过程进行控制。 二、常用命令 …

20145223《信息安全系统设计》 实验四 驱动程序设计

20145223杨梦云《信息安全系统设计》实验四实验报告 一、配置开发环境&#xff08;同实验一&#xff09; 二、阅读和理解源代码 进入/arm2410cl/exp/drivers/01_demo&#xff0c;使用vi编辑器或其他编辑器阅读理解源代码。 三、编译驱动模块及测试程序 上面介绍了在 Makefile 中…

Android屏幕适配框架-(今日头条终极适配方案)

2019独角兽企业重金招聘Python工程师标准>>> 在Android开发中,屏幕适配是一个非常头痛的问题,因而为了去进行屏幕适配,作为程序员,是呕心沥血,历经磨难,哈哈 我们之前做屏幕适配一般都会用到一下两种方式: 我们之前做屏幕适配一般都会用到一下两种方式: 第一种就是宽…

OpenCV 【三】————contours便利删除操作方法

int cmin 100;int cmax 1000;vector<vector<Point>>::const_iterator itc contours.begin();while (itc ! contours.end()){if (itc->size() < cmin || itc->size() > cmax)itc contours.erase(itc);elseitc;}

解决myeclipse中新建javaweb工程,无法使用Web App Libraries问题

在myeclipse中新建的java web工程&#xff0c;lib中的jar包无法自动加载工程&#xff0c;不能像eclipse那样使用Web App Libraries。即使添加了Web App Libraries这个libraries&#xff0c;jar包还是如法加入。解决方法&#xff1a;在.project文件中&#xff0c;修改<nature…

企业分布式微服务云SpringCloud SpringBoot mybatis - 服务消费者(Feign)

一、Feign简介 Feign是一个声明式的伪Http客户端&#xff0c;它使得写Http客户端变得更简单。使用Feign&#xff0c;只需要创建一个接口并注解。它具有可插拔的注解特性&#xff0c;可使用Feign 注解和JAX-RS注解。Feign支持可插拔的编码器和解码器。Feign默认集成了Ribbon&…

OpenCV 【四】————Watershed Algorithm(图像分割)——分水岭算法的原理及实现

分水岭算法实现&#xff08;C、opencv&#xff09; 1.作用&#xff1a; 通常用于分割图像&#xff0c;主要实现以临近像素间的相似性作为重要的参考依据&#xff0c;从而将在空间位置上相近并且灰度值相近的像素点互相连接起来构成一个封闭的轮廓&#xff0c;封闭性是分水岭算…

SQL脚本--有关压缩数据库日志

/*--压缩数据库的通用存储过程 压缩日志及数据库文件大小 因为要对数据库进行分离处理 所以存储过程不能创建在被压缩的数据库中 --邹建 2004.03(引用请保留此信息)--*/ /*--调用示例 exec p_compdb test--*/ use master --注意,此存储过程要建在master数据库中Go if exists …

【POJ】1308 Is It A Tree?((并查集 + set)or (map))

http://poj.org/problem?id1308 这个题数组开到200就可以了&#xff0c;但题目中貌似没有说呢&#xff1f; 读入每一对顶点&#xff0c;看看他们是否在同一个集合中&#xff0c;如果是的话&#xff0c;肯定成环&#xff0c;不是一棵树。 用set容器保存节点&#xff0c;最后…

Java程序员修炼之路(一)我们为什么选择Java

我们为什么选择Java大多数人选择Java可能只是因为听说Java前景好、Java比较好找工作、Java语言在TIOBE排行榜上一直位于前三等等之类的原因&#xff0c;但是Java具体好在哪里&#xff0c;心里却是没有什么概念的。其实我选择Java也是出于以上的原因&#xff0c;但是现在确实真正…

iOS10 权限崩溃问题

iOS10 权限崩溃问题 今天 手机升级了 iOS10然后用正在开发的项目 装了个ipa包&#xff0c;发现点击有关 权限访问 直接Crash了&#xff0c;并在控制台输出了一些信息&#xff1a; This app has crashed because it attempted to access privacy-sensitive data without a usage…

OpenCV 【六】————youtu(图像)——旋转保存图片

OpenCV Mat结构的图片 旋转顺时针90度 180度 270度 逆时针90度 Mat matRotateClockWise90(Mat src) {if (src.empty()){qDebug()<<"RorateMat src is empty!";}// 矩阵转置transpose(src, src);//0: 沿X轴翻转&#xff1b; >0: 沿Y轴翻转&#xff1b; <…

【HDU】2087 剪花布条 (KMP算法的应用)

可以参考&#xff1a;从头彻尾彻底理解KMP 可以用朴素的模式匹配算法&#xff0c;也可以使用KMP算法&#xff0c;KMP算法所用的时间较短 普通版 #include <iostream> #include <string>using namespace std;int main () {string s1,s2;while(cin >> s1){i…

081_Introducing trigger handler class

案例分析&#xff1a; 我们对一个Object写多个独立得Trigger。 但最终这不是最好的做法。 在Salesforce中&#xff0c;只为每个SObject设置一个触发器总是好的。 原因&#xff1a;每个独立触发器的执行顺序始终未定义。 因此&#xff0c;如果我们有多个触发器&#xff0c;它可能…

python-opencv 定位识别读表

import cv2 import numpy as np import math import matplotlib.pyplot as plt """ 函数的格式为&#xff1a;kmeans(data, K, bestLabels, criteria, attempts, flags) &#xff08;1&#xff09;data: 分类数据&#xff0c;最好是np.float32的数据&#xff0c…

使用 Vue 2.0 实现服务端渲染的 HackerNews

Vue 2.0 支持服务端渲染 (SSR)&#xff0c;并且是流式的&#xff0c;可以做组件级的缓存&#xff0c;这使得极速渲染成为可能。同时&#xff0c; 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration。vue-hackernews-2.0 是 Vue 作者在GitHub上面放的 Vue 2.0 的一…

【HDU】Flipper 3328 (stack + 模拟 + 英语阅读)

http://acm.hdu.edu.cn/showproblem.php?pid3328 stack模拟&#xff0c;做完这一题最大的感想就是学好英语真的很重要&#xff0c;看题看了半天&#xff0c;还理解错了&#xff0c;这一题&#xff0c;出现L的话&#xff0c;就把最左边的牌翻转&#xff0c;然后放到它旁边的那…

最新阿里Java技术面试题,看这一文就够了!

金三银四跳槽季即将到来&#xff0c;作为 Java 开发者你开始刷面试题了吗&#xff1f;别急&#xff0c;小编整理了阿里技术面试题&#xff0c;看这一文就够了&#xff01;阿里面试题目目录1&#xff1a;技术一面(基础面试题目)2&#xff1a;技术二面&#xff08;技术深度、技术…

OpenCV 【七】————边缘提取算子(图像边缘提取)——canny算法的原理及实现

canny边缘检测实现&#xff08;C、opencv&#xff09; 1.作用&#xff1a; 图像边缘信息主要集中在高频段&#xff0c;通常说图像锐化或检测边缘&#xff0c;实质就是高频滤波。我们知道微分运算是求信号的变化率&#xff0c;具有加强高频分量的作用。在空域运算中来说&#x…

【Python】序列解包 and * 和 ** 的区别

可以使用序列解包功能对多个变量进行赋值。 序列解包也可以用于列表和字典&#xff0c;但对字典使用时&#xff0c;默认是对字典的“键”进行操作&#xff1b; 如果需要对“键&#xff1a;值”进行操作&#xff0c;需要使用字典items()方法&#xff1b; 如果需要对字典的“值…

JavaScript学习笔记—— 4. 变量、作用域和内存问题

ECMAScript变量可能包含两种不同数据类型的值&#xff1a;基本类型值和引用类型值&#xff0c;其中基本类型值是简单的数据段&#xff0c;而引用类型值指的是那些可能由多个值构成的对象&#xff1b;对于5种基本类型数据&#xff1a;undefined&#xff0c; null&#xff0c;boo…

ApacheCN 学习资源汇总 2019.3

【主页】 apachecn.org 【Github】ApacheCN 暂时下线: 社区 暂时下线: cwiki 知识库 自媒体平台 微博&#xff1a;ApacheCN知乎&#xff1a;ApacheCNCSDN简书OSChina博客园We are ApacheCN Open Source Organization, not ASF! We are fans of AI, and have no relationship w…

python数据结构与算法:二叉树及三种遍历方式(先序遍历/中序遍历/后序遍历)

树的实现采用queue的形式&#xff1a; 树的三种遍历方式&#xff08;广度优先白能力法&#xff09;&#xff1a;先序遍历&#xff08;根左右&#xff09;&#xff0c;中序遍历&#xff08;左根右&#xff09;以及后序遍历&#xff08;左右根&#xff09; ###################…

【HDU】3635 Dragon Balls (带权并查集 一)

题目链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid3635 【问题描述】 有标号为1到n的n个龙珠&#xff0c;分别放在对应标号为1到n的n个城市里。 下面有两种操作: T A B表示把A龙珠所在城市的所有龙珠都转移到B龙珠所在的城市中 Q A 表示查询A&#xff0c;需…

php源码安全加密之PHP混淆算法.

php源码安全加密的前世今生,本想发在教程区中.不知道怎么发,就写在这里面吧.PHP加密,解密是一直的话题,本人菜鸟,今天就简单向大家介绍一下并说说其中原理.提供一些加密的混淆算法.一\PHP的加密总体上来说分以下2种:1\扩展组件类加密,代表有:zend\ionCube\SG\php_screw\bcompil…

Element 2.6.0 发布,基于 Vue 2.0 的桌面端组件库

开发四年只会写业务代码&#xff0c;分布式高并发都不会还做程序员&#xff1f; Element 2.6.0 发布了&#xff0c;Element 是一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库&#xff0c;提供了配套设计资源&#xff0c;帮助你的网站快速成型。由饿了么公…