]> gitweb.hhaalo.de Git - sane-kds-s2000w-net.git/commitdiff
change offset y with pixel
authorBastian Dehn <hhaalo@arcor.de>
Sun, 23 Feb 2025 11:21:06 +0000 (12:21 +0100)
committerBastian Dehn <hhaalo@arcor.de>
Thu, 6 Mar 2025 20:44:47 +0000 (21:44 +0100)
src/kds_s2000w_handler_opts.c
src/kds_s2000w_option_descriptors.c
tests/kds_s2000w_option_descriptor_tests.c

index 850f6db7ff3d024423ecec040e41f88540440890..a77d8faa7b1072ecf0739adbac35ab5d1dff5f0b 100644 (file)
@@ -10,6 +10,7 @@
 #define OPTION_COUNT 47
 
 #define OFFSET_X_MAX_INCH 75
+#define OFFSET_Y_MAX_INCH 390
 
 void _kds_s2000w_handler_opts_write_string_value(json_object* value_object, void* value)
 {
@@ -135,17 +136,32 @@ void _kds_s2000w_handler_opts_set_offset_x_range(json_object* config)
        range->quant = kds_s2000w_handler_opts_calc_pixel_quant(dpi);
 }
 
+void _kds_s2000w_handler_opts_set_offset_y_range(json_object* config)
+{
+       SANE_Option_Descriptor* image_offset_x = kds_s2000w_option_descriptors_get_by_name(SANE_NAME_SCAN_TL_Y);
+
+       json_object* object_value = json_object_object_get(config, "DPI");
+       int32_t dpi = json_object_get_int(object_value);
+
+       SANE_Range* range = (SANE_Range*) image_offset_x->constraint.range;
+
+       range->min = 0;
+       range->max = kds_s2000w_handler_opts_calc_inch_to_pixel(dpi, OFFSET_Y_MAX_INCH);
+       range->quant = kds_s2000w_handler_opts_calc_pixel_quant(dpi);
+}
+
 void _kds_s2000w_handler_opts_set_enable_suboptions_cropping_image(json_object* config)
 {
        json_object* cropping_image = json_object_object_get(config, "CroppingImage");;
        const char* cropping_image_value = json_object_get_string(cropping_image);
 
        SANE_Option_Descriptor* image_offset_x = kds_s2000w_option_descriptors_get_by_name(SANE_NAME_SCAN_TL_X);
-       SANE_Option_Descriptor* image_offset_y = kds_s2000w_option_descriptors_get_by_name("image-offset-y");
+       SANE_Option_Descriptor* image_offset_y = kds_s2000w_option_descriptors_get_by_name(SANE_NAME_SCAN_TL_Y);
        SANE_Option_Descriptor* image_width = kds_s2000w_option_descriptors_get_by_name("image-width");
        SANE_Option_Descriptor* image_height = kds_s2000w_option_descriptors_get_by_name("image-height");
 
        _kds_s2000w_handler_opts_set_offset_x_range(config);
+       _kds_s2000w_handler_opts_set_offset_y_range(config);
 
        if (strcmp(cropping_image_value, "PartialDocument") == 0) {
                image_offset_x->cap |= SANE_CAP_SOFT_SELECT;
@@ -260,25 +276,25 @@ void _kds_s2000w_handler_opts_set_enable_color_drop_out_aggressiveness(json_obje
        color_drop_out_aggressiveness->cap &= ~SANE_CAP_SOFT_SELECT;
 }
 
-void _kds_s2000w_handler_opts_get_offset_x_value(json_object* config, void* value)
+void _kds_s2000w_handler_opts_get_pixel_value_from_inch(json_object* config, const char* option_name, void* value)
 {
        int32_t* pixel = (int32_t*) value;
 
        json_object* object_value = json_object_object_get(config, "DPI");
        int32_t dpi = json_object_get_int(object_value);
-       object_value = json_object_object_get(config, "ImageOffsetX");
+       object_value = json_object_object_get(config, option_name);
        int32_t inch = json_object_get_int(object_value);
 
        *pixel = kds_s2000w_handler_opts_calc_inch_to_pixel(dpi, inch);
 }
 
-void _kds_s2000w_handler_opts_set_offset_x_value(json_object* config, void* value)
+void _kds_s2000w_handler_opts_set_inch_value_from_pixel(json_object* config, const char* option_name, void* value)
 {
        int32_t* pixel = (int32_t*) value;
 
        json_object* object_value = json_object_object_get(config, "DPI");
        int32_t dpi = json_object_get_int(object_value);
-       object_value = json_object_object_get(config, "ImageOffsetX");
+       object_value = json_object_object_get(config, option_name);
        int32_t inch = kds_s2000w_handler_opts_calc_pixel_to_inch(dpi, *pixel);
 
        _kds_s2000w_handler_opts_write_int_value_to_json(object_value, &inch);
@@ -340,7 +356,7 @@ void kds_s2000w_handler_opts_get_option(handler* h, uint32_t option, void* value
                        _kds_s2000w_handler_opts_write_string_value(value_object, value);
                        break;
                case 9:
-                       _kds_s2000w_handler_opts_get_offset_x_value(config, value);
+                       _kds_s2000w_handler_opts_get_pixel_value_from_inch(config, "ImageOffsetX", value);
                        break;
                case 10:
                        value_object = json_object_object_get(config, "ImageOffsetY");
@@ -540,11 +556,10 @@ void kds_s2000w_handler_opts_set_option(handler* h, uint32_t option, void* value
                                *info = RELOAD_OPTIONS;
                        break;
                case 9:
-                       _kds_s2000w_handler_opts_set_offset_x_value(config, value);
+                       _kds_s2000w_handler_opts_set_inch_value_from_pixel(config, "ImageOffsetX", value);
                        break;
                case 10:
-                       value_object = json_object_object_get(config, "ImageOffsetY");
-                       _kds_s2000w_handler_opts_write_int_value_to_json(value_object, value);
+                       _kds_s2000w_handler_opts_set_inch_value_from_pixel(config, "ImageOffsetY", value);
                        break;
                case 11:
                        value_object = json_object_object_get(config, "ImageWidth");
index 5b0a26a6ed6f1ea6dafedbc7e68ace2c530a612f..a1de069f691f537c5d364b4c5b8f46caa9262660 100644 (file)
@@ -970,15 +970,15 @@ SANE_Option_Descriptor _kds_s2000w_option_descriptor_image_offset_y()
 
        SANE_Range* constraint = malloc(sizeof(SANE_Range));
        constraint->min = 0;
-       constraint->max = 390;
-       constraint->quant = 1;
+       constraint->max = 7800;
+       constraint->quant = 20;
 
        SANE_Option_Descriptor descriptor = {
-               "image-offset-y",
-               "Image Offset Y",
-               "Image Offset Y",
+               SANE_NAME_SCAN_TL_Y,
+               SANE_TITLE_SCAN_TL_Y,
+               SANE_DESC_SCAN_TL_Y,
                SANE_TYPE_INT,
-               SANE_UNIT_NONE,
+               SANE_UNIT_PIXEL,
                sizeof(SANE_Int),
                SANE_CAP_SOFT_DETECT | SANE_CAP_SOFT_SELECT,
                SANE_CONSTRAINT_RANGE,
index 15368e199c1bda0d913996c99237e05fd7976c6a..f0635ccb14bb1432235c60d70ffd184e5b37c061 100644 (file)
@@ -191,17 +191,17 @@ void kds_s2000w_option_get_descriptor_ten_test()
 {
        SANE_Option_Descriptor* option = kds_s2000w_option_descriptors_get(10);
 
-       assert_string_equal("image-offset-y", option->name);
-       assert_string_equal("Image Offset Y", option->title);
-       assert_string_equal("Image Offset Y", option->desc);
+       assert_string_equal(SANE_NAME_SCAN_TL_Y, option->name);
+       assert_string_equal(SANE_TITLE_SCAN_TL_Y, option->title);
+       assert_string_equal(SANE_DESC_SCAN_TL_Y, option->desc);
        assert_int_equal(SANE_TYPE_INT, option->type);
-       assert_int_equal(SANE_UNIT_NONE, option->unit);
+       assert_int_equal(SANE_UNIT_PIXEL, option->unit);
        assert_int_equal(sizeof(SANE_Int), option->size);
        assert_int_equal(SANE_CAP_SOFT_DETECT | SANE_CAP_SOFT_SELECT, option->cap);
        assert_int_equal(SANE_CONSTRAINT_RANGE, option->constraint_type);
        assert_int_equal(option->constraint.range->min, 0);
-       assert_int_equal(option->constraint.range->max, 390);
-       assert_int_equal(option->constraint.range->quant, 1);
+       assert_int_equal(option->constraint.range->max, 7800);
+       assert_int_equal(option->constraint.range->quant, 20);
 }
 
 void kds_s2000w_option_get_descriptor_eleven_test()