Merge pull request #26571 from vpisarev:fix_26497

Fixed issue when std::vector<T> is wrapped into Mat with explicit step. #26571

Hopefully, fixes #26497

- [x] I agree to contribute to the project under Apache 2 License.
- [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV
- [x] The PR is proposed to the proper branch
- [x] There is a reference to the original bug report and related work
- [x] There is accuracy test, performance test and test data in opencv_extra repository, if applicable
      Patch to opencv_extra has the same branch name.
- [ ] The feature is well documented and sample code can be built with the project CMake
This commit is contained in:
Vadim Pisarevsky 2024-12-05 09:03:51 +03:00 committed by GitHub
parent c69b5524ff
commit 446787ab48
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 13 additions and 1 deletions

View File

@ -895,7 +895,7 @@ Mat::Mat(Size _sz, int _type, void* _data, size_t _step)
size_t esz = CV_ELEM_SIZE(_type), esz1 = CV_ELEM_SIZE1(_type); size_t esz = CV_ELEM_SIZE(_type), esz1 = CV_ELEM_SIZE1(_type);
size_t minstep = cols*esz; size_t minstep = cols*esz;
if( _step == AUTO_STEP ) if( _step == AUTO_STEP || (_step < minstep && rows == 1))
{ {
_step = minstep; _step = minstep;
} }

View File

@ -1200,5 +1200,17 @@ TEST(Imgproc_Remap, issue_23562)
} }
} }
TEST(Imgproc_Resize, issue_26497)
{
std::vector<float> vec = {0.f, 1.f, 2.f, 3.f};
Mat A(vec), B;
resize(A, B, Size(2,2), 0, 0, INTER_LINEAR);
double minv = 0, maxv = 0;
cvtest::minMaxIdx(B, &minv, &maxv, nullptr, nullptr, noArray());
EXPECT_EQ(B.size(), Size(2, 2));
EXPECT_LE(0., minv);
EXPECT_LE(maxv, 3.);
}
}} // namespace }} // namespace
/* End of file. */ /* End of file. */